Add simulation result and report to output json
This commit is contained in:
@@ -7,7 +7,7 @@ from typing import Any
|
|||||||
sys.path.append("..")
|
sys.path.append("..")
|
||||||
from api import project
|
from api import project
|
||||||
from api import parser
|
from api import parser
|
||||||
|
from .error_code import *
|
||||||
|
|
||||||
def _verify_platform():
|
def _verify_platform():
|
||||||
_platform = platform.system()
|
_platform = platform.system()
|
||||||
@@ -196,7 +196,7 @@ class Output:
|
|||||||
return ds
|
return ds
|
||||||
|
|
||||||
|
|
||||||
def dump(self, cache: bool = True) -> str:
|
def dump(self) -> dict[str, Any]:
|
||||||
data = {}
|
data = {}
|
||||||
data |= { 'version' : self.version() }
|
data |= { 'version' : self.version() }
|
||||||
data |= { 'net_size' : self.net_size() }
|
data |= { 'net_size' : self.net_size() }
|
||||||
@@ -207,15 +207,24 @@ class Output:
|
|||||||
data |= { 'reactions' : self.reactions() }
|
data |= { 'reactions' : self.reactions() }
|
||||||
data |= { 'node_results' : self.node_results() }
|
data |= { 'node_results' : self.node_results() }
|
||||||
data |= { 'link_results' : self.link_results() }
|
data |= { 'link_results' : self.link_results() }
|
||||||
if cache:
|
return data
|
||||||
with open(self._path + '.json', 'w') as f:
|
|
||||||
json.dump(data, f)
|
|
||||||
return json.dumps(data)
|
def dump_report(path: str) -> str:
|
||||||
|
return open(path, mode='r').read()
|
||||||
|
|
||||||
|
|
||||||
|
def _dump_output(path: str) -> dict[str, Any]:
|
||||||
|
opt = Output(path)
|
||||||
|
data = opt.dump()
|
||||||
|
with open(path + '.json', 'w') as f:
|
||||||
|
json.dump(data, f)
|
||||||
|
return data
|
||||||
|
|
||||||
|
|
||||||
def dump_output(path: str) -> str:
|
def dump_output(path: str) -> str:
|
||||||
opt = Output(path)
|
data = _dump_output(path)
|
||||||
return opt.dump()
|
return json.dumps(data)
|
||||||
|
|
||||||
|
|
||||||
def run_project(name: str) -> str:
|
def run_project(name: str) -> str:
|
||||||
@@ -234,12 +243,18 @@ def run_project(name: str) -> str:
|
|||||||
opt = os.path.join(os.path.join(dir, 'temp'), input + '.opt')
|
opt = os.path.join(os.path.join(dir, 'temp'), input + '.opt')
|
||||||
command = f'{exe} {inp} {rpt} {opt}'
|
command = f'{exe} {inp} {rpt} {opt}'
|
||||||
|
|
||||||
|
data = {}
|
||||||
|
|
||||||
result = os.system(command)
|
result = os.system(command)
|
||||||
if result != 0:
|
if result != 0:
|
||||||
msg = f'Failed to run simulation for project [{name}]'
|
data['simulation_result'] = 'failed'
|
||||||
raise Exception(msg)
|
else:
|
||||||
|
data['simulation_result'] = 'successful'
|
||||||
|
data |= _dump_output(opt)
|
||||||
|
|
||||||
return dump_output(opt)
|
data['report'] = dump_report(rpt)
|
||||||
|
|
||||||
|
return json.dumps(data)
|
||||||
|
|
||||||
|
|
||||||
def run_inp(name: str) -> str:
|
def run_inp(name: str) -> str:
|
||||||
@@ -251,12 +266,18 @@ def run_inp(name: str) -> str:
|
|||||||
opt = os.path.join(os.path.join(dir, 'temp'), name + '.opt')
|
opt = os.path.join(os.path.join(dir, 'temp'), name + '.opt')
|
||||||
command = f'{exe} {inp} {rpt} {opt}'
|
command = f'{exe} {inp} {rpt} {opt}'
|
||||||
|
|
||||||
|
data = {}
|
||||||
|
|
||||||
result = os.system(command)
|
result = os.system(command)
|
||||||
if result != 0:
|
if result != 0:
|
||||||
msg = f'Failed to run simulation for project [{name}]'
|
data['simulation_result'] = 'failed'
|
||||||
raise Exception(msg)
|
else:
|
||||||
|
data['simulation_result'] = 'successful'
|
||||||
|
data |= _dump_output(opt)
|
||||||
|
|
||||||
return dump_output(opt)
|
data['report'] = dump_report(rpt)
|
||||||
|
|
||||||
|
return json.dumps(data)
|
||||||
|
|
||||||
|
|
||||||
if __name__ == '__main__':
|
if __name__ == '__main__':
|
||||||
|
|||||||
Reference in New Issue
Block a user