tests/run-multitests.py: Change to dir of test script when running it.

This matches the behaviour of run-tests.py, which sets cwd to the directory
containing the test script, which helps to isolate the filesystem.

It means that the SSL tests no longer need to know the name of their
containing directory to find the certificate files, and helps to run these
tests on bare-metal.

Signed-off-by: Damien George <damien@micropython.org>
This commit is contained in:
Damien George
2024-01-03 16:26:52 +11:00
parent a003ac2f73
commit f0392b8d3d
13 changed files with 36 additions and 30 deletions

View File

@@ -11,8 +11,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
cert = cafile = "multi_net/rsa_cert.der" cert = cafile = "rsa_cert.der"
key = "multi_net/rsa_key.der" key = "rsa_key.der"
try: try:
os.stat(cafile) os.stat(cafile)

View File

@@ -11,8 +11,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
cert = cafile = "multi_net/rsa_cert.der" cert = cafile = "rsa_cert.der"
key = "multi_net/rsa_key.der" key = "rsa_key.der"
try: try:
os.stat(cafile) os.stat(cafile)

View File

@@ -11,8 +11,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
cert = cafile = "multi_net/rsa_cert.der" cert = cafile = "rsa_cert.der"
key = "multi_net/rsa_key.der" key = "rsa_key.der"
try: try:
os.stat(cafile) os.stat(cafile)

View File

@@ -11,8 +11,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
cert = cafile = "multi_net/rsa_cert.der" cert = cafile = "rsa_cert.der"
key = "multi_net/rsa_key.der" key = "rsa_key.der"
try: try:
os.stat(cafile) os.stat(cafile)

View File

@@ -10,8 +10,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
certfile = "multi_net/rsa_cert.der" certfile = "rsa_cert.der"
keyfile = "multi_net/rsa_key.der" keyfile = "rsa_key.der"
try: try:
os.stat(certfile) os.stat(certfile)

View File

@@ -11,8 +11,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
cert = cafile = "multi_net/rsa_cert.der" cert = cafile = "rsa_cert.der"
key = "multi_net/rsa_key.der" key = "rsa_key.der"
try: try:
os.stat(cafile) os.stat(cafile)

View File

@@ -12,8 +12,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
cert = cafile = "multi_net/rsa_cert.der" cert = cafile = "rsa_cert.der"
key = "multi_net/rsa_key.der" key = "rsa_key.der"
try: try:
os.stat(cafile) os.stat(cafile)

View File

@@ -11,8 +11,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
certfile = "multi_net/rsa_cert.der" certfile = "rsa_cert.der"
keyfile = "multi_net/rsa_key.der" keyfile = "rsa_key.der"
try: try:
os.stat(certfile) os.stat(certfile)

View File

@@ -11,8 +11,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
cert = cafile = "multi_net/rsa_cert.der" cert = cafile = "rsa_cert.der"
key = "multi_net/rsa_key.der" key = "rsa_key.der"
try: try:
os.stat(cafile) os.stat(cafile)

View File

@@ -11,8 +11,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
cert = cafile = "multi_net/rsa_cert.der" cert = cafile = "rsa_cert.der"
key = "multi_net/rsa_key.der" key = "rsa_key.der"
try: try:
os.stat(cafile) os.stat(cafile)

View File

@@ -11,8 +11,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
cert = cafile = "multi_net/rsa_cert.der" cert = cafile = "rsa_cert.der"
key = "multi_net/rsa_key.der" key = "rsa_key.der"
try: try:
os.stat(cafile) os.stat(cafile)

View File

@@ -11,8 +11,8 @@ except ImportError:
PORT = 8000 PORT = 8000
# These are test certificates. See tests/README.md for details. # These are test certificates. See tests/README.md for details.
cert = cafile = "multi_net/expired_cert.der" cert = cafile = "expired_cert.der"
key = "multi_net/rsa_key.der" key = "rsa_key.der"
try: try:
os.stat(cafile) os.stat(cafile)

View File

@@ -27,13 +27,15 @@ import pyboard
if os.name == "nt": if os.name == "nt":
CPYTHON3 = os.getenv("MICROPY_CPYTHON3", "python3.exe") CPYTHON3 = os.getenv("MICROPY_CPYTHON3", "python3.exe")
MICROPYTHON = os.getenv( MICROPYTHON = os.path.abspath(
"MICROPY_MICROPYTHON", test_dir + "/../ports/windows/build-standard/micropython.exe" os.getenv(
"MICROPY_MICROPYTHON", test_dir + "/../ports/windows/build-standard/micropython.exe"
)
) )
else: else:
CPYTHON3 = os.getenv("MICROPY_CPYTHON3", "python3") CPYTHON3 = os.getenv("MICROPY_CPYTHON3", "python3")
MICROPYTHON = os.getenv( MICROPYTHON = os.path.abspath(
"MICROPY_MICROPYTHON", test_dir + "/../ports/unix/build-standard/micropython" os.getenv("MICROPY_MICROPYTHON", test_dir + "/../ports/unix/build-standard/micropython")
) )
# For diff'ing test output # For diff'ing test output
@@ -155,6 +157,7 @@ class PyInstance:
class PyInstanceSubProcess(PyInstance): class PyInstanceSubProcess(PyInstance):
def __init__(self, argv, env=None): def __init__(self, argv, env=None):
self.argv = argv self.argv = argv
self.cwd = None
self.env = {n: v for n, v in (i.split("=") for i in env)} if env else None self.env = {n: v for n, v in (i.split("=") for i in env)} if env else None
self.popen = None self.popen = None
self.finished = True self.finished = True
@@ -163,8 +166,9 @@ class PyInstanceSubProcess(PyInstance):
return self.argv[0].rsplit("/")[-1] return self.argv[0].rsplit("/")[-1]
def prepare_script_from_file(self, filename, prepend, append): def prepare_script_from_file(self, filename, prepend, append):
# Make tests run in an isolated environment (i.e. `import io` would # Make tests run in the directory of the test file, and in an isolated environment
# otherwise get the `tests/io` directory). # (i.e. `import io` would otherwise get the `tests/io` directory).
self.cwd = os.path.dirname(filename)
remove_cwd_from_sys_path = b"import sys\nsys.path.remove('')\n\n" remove_cwd_from_sys_path = b"import sys\nsys.path.remove('')\n\n"
return remove_cwd_from_sys_path + super().prepare_script_from_file( return remove_cwd_from_sys_path + super().prepare_script_from_file(
filename, prepend, append filename, prepend, append
@@ -179,6 +183,7 @@ class PyInstanceSubProcess(PyInstance):
stdout=subprocess.PIPE, stdout=subprocess.PIPE,
stderr=subprocess.STDOUT, stderr=subprocess.STDOUT,
input=script, input=script,
cwd=self.cwd,
env=self.env, env=self.env,
) )
output = p.stdout output = p.stdout
@@ -192,6 +197,7 @@ class PyInstanceSubProcess(PyInstance):
stdin=subprocess.PIPE, stdin=subprocess.PIPE,
stdout=subprocess.PIPE, stdout=subprocess.PIPE,
stderr=subprocess.STDOUT, stderr=subprocess.STDOUT,
cwd=self.cwd,
env=self.env, env=self.env,
) )
self.finished = False self.finished = False