Chromium Code Reviews
chromiumcodereview-hr@appspot.gserviceaccount.com (chromiumcodereview-hr) | Please choose your nickname with Settings | Help | Chromium Project | Gerrit Changes | Sign out
(133)

Unified Diff: tools-webrtc/check_package_boundaries_test.py

Issue 2629723004: Add presubmit check to prevent package boundary violations. (Closed)
Patch Set: Sort lists before comparing. Created 3 years, 11 months ago
Use n/p to move between diff chunks; N/P to move between comments. Draft comments are only viewable by you.
Jump to:
View side-by-side diff with in-line comments
Download patch
« no previous file with comments | « tools-webrtc/check_package_boundaries.py ('k') | tools-webrtc/testdata/all_build_files/BUILD.gn » ('j') | no next file with comments »
Expand Comments ('e') | Collapse Comments ('c') | Show Comments Hide Comments ('s')
Index: tools-webrtc/check_package_boundaries_test.py
diff --git a/tools-webrtc/check_package_boundaries_test.py b/tools-webrtc/check_package_boundaries_test.py
new file mode 100755
index 0000000000000000000000000000000000000000..437f6e6eac69b73e21830e6fac817475d2b4e2f1
--- /dev/null
+++ b/tools-webrtc/check_package_boundaries_test.py
@@ -0,0 +1,67 @@
+#!/usr/bin/env python
+
+# Copyright (c) 2017 The WebRTC project authors. All Rights Reserved.
+#
+# Use of this source code is governed by a BSD-style license
+# that can be found in the LICENSE file in the root of the source
+# tree. An additional intellectual property rights grant can be found
+# in the file PATENTS. All contributing project authors may
+# be found in the AUTHORS file in the root of the source tree.
+
+import ast
+import os
+import unittest
+
+from check_package_boundaries import CheckPackageBoundaries
+
+
+MSG_FORMAT = 'ERROR:check_package_boundaries.py: Unexpected %s.'
+TESTDATA_DIR = os.path.join(os.path.dirname(os.path.abspath(__file__)),
+ 'testdata')
+
+
+def ReadPylFile(file_path):
+ with open(file_path) as f:
+ return ast.literal_eval(f.read())
+
+
+class Logger(object):
+ def __init__(self, test_dir):
+ self.messages = []
+ self.test_dir = test_dir
+
+ def log(self, build_file_path, line_number, target_name, source_file,
+ subpackage):
+ build_file_path = os.path.relpath(build_file_path, self.test_dir)
+ self.messages.append([build_file_path, line_number, target_name,
+ source_file, subpackage])
+
+
+class UnitTest(unittest.TestCase):
+ def RunTest(self, test_dir, check_all_build_files=False):
+ logger = Logger(test_dir)
+ build_files = [os.path.join(test_dir, 'BUILD.gn')]
+ if check_all_build_files:
+ build_files = None
+ CheckPackageBoundaries(test_dir, logger, build_files)
+ expected_messages = ReadPylFile(os.path.join(test_dir, 'expected.pyl'))
+ self.assertListEqual(sorted(expected_messages), sorted(logger.messages))
+
+ def test_no_errors(self):
+ self.RunTest(os.path.join(TESTDATA_DIR, 'no_errors'))
+
+ def test_multiple_errors_single_target(self):
+ self.RunTest(os.path.join(TESTDATA_DIR, 'multiple_errors_single_target'))
+
+ def test_multiple_errors_multiple_targets(self):
+ self.RunTest(os.path.join(TESTDATA_DIR, 'multiple_errors_multiple_targets'))
+
+ def test_common_prefix(self):
+ self.RunTest(os.path.join(TESTDATA_DIR, 'common_prefix'))
+
+ def test_all_build_files(self):
+ self.RunTest(os.path.join(TESTDATA_DIR, 'all_build_files'), True)
+
+
+if __name__ == '__main__':
+ unittest.main()
« no previous file with comments | « tools-webrtc/check_package_boundaries.py ('k') | tools-webrtc/testdata/all_build_files/BUILD.gn » ('j') | no next file with comments »

Powered by Google App Engine
This is Rietveld 408576698