Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

feat: misc #23

Merged
merged 1 commit into from
Dec 9, 2024
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion pyproject.toml
Original file line number Diff line number Diff line change
Expand Up @@ -9,7 +9,7 @@ build-backend = "hatchling.build"

[project]
name = "swankit"
version = "0.1.2b4"
version = "0.1.2b5"
dynamic = ["readme", "dependencies"]
description = "Base toolkit for SwanLab"
license = "Apache-2.0"
Expand Down
22 changes: 19 additions & 3 deletions swankit/callback/models/key.py
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@
@Description:
与Key相关的回调函数触发时的模型
"""
from typing import Union, Optional, Dict, List, Literal, Tuple, TypedDict
from typing import Union, Optional, Dict, List, Literal, Tuple

from swankit.core import ChartType, ParseErrorInfo, MediaBuffer, ChartReference
from urllib.parse import quote
Expand All @@ -23,28 +23,44 @@ class ColumnConfig:
列信息配置
"""

def __init__(self, y_range: YRange = None, chart_name: Optional[str] = None, metric_name: Optional[str] = None):
def __init__(
self,
y_range: YRange = None,
chart_name: Optional[str] = None,
chart_index: Optional[str] = None,
metric_name: Optional[str] = None,
):
"""
生成的列信息配置对象
:param y_range: y轴范围
:param chart_name: 图表名称
:param chart_index: 图表索引
:param metric_name: 指标名称
"""
self.y_range: YRange = y_range
self.chart_name: Optional[str] = chart_name
self.chart_index: Optional[str] = chart_index
self.metric_name: Optional[str] = metric_name

def clone(self, y_range: YRange = None, chart_name: Optional[str] = None, metric_name: Optional[str] = None):
def clone(
self,
y_range: YRange = None,
chart_name: Optional[str] = None,
chart_index: Optional[str] = None,
metric_name: Optional[str] = None,
):
"""
克隆一个新的ColumnConfig对象,并且可以修改其中的参数
:param y_range: y轴范围
:param chart_name: 图表名称
:param chart_index: 图表索引
:param metric_name: 指标名称
"""
return ColumnConfig(
y_range=y_range if y_range is not None else self.y_range,
chart_name=chart_name if chart_name is not None else self.chart_name,
metric_name=metric_name if metric_name is not None else self.metric_name,
chart_index=chart_index if chart_index is not None else self.chart_index,
)


Expand Down
8 changes: 8 additions & 0 deletions swankit/env.py
Original file line number Diff line number Diff line change
Expand Up @@ -10,6 +10,7 @@
import os
import sys
from enum import Enum
from platform import platform
from typing import List
import datetime

Expand Down Expand Up @@ -77,6 +78,13 @@ def is_windows() -> bool:
raise OSError("Unknown system, not windows or unix-like system")


def is_macos() -> bool:
"""判断当前操作系统是否是macos
:return: True表示是macos系统,False表示不是macos系统
"""
return "mac" in platform().lower()


def create_time() -> str:
"""获取当前时间(UTC时区)"""
return datetime.datetime.now(datetime.timezone.utc).isoformat()
Expand Down
8 changes: 7 additions & 1 deletion test/unit/callback/models/test_key.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,11 @@


def test_column_config():
c = K.ColumnConfig(y_range=(0, 100), chart_name="CPU Utilization (%)")
c = K.ColumnConfig(y_range=(0, 100), chart_name="CPU Utilization (%)", metric_name=None)
assert c.y_range == (0, 100)
assert c.chart_name == "CPU Utilization (%)"
assert c.metric_name is None

clone = c.clone(y_range=None, metric_name="12345")
assert clone.y_range == (0, 100)
assert clone.chart_name == c.chart_name
Expand All @@ -15,6 +16,11 @@ def test_column_config():
assert clone.y_range == (0, 50)
assert clone.chart_name == c.chart_name
assert clone.metric_name == "12345"
c = K.ColumnConfig(y_range=(0, 100), chart_name="CPU Utilization (%)", metric_name="12345", chart_index="1")
assert c.y_range == (0, 100)
assert c.chart_name == "CPU Utilization (%)"
assert c.metric_name == "12345"
assert c.chart_index == "1"


def test_column_info():
Expand Down
Loading