Skip to content

Commit

Permalink
feat: misc (#23)
Browse files Browse the repository at this point in the history
  • Loading branch information
SAKURA-CAT authored Dec 9, 2024
1 parent 09489b9 commit ebf9cf2
Show file tree
Hide file tree
Showing 4 changed files with 35 additions and 5 deletions.
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

0 comments on commit ebf9cf2

Please sign in to comment.