pybioos 0.0.12__py3-none-any.whl → 0.0.14__py3-none-any.whl
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- bioos/__about__.py +1 -1
- bioos/bioos_workflow.py +6 -1
- bioos/bw_import.py +2 -1
- bioos/bw_import_status_check.py +91 -0
- bioos/bw_status_check.py +94 -0
- bioos/get_submission_logs.py +119 -0
- {pybioos-0.0.12.dist-info → pybioos-0.0.14.dist-info}/METADATA +1 -1
- {pybioos-0.0.12.dist-info → pybioos-0.0.14.dist-info}/RECORD +12 -9
- pybioos-0.0.14.dist-info/entry_points.txt +7 -0
- pybioos-0.0.12.dist-info/entry_points.txt +0 -4
- {pybioos-0.0.12.dist-info → pybioos-0.0.14.dist-info}/LICENSE +0 -0
- {pybioos-0.0.12.dist-info → pybioos-0.0.14.dist-info}/WHEEL +0 -0
- {pybioos-0.0.12.dist-info → pybioos-0.0.14.dist-info}/top_level.txt +0 -0
bioos/__about__.py
CHANGED
bioos/bioos_workflow.py
CHANGED
|
@@ -277,8 +277,13 @@ class Bioos_workflow:
|
|
|
277
277
|
self.logger.info("Download finish.")
|
|
278
278
|
|
|
279
279
|
def submit_workflow_bioosapi(self):
|
|
280
|
+
"""Submit workflow using Bio-OS API"""
|
|
280
281
|
self.runs = self.wf.submit(**self.params_submit)
|
|
281
|
-
self.
|
|
282
|
+
submission_id = self.runs[0].submission
|
|
283
|
+
run_id = self.runs[0].id
|
|
284
|
+
self.logger.info(
|
|
285
|
+
f"Submit workflow run successfully. Submission ID: {submission_id}, Run ID: {run_id}"
|
|
286
|
+
)
|
|
282
287
|
return self.runs
|
|
283
288
|
|
|
284
289
|
def monitor_workflow(self):
|
bioos/bw_import.py
CHANGED
|
@@ -145,7 +145,8 @@ def bioos_workflow_import():
|
|
|
145
145
|
else:
|
|
146
146
|
# 如果没有设置monitor参数,直接退出
|
|
147
147
|
logger.info(
|
|
148
|
-
f"Workflow {args.workflow_name}
|
|
148
|
+
f"Workflow {args.workflow_name} is still validating, {result}, please wait and check the status later."
|
|
149
|
+
)
|
|
149
150
|
sys.exit(0)
|
|
150
151
|
|
|
151
152
|
except Exception as e:
|
|
@@ -0,0 +1,91 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
# coding: utf-8
|
|
3
|
+
|
|
4
|
+
import argparse
|
|
5
|
+
import logging
|
|
6
|
+
import sys
|
|
7
|
+
|
|
8
|
+
from bioos import bioos
|
|
9
|
+
from bioos.config import Config
|
|
10
|
+
from bioos.resource.workflows import WorkflowResource
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
def get_logger():
|
|
14
|
+
"""Setup logger"""
|
|
15
|
+
logger = logging.getLogger('bw_import_status_check')
|
|
16
|
+
if not logger.handlers:
|
|
17
|
+
handler = logging.StreamHandler()
|
|
18
|
+
formatter = logging.Formatter(
|
|
19
|
+
'%(asctime)s - %(levelname)s - %(message)s')
|
|
20
|
+
handler.setFormatter(formatter)
|
|
21
|
+
logger.addHandler(handler)
|
|
22
|
+
logger.setLevel(logging.INFO)
|
|
23
|
+
return logger
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
def bioos_workflow_status_check():
|
|
27
|
+
"""Command line entry point for checking workflow validation status"""
|
|
28
|
+
parser = argparse.ArgumentParser(
|
|
29
|
+
description='Bio-OS Workflow Import Status Check Tool',
|
|
30
|
+
formatter_class=argparse.RawDescriptionHelpFormatter)
|
|
31
|
+
|
|
32
|
+
# 必需参数
|
|
33
|
+
parser.add_argument(
|
|
34
|
+
'--ak',
|
|
35
|
+
required=True,
|
|
36
|
+
help='Access key for your Bio-OS instance platform account')
|
|
37
|
+
parser.add_argument(
|
|
38
|
+
'--sk',
|
|
39
|
+
required=True,
|
|
40
|
+
help='Secret key for your Bio-OS instance platform account')
|
|
41
|
+
parser.add_argument('--workspace_name',
|
|
42
|
+
required=True,
|
|
43
|
+
help='Target workspace name')
|
|
44
|
+
parser.add_argument('--workflow_id',
|
|
45
|
+
required=True,
|
|
46
|
+
help='ID of the workflow to check')
|
|
47
|
+
|
|
48
|
+
args = parser.parse_args()
|
|
49
|
+
logger = get_logger()
|
|
50
|
+
|
|
51
|
+
try:
|
|
52
|
+
# 配置Bio-OS
|
|
53
|
+
Config.set_access_key(args.ak)
|
|
54
|
+
Config.set_secret_key(args.sk)
|
|
55
|
+
Config.set_endpoint("https://bio-top.miracle.ac.cn")
|
|
56
|
+
|
|
57
|
+
# 获取workspace ID
|
|
58
|
+
workspaces = bioos.list_workspaces()
|
|
59
|
+
workspace_info = workspaces.query(f"Name=='{args.workspace_name}'")
|
|
60
|
+
if workspace_info.empty:
|
|
61
|
+
logger.error(f"Workspace {args.workspace_name} not found")
|
|
62
|
+
sys.exit(1)
|
|
63
|
+
workspace_id = workspace_info["ID"].iloc[0]
|
|
64
|
+
|
|
65
|
+
# 创建WorkflowResource实例
|
|
66
|
+
workflow_resource = WorkflowResource(workspace_id)
|
|
67
|
+
|
|
68
|
+
# 获取工作流状态
|
|
69
|
+
df = workflow_resource.list()
|
|
70
|
+
workflow_info = df[df.ID == args.workflow_id]
|
|
71
|
+
|
|
72
|
+
if len(workflow_info) == 1:
|
|
73
|
+
status = workflow_info.iloc[0]["Status"]["Phase"]
|
|
74
|
+
message = workflow_info.iloc[0]["Status"].get("Message", "")
|
|
75
|
+
|
|
76
|
+
# 打印状态信息
|
|
77
|
+
print(f"Status: {status}")
|
|
78
|
+
if message:
|
|
79
|
+
print(f"Message: {message}")
|
|
80
|
+
|
|
81
|
+
else:
|
|
82
|
+
logger.error(f"Workflow with ID {args.workflow_id} not found")
|
|
83
|
+
sys.exit(1)
|
|
84
|
+
|
|
85
|
+
except Exception as e:
|
|
86
|
+
logger.error(f"Error: {str(e)}")
|
|
87
|
+
sys.exit(1)
|
|
88
|
+
|
|
89
|
+
|
|
90
|
+
if __name__ == '__main__':
|
|
91
|
+
bioos_workflow_status_check()
|
bioos/bw_status_check.py
ADDED
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
# coding: utf-8
|
|
3
|
+
|
|
4
|
+
import argparse
|
|
5
|
+
import logging
|
|
6
|
+
import sys
|
|
7
|
+
|
|
8
|
+
from bioos import bioos
|
|
9
|
+
from bioos.config import Config
|
|
10
|
+
from bioos.resource.workflows import WorkflowResource
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
def get_logger():
|
|
14
|
+
"""Setup logger"""
|
|
15
|
+
logger = logging.getLogger('bw_status_check')
|
|
16
|
+
if not logger.handlers:
|
|
17
|
+
handler = logging.StreamHandler()
|
|
18
|
+
formatter = logging.Formatter(
|
|
19
|
+
'%(asctime)s - %(levelname)s - %(message)s')
|
|
20
|
+
handler.setFormatter(formatter)
|
|
21
|
+
logger.addHandler(handler)
|
|
22
|
+
logger.setLevel(logging.INFO)
|
|
23
|
+
return logger
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
def bioos_workflow_status_check():
|
|
27
|
+
"""Command line entry point for checking workflow run status"""
|
|
28
|
+
parser = argparse.ArgumentParser(
|
|
29
|
+
description='Bio-OS Workflow Run Status Check Tool',
|
|
30
|
+
formatter_class=argparse.RawDescriptionHelpFormatter)
|
|
31
|
+
|
|
32
|
+
# 必需参数
|
|
33
|
+
parser.add_argument(
|
|
34
|
+
'--ak',
|
|
35
|
+
required=True,
|
|
36
|
+
help='Access key for your Bio-OS instance platform account')
|
|
37
|
+
parser.add_argument(
|
|
38
|
+
'--sk',
|
|
39
|
+
required=True,
|
|
40
|
+
help='Secret key for your Bio-OS instance platform account')
|
|
41
|
+
parser.add_argument('--workspace_name',
|
|
42
|
+
required=True,
|
|
43
|
+
help='Target workspace name')
|
|
44
|
+
parser.add_argument('--submission_id',
|
|
45
|
+
required=True,
|
|
46
|
+
help='ID of the submission to check')
|
|
47
|
+
|
|
48
|
+
args = parser.parse_args()
|
|
49
|
+
logger = get_logger()
|
|
50
|
+
|
|
51
|
+
try:
|
|
52
|
+
# 配置Bio-OS
|
|
53
|
+
Config.set_access_key(args.ak)
|
|
54
|
+
Config.set_secret_key(args.sk)
|
|
55
|
+
Config.set_endpoint("https://bio-top.miracle.ac.cn")
|
|
56
|
+
|
|
57
|
+
# 获取workspace ID
|
|
58
|
+
workspaces = bioos.list_workspaces()
|
|
59
|
+
workspace_info = workspaces.query(f"Name=='{args.workspace_name}'")
|
|
60
|
+
if workspace_info.empty:
|
|
61
|
+
logger.error(f"Workspace {args.workspace_name} not found")
|
|
62
|
+
sys.exit(1)
|
|
63
|
+
workspace_id = workspace_info["ID"].iloc[0]
|
|
64
|
+
|
|
65
|
+
# 获取提交的运行状态
|
|
66
|
+
resp = Config.service().list_runs({
|
|
67
|
+
"SubmissionID": args.submission_id,
|
|
68
|
+
"WorkspaceID": workspace_id
|
|
69
|
+
})
|
|
70
|
+
|
|
71
|
+
if not resp.get("Items"):
|
|
72
|
+
logger.error(f"No runs found for submission {args.submission_id}")
|
|
73
|
+
sys.exit(1)
|
|
74
|
+
|
|
75
|
+
# 打印所有运行的状态
|
|
76
|
+
print(f"\nSubmission ID: {args.submission_id}")
|
|
77
|
+
print("Runs Status:")
|
|
78
|
+
print("-" * 60)
|
|
79
|
+
print(f"{'Run ID':<40} {'Status':<10} {'Message'}")
|
|
80
|
+
print("-" * 60)
|
|
81
|
+
|
|
82
|
+
for run in resp.get("Items"):
|
|
83
|
+
run_id = run.get("ID", "N/A")
|
|
84
|
+
status = run.get("Status", "Unknown")
|
|
85
|
+
message = run.get("Message", "")
|
|
86
|
+
print(f"{run_id:<40} {status:<10} {message}")
|
|
87
|
+
|
|
88
|
+
except Exception as e:
|
|
89
|
+
logger.error(f"Error: {str(e)}")
|
|
90
|
+
sys.exit(1)
|
|
91
|
+
|
|
92
|
+
|
|
93
|
+
if __name__ == '__main__':
|
|
94
|
+
bioos_workflow_status_check()
|
|
@@ -0,0 +1,119 @@
|
|
|
1
|
+
#!/usr/bin/env python3
|
|
2
|
+
# coding: utf-8
|
|
3
|
+
|
|
4
|
+
import argparse
|
|
5
|
+
import logging
|
|
6
|
+
import os
|
|
7
|
+
import sys
|
|
8
|
+
|
|
9
|
+
from bioos import bioos
|
|
10
|
+
from bioos.config import Config
|
|
11
|
+
|
|
12
|
+
|
|
13
|
+
def get_logger():
|
|
14
|
+
"""Setup logger"""
|
|
15
|
+
logger = logging.getLogger('get_submission_logs')
|
|
16
|
+
if not logger.handlers:
|
|
17
|
+
handler = logging.StreamHandler()
|
|
18
|
+
formatter = logging.Formatter(
|
|
19
|
+
'%(asctime)s - %(levelname)s - %(message)s')
|
|
20
|
+
handler.setFormatter(formatter)
|
|
21
|
+
logger.addHandler(handler)
|
|
22
|
+
logger.setLevel(logging.INFO)
|
|
23
|
+
return logger
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+
def get_submission_logs():
|
|
27
|
+
"""Command line entry point for downloading workflow submission logs"""
|
|
28
|
+
parser = argparse.ArgumentParser(
|
|
29
|
+
description='Bio-OS Workflow Submission Logs Download Tool',
|
|
30
|
+
formatter_class=argparse.RawDescriptionHelpFormatter)
|
|
31
|
+
|
|
32
|
+
# 必需参数
|
|
33
|
+
parser.add_argument(
|
|
34
|
+
'--ak',
|
|
35
|
+
required=True,
|
|
36
|
+
help='Access key for your Bio-OS instance platform account')
|
|
37
|
+
parser.add_argument(
|
|
38
|
+
'--sk',
|
|
39
|
+
required=True,
|
|
40
|
+
help='Secret key for your Bio-OS instance platform account')
|
|
41
|
+
parser.add_argument('--workspace_name',
|
|
42
|
+
required=True,
|
|
43
|
+
help='Target workspace name')
|
|
44
|
+
parser.add_argument('--submission_id',
|
|
45
|
+
required=True,
|
|
46
|
+
help='ID of the submission to download logs')
|
|
47
|
+
parser.add_argument(
|
|
48
|
+
'--output_dir',
|
|
49
|
+
default='.',
|
|
50
|
+
help='Local directory to save the logs (default: current directory)')
|
|
51
|
+
|
|
52
|
+
args = parser.parse_args()
|
|
53
|
+
logger = get_logger()
|
|
54
|
+
|
|
55
|
+
try:
|
|
56
|
+
# 配置Bio-OS
|
|
57
|
+
Config.set_access_key(args.ak)
|
|
58
|
+
Config.set_secret_key(args.sk)
|
|
59
|
+
Config.set_endpoint("https://bio-top.miracle.ac.cn")
|
|
60
|
+
|
|
61
|
+
# 获取workspace ID
|
|
62
|
+
workspaces = bioos.list_workspaces()
|
|
63
|
+
workspace_info = workspaces.query(f"Name=='{args.workspace_name}'")
|
|
64
|
+
if workspace_info.empty:
|
|
65
|
+
logger.error(f"Workspace {args.workspace_name} not found")
|
|
66
|
+
sys.exit(1)
|
|
67
|
+
workspace_id = workspace_info["ID"].iloc[0]
|
|
68
|
+
|
|
69
|
+
# 获取workspace对象
|
|
70
|
+
ws = bioos.workspace(workspace_id)
|
|
71
|
+
|
|
72
|
+
# 列出所有文件
|
|
73
|
+
logger.info(f"Listing files for submission {args.submission_id}")
|
|
74
|
+
files_df = ws.files.list()
|
|
75
|
+
|
|
76
|
+
# 过滤出与submission相关的日志文件
|
|
77
|
+
log_files = []
|
|
78
|
+
for file in files_df.key:
|
|
79
|
+
if args.submission_id in file:
|
|
80
|
+
# 检查是否是日志文件
|
|
81
|
+
if (file.endswith('.log') or 'stderr' in file
|
|
82
|
+
or 'stdout' in file or '/log/' in file):
|
|
83
|
+
log_files.append(file)
|
|
84
|
+
|
|
85
|
+
if not log_files:
|
|
86
|
+
logger.error(
|
|
87
|
+
f"No log files found for submission {args.submission_id}")
|
|
88
|
+
sys.exit(1)
|
|
89
|
+
|
|
90
|
+
logger.info(f"Found {len(log_files)} log files")
|
|
91
|
+
|
|
92
|
+
# 创建输出目录
|
|
93
|
+
output_path = os.path.join(args.output_dir, args.submission_id)
|
|
94
|
+
os.makedirs(output_path, exist_ok=True)
|
|
95
|
+
|
|
96
|
+
# 下载文件
|
|
97
|
+
logger.info("Downloading log files...")
|
|
98
|
+
try:
|
|
99
|
+
ws.files.download(log_files, output_path, flatten=False)
|
|
100
|
+
logger.info(f"Successfully downloaded log files to {output_path}")
|
|
101
|
+
except Exception as e:
|
|
102
|
+
logger.error(f"Error downloading some files: {str(e)}")
|
|
103
|
+
logger.info("Continuing with successfully downloaded files...")
|
|
104
|
+
|
|
105
|
+
# 打印下载的文件列表
|
|
106
|
+
logger.info("\nDownloaded files:")
|
|
107
|
+
for root, _, files in os.walk(output_path):
|
|
108
|
+
for file in files:
|
|
109
|
+
rel_path = os.path.relpath(os.path.join(root, file),
|
|
110
|
+
output_path)
|
|
111
|
+
logger.info(f" {rel_path}")
|
|
112
|
+
|
|
113
|
+
except Exception as e:
|
|
114
|
+
logger.error(f"Error: {str(e)}")
|
|
115
|
+
sys.exit(1)
|
|
116
|
+
|
|
117
|
+
|
|
118
|
+
if __name__ == '__main__':
|
|
119
|
+
get_submission_logs()
|
|
@@ -1,10 +1,13 @@
|
|
|
1
|
-
bioos/__about__.py,sha256=
|
|
1
|
+
bioos/__about__.py,sha256=ev5P6FQdPx-W_Hkam384TBq5XWIMHrvDeSBRkz-p7wo,57
|
|
2
2
|
bioos/__init__.py,sha256=4GZKi13lDTD25YBkGakhZyEQZWTER_OWQMNPoH_UM2c,22
|
|
3
3
|
bioos/bioos.py,sha256=fHzOb1l5wYxw6NVYYZDiFcgk4V28BAgWEc3ev12reWs,2409
|
|
4
|
-
bioos/bioos_workflow.py,sha256=
|
|
5
|
-
bioos/bw_import.py,sha256=
|
|
4
|
+
bioos/bioos_workflow.py,sha256=BzEPOyAjgdK7Wafbl2b1_qG_VTEdp8xDwKS68tBovjs,14327
|
|
5
|
+
bioos/bw_import.py,sha256=lQk_ch_tTz8l4bnWniOzWZ1IxI6ZvKlaASkNMsdDGfA,5697
|
|
6
|
+
bioos/bw_import_status_check.py,sha256=sJuso2SAfZWvPzypnGge25Ayv5PsSGRXqSNNwIhNu-E,2794
|
|
7
|
+
bioos/bw_status_check.py,sha256=FVilkawRA7GD1JXUBeaR28W1DfN9bAzYBIAjqi4JIno,2916
|
|
6
8
|
bioos/config.py,sha256=CvFabYqV1BkFWO8fnr5vBf6xNtNzA8hAEVeEIbvAOm8,4307
|
|
7
9
|
bioos/errors.py,sha256=Lzz2rkjDOTR2X9CnVkmsmqeOgmNqbi46WAxnC6LEGm0,2459
|
|
10
|
+
bioos/get_submission_logs.py,sha256=jUtT8Vic8h_VOcqrqJsTBSonve64RjbKNAyp0wUtIpg,3934
|
|
8
11
|
bioos/log.py,sha256=twiCvf5IgJB7uvzANwBluSlztJN8ZrxbGZUBGlZ0vps,3204
|
|
9
12
|
bioos/internal/__init__.py,sha256=AbpHGcgLb-kRsJGnwFEktk7uzpZOCcBY74-YBdrKVGs,1
|
|
10
13
|
bioos/internal/tos.py,sha256=0R6YN2lxjjZsuMfv0yLSkBmz_LqmzQGb8GagnUMc8EY,12264
|
|
@@ -31,9 +34,9 @@ bioos/tests/workspaces.py,sha256=LuuRrTs2XqfE5mGQyJNl9RBtuMb4NZHBJFoO8HMZVYQ,522
|
|
|
31
34
|
bioos/utils/__init__.py,sha256=47DEQpj8HBSa-_TImW-5JCeuQeRkm5NMpJWZG3hSuFU,0
|
|
32
35
|
bioos/utils/common_tools.py,sha256=fgMoE_-qZjgfQtUj_pmCTyYDtbJasyfH4Gm3VQsbgBQ,1651
|
|
33
36
|
bioos/utils/workflows.py,sha256=zRbwTUigoM5V5LFOgzQPm3kwxt5Ogz95OFfefJc6Fjo,133
|
|
34
|
-
pybioos-0.0.
|
|
35
|
-
pybioos-0.0.
|
|
36
|
-
pybioos-0.0.
|
|
37
|
-
pybioos-0.0.
|
|
38
|
-
pybioos-0.0.
|
|
39
|
-
pybioos-0.0.
|
|
37
|
+
pybioos-0.0.14.dist-info/LICENSE,sha256=cPkGXsgfPgEhIns7Lt3Avxx0Uy-VbdsoP8jvNGuj3cE,1063
|
|
38
|
+
pybioos-0.0.14.dist-info/METADATA,sha256=8sh0iBOI-33lr0H0_q6ZOzznns9i46p16siJFcRbnrM,830
|
|
39
|
+
pybioos-0.0.14.dist-info/WHEEL,sha256=OqRkF0eY5GHssMorFjlbTIq072vpHpF60fIQA6lS9xA,92
|
|
40
|
+
pybioos-0.0.14.dist-info/entry_points.txt,sha256=Sc5H0_X7r03Mef4Qd70bebqgdIbVAxLU7nV7qP7cKD4,328
|
|
41
|
+
pybioos-0.0.14.dist-info/top_level.txt,sha256=llpzydkKVDSaWZgz3bsTUsQmhoQpc_JcRJg2-H-5a2U,6
|
|
42
|
+
pybioos-0.0.14.dist-info/RECORD,,
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
[console_scripts]
|
|
2
|
+
bw = bioos.bioos_workflow:bioos_workflow
|
|
3
|
+
bw_import = bioos.bw_import:bioos_workflow_import
|
|
4
|
+
bw_import_status_check = bioos.bw_import_status_check:bioos_workflow_status_check
|
|
5
|
+
bw_status_check = bioos.bw_status_check:bioos_workflow_status_check
|
|
6
|
+
get_submission_logs = bioos.get_submission_logs:get_submission_logs
|
|
7
|
+
|
|
File without changes
|
|
File without changes
|
|
File without changes
|