# Copyright 2017 The Chromium Authors. All rights reserved. # Use of this source code is governed by a BSD-style license that can be # found in the LICENSE file. # # Note: running this test requires installing the package python-mock. # pylint: disable=C0103 # pylint: disable=F0401 import PRESUBMIT import mock import os.path import subprocess import sys import unittest sys.path.append( os.path.join(os.path.dirname(os.path.abspath(__file__)), '..', '..')) from PRESUBMIT_test_mocks import MockInputApi from PRESUBMIT_test_mocks import MockOutputApi from PRESUBMIT_test_mocks import MockAffectedFile class Capture(object): """Class to capture a call argument that can be tested later on.""" def __init__(self): self.value = None def __eq__(self, other): self.value = other return True class PresubmitTest(unittest.TestCase): @mock.patch('subprocess.Popen') def testCheckChangeOnUploadWithWebKitAndChromiumFiles(self, _): """This verifies that CheckChangeOnUpload will only call check-webkit-style on WebKit files. """ diff_file_webkit_h = ['some diff'] diff_file_chromium_h = ['another diff'] mock_input_api = MockInputApi() mock_input_api.files = [ MockAffectedFile('FileWebkit.h', diff_file_webkit_h), MockAffectedFile('file_chromium.h', diff_file_chromium_h) ] # Access to a protected member _CheckStyle # pylint: disable=W0212 PRESUBMIT._CheckStyle(mock_input_api, MockOutputApi()) capture = Capture() # pylint: disable=E1101 subprocess.Popen.assert_called_with(capture, stderr=-1) self.assertEqual(4, len(capture.value)) self.assertEqual('../../FileWebkit.h', capture.value[3]) @mock.patch('subprocess.Popen') def testCheckChangeOnUploadWithEmptyAffectedFileList(self, _): """This verifies that CheckChangeOnUpload will skip calling check-webkit-style if the affected file list is empty. """ diff_file_chromium1_h = ['some diff'] diff_file_chromium2_h = ['another diff'] mock_input_api = MockInputApi() mock_input_api.files = [ MockAffectedFile('first_file_chromium.h', diff_file_chromium1_h), MockAffectedFile('second_file_chromium.h', diff_file_chromium2_h) ] # Access to a protected member _CheckStyle # pylint: disable=W0212 PRESUBMIT._CheckStyle(mock_input_api, MockOutputApi()) # pylint: disable=E1101 subprocess.Popen.assert_not_called() def testCheckPublicHeaderWithBlinkMojo(self): """This verifies that _CheckForWrongMojomIncludes detects -blink mojo headers in public files. """ mock_input_api = MockInputApi() potentially_bad_content = '#include "public/platform/modules/cache_storage.mojom-blink.h"' mock_input_api.files = [ MockAffectedFile('third_party/WebKit/public/AHeader.h', [potentially_bad_content], None) ] # Access to a protected member _CheckForWrongMojomIncludes # pylint: disable=W0212 errors = PRESUBMIT._CheckForWrongMojomIncludes(mock_input_api, MockOutputApi()) self.assertEquals( 'Public blink headers using Blink variant mojoms found. ' + 'You must include .mojom-shared.h instead:', errors[0].message) def testCheckInternalHeaderWithBlinkMojo(self): """This verifies that _CheckForWrongMojomIncludes accepts -blink mojo headers in blink internal files. """ mock_input_api = MockInputApi() potentially_bad_content = '#include "public/platform/modules/cache_storage.mojom-blink.h"' mock_input_api.files = [ MockAffectedFile('third_party/WebKit/Source/public/AHeader.h', [potentially_bad_content], None) ] # Access to a protected member _CheckForWrongMojomIncludes # pylint: disable=W0212 errors = PRESUBMIT._CheckForWrongMojomIncludes(mock_input_api, MockOutputApi()) self.assertEquals([], errors) class CxxDependencyTest(unittest.TestCase): allow_list = [ 'gfx::ColorSpace', 'gfx::CubicBezier', 'gfx::ICCProfile', 'gfx::ScrollOffset', 'scoped_refptr', ] disallow_list = [ 'GURL', 'base::Callback', 'base::OnceCallback', 'content::RenderFrame', 'gfx::Point', 'gfx::Rect', 'net::IPEndPoint', 'ui::Clipboard', ] disallow_message = [ ] def runCheck(self, filename, file_contents): mock_input_api = MockInputApi() mock_input_api.files = [ MockAffectedFile(filename, file_contents), ] # Access to a protected member # pylint: disable=W0212 return PRESUBMIT._CheckForForbiddenChromiumCode(mock_input_api, MockOutputApi()) # References in comments should never be checked. def testCheckCommentsIgnored(self): filename = 'third_party/WebKit/Source/core/frame/frame.cc' for item in self.allow_list: errors = self.runCheck(filename, ['// %s' % item]) self.assertEqual([], errors) for item in self.disallow_list: errors = self.runCheck(filename, ['// %s' % item]) self.assertEqual([], errors) # core, modules, public, et cetera should all have dependency enforcement. def testCheckCoreEnforcement(self): filename = 'third_party/WebKit/Source/core/frame/frame.cc' for item in self.allow_list: errors = self.runCheck(filename, ['%s' % item]) self.assertEqual([], errors) for item in self.disallow_list: errors = self.runCheck(filename, ['%s' % item]) self.assertEquals(1, len(errors)) self.assertRegexpMatches( errors[0].message, r'^[^:]+:\d+ uses disallowed identifier .+$') def testCheckModulesEnforcement(self): filename = 'third_party/WebKit/Source/modules/modules_initializer.cc' for item in self.allow_list: errors = self.runCheck(filename, ['%s' % item]) self.assertEqual([], errors) for item in self.disallow_list: errors = self.runCheck(filename, ['%s' % item]) self.assertEquals(1, len(errors)) self.assertRegexpMatches( errors[0].message, r'^[^:]+:\d+ uses disallowed identifier .+$') def testCheckPublicEnforcement(self): filename = 'third_party/WebKit/Source/public/platform/WebThread.h' for item in self.allow_list: errors = self.runCheck(filename, ['%s' % item]) self.assertEqual([], errors) for item in self.disallow_list: errors = self.runCheck(filename, ['%s' % item]) self.assertEquals(1, len(errors)) self.assertRegexpMatches( errors[0].message, r'^[^:]+:\d+ uses disallowed identifier .+$') # platform and controller should be opted out of enforcement, but aren't # currently checked because the PRESUBMIT test mocks are missing too # much functionality... # External module checks should not affect CSS files. def testCheckCSSIgnored(self): filename = 'third_party/WebKit/Source/devtools/front_end/timeline/someFile.css' errors = self.runCheck(filename, ['.toolbar::after { color: pink; }\n']) self.assertEqual([], errors) if __name__ == '__main__': unittest.main()