Move src/lib/ → src/testium/runtime/ (internal plumbing)
Move src/testium/libs/ → src/testium/api/ (public SDK for test scripts)
Move src/py_func/ → src/testium/py_func/ (Python subprocess)
Move src/lua_func/ → src/testium/lua_func/ (Lua subprocess data)
The package now ships as a single coherent unit instead of four sibling
top-level packages (testium, lib, py_func, lua_func) — pip install
gives a clean site-packages/testium/ with no namespace pollution; .lua
files travel with the wheel via package_data; the wheel installs
cleanly and `testium -b` runs end-to-end including py_func subprocesses
and entry-point exporter plugins.
Naming:
- runtime/ (internal, no API guarantees) clearer than lib/
- api/ (public SDK consumed as `import api.testium as tm`) clearer than libs/
Imports updated en masse: from lib. → from runtime. and from libs. →
from api., plus the importlib.import_module("libs.*") strings in
test_item_console.py and test_item_runtime_plot.py. Test/example
scripts (helper_lib.py, parallel.py, post_execution.py) and the
fake_exporter test suite migrated too.
paths.py: subproc_path() now returns testium_path() — both point at
the testium package directory since the subprocesses live inside.
pyproject.toml: removed exclude=["lua_func", "py_func"] (no longer
needed), added package-data for testium.lua_func/*.lua, removed the
license classifier (PEP 639 conflict with license expression).
Subprocess isolation contract: py_func/ and lua_func/ may only import
runtime/ and their own modules — never interpreter/, main_win/, api/,
or testium/. Enforced by test/validation/items/isolation/ which runs a
py_func that statically scans subprocess source files for forbidden
imports. The contract holds today; the test prevents future drift.
Co-Authored-By: Claude Opus 4.7 <noreply@anthropic.com>
28 lines
790 B
Python
28 lines
790 B
Python
from runtime.api import SUPPORTED_API
|
|
|
|
import api.testium as tm
|
|
|
|
# Fill the api_dict with the function of tm
|
|
api_dict = {k: getattr(tm, k) for k in SUPPORTED_API if hasattr(tm, k)}
|
|
|
|
def api_request(method, params):
|
|
global api_dict
|
|
|
|
if method in api_dict.keys():
|
|
if params is None:
|
|
params = []
|
|
if not isinstance(params, list):
|
|
params = [params]
|
|
try:
|
|
return {"result": api_dict[method](*params)}
|
|
except Exception as e:
|
|
return {"error": str(e)}
|
|
elif method == "print":
|
|
if isinstance(params, str):
|
|
print(params, end="")
|
|
elif isinstance(params, list):
|
|
print(*params, end="")
|
|
return {"result": 0}
|
|
else:
|
|
return {"error": "unsupported function"}
|