| Index: tools/telemetry/third_party/coverage/tests/test_files.py
|
| diff --git a/tools/telemetry/third_party/coverage/tests/test_files.py b/tools/telemetry/third_party/coverage/tests/test_files.py
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..e3d33285de5d58453bc403b8a739e2f68f524fac
|
| --- /dev/null
|
| +++ b/tools/telemetry/third_party/coverage/tests/test_files.py
|
| @@ -0,0 +1,278 @@
|
| +# Licensed under the Apache License: http://www.apache.org/licenses/LICENSE-2.0
|
| +# For details: https://bitbucket.org/ned/coveragepy/src/default/NOTICE.txt
|
| +
|
| +"""Tests for files.py"""
|
| +
|
| +import os
|
| +import os.path
|
| +
|
| +from coverage import files
|
| +from coverage.files import (
|
| + TreeMatcher, FnmatchMatcher, ModuleMatcher, PathAliases,
|
| + find_python_files, abs_file, actual_path, flat_rootname,
|
| +)
|
| +from coverage.misc import CoverageException
|
| +from coverage import env
|
| +
|
| +from tests.coveragetest import CoverageTest
|
| +
|
| +
|
| +class FilesTest(CoverageTest):
|
| + """Tests of coverage.files."""
|
| +
|
| + def abs_path(self, p):
|
| + """Return the absolute path for `p`."""
|
| + return os.path.join(os.getcwd(), os.path.normpath(p))
|
| +
|
| + def test_simple(self):
|
| + self.make_file("hello.py")
|
| + files.set_relative_directory()
|
| + self.assertEqual(files.relative_filename("hello.py"), "hello.py")
|
| + a = self.abs_path("hello.py")
|
| + self.assertNotEqual(a, "hello.py")
|
| + self.assertEqual(files.relative_filename(a), "hello.py")
|
| +
|
| + def test_peer_directories(self):
|
| + self.make_file("sub/proj1/file1.py")
|
| + self.make_file("sub/proj2/file2.py")
|
| + a1 = self.abs_path("sub/proj1/file1.py")
|
| + a2 = self.abs_path("sub/proj2/file2.py")
|
| + d = os.path.normpath("sub/proj1")
|
| + os.chdir(d)
|
| + files.set_relative_directory()
|
| + self.assertEqual(files.relative_filename(a1), "file1.py")
|
| + self.assertEqual(files.relative_filename(a2), a2)
|
| +
|
| + def test_filepath_contains_absolute_prefix_twice(self):
|
| + # https://bitbucket.org/ned/coveragepy/issue/194
|
| + # Build a path that has two pieces matching the absolute path prefix.
|
| + # Technically, this test doesn't do that on Windows, but drive
|
| + # letters make that impractical to achieve.
|
| + files.set_relative_directory()
|
| + d = abs_file(os.curdir)
|
| + trick = os.path.splitdrive(d)[1].lstrip(os.path.sep)
|
| + rel = os.path.join('sub', trick, 'file1.py')
|
| + self.assertEqual(files.relative_filename(abs_file(rel)), rel)
|
| +
|
| + def test_flat_rootname(self):
|
| + self.assertEqual(flat_rootname("a/b/c.py"), "a_b_c_py")
|
| + self.assertEqual(flat_rootname(r"c:\foo\bar.html"), "_foo_bar_html")
|
| +
|
| +
|
| +class MatcherTest(CoverageTest):
|
| + """Tests of file matchers."""
|
| +
|
| + def setUp(self):
|
| + super(MatcherTest, self).setUp()
|
| + files.set_relative_directory()
|
| +
|
| + def assertMatches(self, matcher, filepath, matches):
|
| + """The `matcher` should agree with `matches` about `filepath`."""
|
| + canonical = files.canonical_filename(filepath)
|
| + self.assertEqual(
|
| + matcher.match(canonical), matches,
|
| + "File %s should have matched as %s" % (filepath, matches)
|
| + )
|
| +
|
| + def test_tree_matcher(self):
|
| + matches_to_try = [
|
| + (self.make_file("sub/file1.py"), True),
|
| + (self.make_file("sub/file2.c"), True),
|
| + (self.make_file("sub2/file3.h"), False),
|
| + (self.make_file("sub3/file4.py"), True),
|
| + (self.make_file("sub3/file5.c"), False),
|
| + ]
|
| + trees = [
|
| + files.canonical_filename("sub"),
|
| + files.canonical_filename("sub3/file4.py"),
|
| + ]
|
| + tm = TreeMatcher(trees)
|
| + self.assertEqual(tm.info(), trees)
|
| + for filepath, matches in matches_to_try:
|
| + self.assertMatches(tm, filepath, matches)
|
| +
|
| + def test_module_matcher(self):
|
| + matches_to_try = [
|
| + ('test', True),
|
| + ('trash', False),
|
| + ('testing', False),
|
| + ('test.x', True),
|
| + ('test.x.y.z', True),
|
| + ('py', False),
|
| + ('py.t', False),
|
| + ('py.test', True),
|
| + ('py.testing', False),
|
| + ('py.test.buz', True),
|
| + ('py.test.buz.baz', True),
|
| + ('__main__', False),
|
| + ('mymain', True),
|
| + ('yourmain', False),
|
| + ]
|
| + modules = ['test', 'py.test', 'mymain']
|
| + mm = ModuleMatcher(modules)
|
| + self.assertEqual(
|
| + mm.info(),
|
| + modules
|
| + )
|
| + for modulename, matches in matches_to_try:
|
| + self.assertEqual(
|
| + mm.match(modulename),
|
| + matches,
|
| + modulename,
|
| + )
|
| +
|
| + def test_fnmatch_matcher(self):
|
| + matches_to_try = [
|
| + (self.make_file("sub/file1.py"), True),
|
| + (self.make_file("sub/file2.c"), False),
|
| + (self.make_file("sub2/file3.h"), True),
|
| + (self.make_file("sub3/file4.py"), True),
|
| + (self.make_file("sub3/file5.c"), False),
|
| + ]
|
| + fnm = FnmatchMatcher(["*.py", "*/sub2/*"])
|
| + self.assertEqual(fnm.info(), ["*.py", "*/sub2/*"])
|
| + for filepath, matches in matches_to_try:
|
| + self.assertMatches(fnm, filepath, matches)
|
| +
|
| + def test_fnmatch_matcher_overload(self):
|
| + fnm = FnmatchMatcher(["*x%03d*.txt" % i for i in range(500)])
|
| + self.assertMatches(fnm, "x007foo.txt", True)
|
| + self.assertMatches(fnm, "x123foo.txt", True)
|
| + self.assertMatches(fnm, "x798bar.txt", False)
|
| +
|
| + def test_fnmatch_windows_paths(self):
|
| + # We should be able to match Windows paths even if we are running on
|
| + # a non-Windows OS.
|
| + fnm = FnmatchMatcher(["*/foo.py"])
|
| + self.assertMatches(fnm, r"dir\foo.py", True)
|
| + fnm = FnmatchMatcher([r"*\foo.py"])
|
| + self.assertMatches(fnm, r"dir\foo.py", True)
|
| +
|
| +
|
| +class PathAliasesTest(CoverageTest):
|
| + """Tests for coverage/files.py:PathAliases"""
|
| +
|
| + run_in_temp_dir = False
|
| +
|
| + def assert_mapped(self, aliases, inp, out):
|
| + """Assert that `inp` mapped through `aliases` produces `out`.
|
| +
|
| + `out` is canonicalized first, since aliases always produce
|
| + canonicalized paths.
|
| +
|
| + """
|
| + self.assertEqual(aliases.map(inp), files.canonical_filename(out))
|
| +
|
| + def assert_not_mapped(self, aliases, inp):
|
| + """Assert that `inp` mapped through `aliases` is unchanged."""
|
| + self.assertEqual(aliases.map(inp), inp)
|
| +
|
| + def test_noop(self):
|
| + aliases = PathAliases()
|
| + self.assert_not_mapped(aliases, '/ned/home/a.py')
|
| +
|
| + def test_nomatch(self):
|
| + aliases = PathAliases()
|
| + aliases.add('/home/*/src', './mysrc')
|
| + self.assert_not_mapped(aliases, '/home/foo/a.py')
|
| +
|
| + def test_wildcard(self):
|
| + aliases = PathAliases()
|
| + aliases.add('/ned/home/*/src', './mysrc')
|
| + self.assert_mapped(aliases, '/ned/home/foo/src/a.py', './mysrc/a.py')
|
| +
|
| + aliases = PathAliases()
|
| + aliases.add('/ned/home/*/src/', './mysrc')
|
| + self.assert_mapped(aliases, '/ned/home/foo/src/a.py', './mysrc/a.py')
|
| +
|
| + def test_no_accidental_match(self):
|
| + aliases = PathAliases()
|
| + aliases.add('/home/*/src', './mysrc')
|
| + self.assert_not_mapped(aliases, '/home/foo/srcetc')
|
| +
|
| + def test_multiple_patterns(self):
|
| + aliases = PathAliases()
|
| + aliases.add('/home/*/src', './mysrc')
|
| + aliases.add('/lib/*/libsrc', './mylib')
|
| + self.assert_mapped(aliases, '/home/foo/src/a.py', './mysrc/a.py')
|
| + self.assert_mapped(aliases, '/lib/foo/libsrc/a.py', './mylib/a.py')
|
| +
|
| + def test_cant_have_wildcard_at_end(self):
|
| + aliases = PathAliases()
|
| + msg = "Pattern must not end with wildcards."
|
| + with self.assertRaisesRegex(CoverageException, msg):
|
| + aliases.add("/ned/home/*", "fooey")
|
| + with self.assertRaisesRegex(CoverageException, msg):
|
| + aliases.add("/ned/home/*/", "fooey")
|
| + with self.assertRaisesRegex(CoverageException, msg):
|
| + aliases.add("/ned/home/*/*/", "fooey")
|
| +
|
| + def test_no_accidental_munging(self):
|
| + aliases = PathAliases()
|
| + aliases.add(r'c:\Zoo\boo', 'src/')
|
| + aliases.add('/home/ned$', 'src/')
|
| + self.assert_mapped(aliases, r'c:\Zoo\boo\foo.py', 'src/foo.py')
|
| + self.assert_mapped(aliases, r'/home/ned$/foo.py', 'src/foo.py')
|
| +
|
| + def test_paths_are_os_corrected(self):
|
| + aliases = PathAliases()
|
| + aliases.add('/home/ned/*/src', './mysrc')
|
| + aliases.add(r'c:\ned\src', './mysrc')
|
| + self.assert_mapped(aliases, r'C:\Ned\src\sub\a.py', './mysrc/sub/a.py')
|
| +
|
| + aliases = PathAliases()
|
| + aliases.add('/home/ned/*/src', r'.\mysrc')
|
| + aliases.add(r'c:\ned\src', r'.\mysrc')
|
| + self.assert_mapped(aliases, r'/home/ned/foo/src/sub/a.py', r'.\mysrc\sub\a.py')
|
| +
|
| + def test_leading_wildcard(self):
|
| + aliases = PathAliases()
|
| + aliases.add('*/d1', './mysrc1')
|
| + aliases.add('*/d2', './mysrc2')
|
| + self.assert_mapped(aliases, '/foo/bar/d1/x.py', './mysrc1/x.py')
|
| + self.assert_mapped(aliases, '/foo/bar/d2/y.py', './mysrc2/y.py')
|
| +
|
| + def test_dot(self):
|
| + for d in ('.', '..', '../other', '~'):
|
| + aliases = PathAliases()
|
| + aliases.add(d, '/the/source')
|
| + the_file = os.path.join(d, 'a.py')
|
| + the_file = os.path.expanduser(the_file)
|
| + the_file = os.path.abspath(os.path.realpath(the_file))
|
| +
|
| + assert '~' not in the_file # to be sure the test is pure.
|
| + self.assert_mapped(aliases, the_file, '/the/source/a.py')
|
| +
|
| +
|
| +class FindPythonFilesTest(CoverageTest):
|
| + """Tests of `find_python_files`."""
|
| +
|
| + def test_find_python_files(self):
|
| + self.make_file("sub/a.py")
|
| + self.make_file("sub/b.py")
|
| + self.make_file("sub/x.c") # nope: not .py
|
| + self.make_file("sub/ssub/__init__.py")
|
| + self.make_file("sub/ssub/s.py")
|
| + self.make_file("sub/ssub/~s.py") # nope: editor effluvia
|
| + self.make_file("sub/lab/exp.py") # nope: no __init__.py
|
| + self.make_file("sub/windows.pyw")
|
| + py_files = set(find_python_files("sub"))
|
| + self.assert_same_files(py_files, [
|
| + "sub/a.py", "sub/b.py",
|
| + "sub/ssub/__init__.py", "sub/ssub/s.py",
|
| + "sub/windows.pyw",
|
| + ])
|
| +
|
| +
|
| +class WindowsFileTest(CoverageTest):
|
| + """Windows-specific tests of file name handling."""
|
| +
|
| + run_in_temp_dir = False
|
| +
|
| + def setUp(self):
|
| + if not env.WINDOWS:
|
| + self.skip("Only need to run Windows tests on Windows.")
|
| + super(WindowsFileTest, self).setUp()
|
| +
|
| + def test_actual_path(self):
|
| + self.assertEquals(actual_path(r'c:\Windows'), actual_path(r'C:\wINDOWS'))
|
|
|