mirror of
https://github.com/denoland/deno.git
synced 2025-01-15 10:35:19 -05:00
43c6c1a9f5
* use subclass of unittest.TestCase for all test cases * allow to run single test file (eg. python tools/integration_tests.py) * test filtering (via --pattern/-p CLI flag) * use common CLI parser for all tests: usage: test.py [-h] [--failfast] [--verbose] [--executable EXECUTABLE] [--release] [--pattern PATTERN] [--build-dir BUILD_DIR] optional arguments: -h, --help show this help message and exit --failfast, -f Stop on first failure --verbose, -v Verbose output --executable EXECUTABLE Use external executable of Deno --release Test against release executable --pattern PATTERN, -p PATTERN Run tests that match provided pattern --build-dir BUILD_DIR Deno build directory * respect NO_COLOR variable
66 lines
2.2 KiB
Python
66 lines
2.2 KiB
Python
# Copyright 2018-2019 the Deno authors. All rights reserved. MIT license.
|
|
import os
|
|
import sys
|
|
|
|
from setup import gn_string, read_gn_args, write_gn_args
|
|
from shutil import rmtree
|
|
from tempfile import mktemp
|
|
|
|
from test_util import DenoTestCase, run_tests
|
|
|
|
|
|
class TestSetup(DenoTestCase):
|
|
def test_gn_string(self):
|
|
assert '"abc"' == gn_string('abc')
|
|
assert '"foo\\$bar\\"baz"' == gn_string('foo$bar"baz')
|
|
assert '"do\\not\\escape"' == gn_string('do\\not\\escape')
|
|
assert '"so\\\\\\very\\\\\\"fun\\"' == gn_string('so\\\\very\\"fun\\')
|
|
|
|
def test_read_gn_args(self):
|
|
# Args file doesn't exist.
|
|
(args,
|
|
hand_edited) = read_gn_args("/baddir/hopefully/nonexistent/args.gn")
|
|
assert args is None
|
|
assert hand_edited == False
|
|
|
|
# Handwritten empty args file.
|
|
filename = mktemp()
|
|
with open(filename, "w"):
|
|
pass
|
|
(args, hand_edited) = read_gn_args(filename)
|
|
os.remove(filename)
|
|
assert args == []
|
|
assert hand_edited == True
|
|
|
|
# Handwritten non-empty args file.
|
|
expect_args = ['some_number=2', 'another_string="ran/dom#yes"']
|
|
filename = mktemp()
|
|
with open(filename, "w") as f:
|
|
f.write("\n".join(expect_args + ["", "# A comment to be ignored"]))
|
|
(args, hand_edited) = read_gn_args(filename)
|
|
os.remove(filename)
|
|
assert args == expect_args
|
|
assert hand_edited == True
|
|
|
|
def test_write_gn_args(self):
|
|
# Build a nonexistent path; write_gn_args() should call mkdir as needed.
|
|
d = mktemp()
|
|
filename = os.path.join(d, "args.gn")
|
|
assert not os.path.exists(d)
|
|
assert not os.path.exists(filename)
|
|
# Write some args.
|
|
args = ['lalala=42', 'foo_bar_baz="lorem ipsum dolor#amet"']
|
|
write_gn_args(filename, args)
|
|
# Directory and args file should now be created.
|
|
assert os.path.isdir(d)
|
|
assert os.path.isfile(filename)
|
|
# Validate that the right contents were written.
|
|
(check_args, hand_edited) = read_gn_args(filename)
|
|
assert check_args == args
|
|
assert hand_edited == False
|
|
# Clean up.
|
|
rmtree(d)
|
|
|
|
|
|
if __name__ == '__main__':
|
|
run_tests()
|