Updated script that can be controled by Nodejs web app
This commit is contained in:
@ -0,0 +1,16 @@
|
||||
from numpy.testing import IS_WASM, IS_EDITABLE
|
||||
import pytest
|
||||
|
||||
|
||||
if IS_WASM:
|
||||
pytest.skip(
|
||||
"WASM/Pyodide does not use or support Fortran",
|
||||
allow_module_level=True
|
||||
)
|
||||
|
||||
|
||||
if IS_EDITABLE:
|
||||
pytest.skip(
|
||||
"Editable install doesn't support tests with a compile step",
|
||||
allow_module_level=True
|
||||
)
|
@ -0,0 +1,32 @@
|
||||
"""A crude *bit of everything* smoke test to verify PyInstaller compatibility.
|
||||
|
||||
PyInstaller typically goes wrong by forgetting to package modules, extension
|
||||
modules or shared libraries. This script should aim to touch as many of those
|
||||
as possible in an attempt to trip a ModuleNotFoundError or a DLL load failure
|
||||
due to an uncollected resource. Missing resources are unlikely to lead to
|
||||
arithmetic errors so there's generally no need to verify any calculation's
|
||||
output - merely that it made it to the end OK. This script should not
|
||||
explicitly import any of numpy's submodules as that gives PyInstaller undue
|
||||
hints that those submodules exist and should be collected (accessing implicitly
|
||||
loaded submodules is OK).
|
||||
|
||||
"""
|
||||
import numpy as np
|
||||
|
||||
a = np.arange(1., 10.).reshape((3, 3)) % 5
|
||||
np.linalg.det(a)
|
||||
a @ a
|
||||
a @ a.T
|
||||
np.linalg.inv(a)
|
||||
np.sin(np.exp(a))
|
||||
np.linalg.svd(a)
|
||||
np.linalg.eigh(a)
|
||||
|
||||
np.unique(np.random.randint(0, 10, 100))
|
||||
np.sort(np.random.uniform(0, 10, 100))
|
||||
|
||||
np.fft.fft(np.exp(2j * np.pi * np.arange(8) / 8))
|
||||
np.ma.masked_array(np.arange(10), np.random.rand(10) < .5).sum()
|
||||
np.polynomial.Legendre([7, 8, 9]).roots()
|
||||
|
||||
print("I made it!")
|
@ -0,0 +1,35 @@
|
||||
import subprocess
|
||||
from pathlib import Path
|
||||
|
||||
import pytest
|
||||
|
||||
|
||||
# PyInstaller has been very unproactive about replacing 'imp' with 'importlib'.
|
||||
@pytest.mark.filterwarnings('ignore::DeprecationWarning')
|
||||
# It also leaks io.BytesIO()s.
|
||||
@pytest.mark.filterwarnings('ignore::ResourceWarning')
|
||||
@pytest.mark.parametrize("mode", ["--onedir", "--onefile"])
|
||||
@pytest.mark.slow
|
||||
def test_pyinstaller(mode, tmp_path):
|
||||
"""Compile and run pyinstaller-smoke.py using PyInstaller."""
|
||||
|
||||
pyinstaller_cli = pytest.importorskip("PyInstaller.__main__").run
|
||||
|
||||
source = Path(__file__).with_name("pyinstaller-smoke.py").resolve()
|
||||
args = [
|
||||
# Place all generated files in ``tmp_path``.
|
||||
'--workpath', str(tmp_path / "build"),
|
||||
'--distpath', str(tmp_path / "dist"),
|
||||
'--specpath', str(tmp_path),
|
||||
mode,
|
||||
str(source),
|
||||
]
|
||||
pyinstaller_cli(args)
|
||||
|
||||
if mode == "--onefile":
|
||||
exe = tmp_path / "dist" / source.stem
|
||||
else:
|
||||
exe = tmp_path / "dist" / source.stem / source.stem
|
||||
|
||||
p = subprocess.run([str(exe)], check=True, stdout=subprocess.PIPE)
|
||||
assert p.stdout.strip() == b"I made it!"
|
Reference in New Issue
Block a user