Chromium Code Reviews| Index: PRESUBMIT_test.py |
| diff --git a/PRESUBMIT_test.py b/PRESUBMIT_test.py |
| new file mode 100644 |
| index 0000000000000000000000000000000000000000..ae4de0947ab24540fff2f7013c0ec97e8a6bb120 |
| --- /dev/null |
| +++ b/PRESUBMIT_test.py |
| @@ -0,0 +1,158 @@ |
| +# Copyright (c) 2012 The Chromium Authors. All rights reserved. |
|
M-A Ruel
2012/11/15 16:49:31
#!/usr/bin/env python
and do a chmod +x PRESUBMIT
marja
2012/11/15 17:48:46
Done.
|
| +# Use of this source code is governed by a BSD-style license that can be |
| +# found in the LICENSE file. |
| + |
| +import os |
| +import re |
| +import unittest |
| + |
| +import PRESUBMIT |
| + |
| + |
| +class MockInputApi(object): |
| + def __init__(self): |
| + self.re = re |
| + self.os_path = os.path |
| + |
| + |
| +class MockFile(object): |
| + def __init__(self, local_path, new_contents): |
| + self._local_path = local_path |
| + self._new_contents = new_contents |
| + |
| + def NewContents(self): |
| + return self._new_contents |
| + |
| + def LocalPath(self): |
| + return self._local_path |
| + |
| + |
| +class IncludeOrderTest(unittest.TestCase): |
| + def testSystemHeaderOrder(self): |
| + scope = [(1, '#include <csystem.h>'), |
| + (2, '#include <cppsystem>'), |
| + (3, '#include "acustom.h"')] |
| + all_linenums = [linenum for (linenum, _) in scope] |
| + mock_input_api = MockInputApi() |
| + warnings = PRESUBMIT._CheckIncludeOrderForScope(scope, mock_input_api, |
| + '', all_linenums) |
| + self.assertEqual(0, len(warnings)) |
| + |
| + def testSystemHeaderOrderMismatch1(self): |
| + scope = [(10, '#include <cppsystem>'), |
| + (20, '#include <csystem.h>'), |
| + (30, '#include "acustom.h"')] |
| + all_linenums = [linenum for (linenum, _) in scope] |
| + mock_input_api = MockInputApi() |
| + warnings = PRESUBMIT._CheckIncludeOrderForScope(scope, mock_input_api, |
| + '', all_linenums) |
| + self.assertEqual(1, len(warnings)) |
| + self.assertTrue('20' in warnings[0]) |
| + |
| + def testSystemHeaderOrderMismatch2(self): |
| + scope = [(10, '#include <cppsystem>'), |
| + (20, '#include "acustom.h"'), |
| + (30, '#include <csystem.h>')] |
| + all_linenums = [linenum for (linenum, _) in scope] |
| + mock_input_api = MockInputApi() |
| + warnings = PRESUBMIT._CheckIncludeOrderForScope(scope, mock_input_api, |
| + '', all_linenums) |
| + self.assertEqual(1, len(warnings)) |
| + self.assertTrue('30' in warnings[0]) |
| + |
| + def testSystemHeaderOrderMismatch3(self): |
| + scope = [(10, '#include "acustom.h"'), |
| + (20, '#include <csystem.h>'), |
| + (30, '#include <cppsystem>')] |
| + all_linenums = [linenum for (linenum, _) in scope] |
| + mock_input_api = MockInputApi() |
| + warnings = PRESUBMIT._CheckIncludeOrderForScope(scope, mock_input_api, |
| + '', all_linenums) |
| + self.assertEqual(2, len(warnings)) |
| + self.assertTrue('20' in warnings[0]) |
| + self.assertTrue('30' in warnings[1]) |
| + |
| + def testAlphabeticalOrderMismatch(self): |
| + scope = [(10, '#include <csystem.h>'), |
| + (15, '#include <bsystem.h>'), |
| + (20, '#include <cppsystem>'), |
| + (25, '#include <bppsystem>'), |
| + (30, '#include "bcustom.h"'), |
| + (35, '#include "acustom.h"')] |
| + all_linenums = [linenum for (linenum, _) in scope] |
| + mock_input_api = MockInputApi() |
| + warnings = PRESUBMIT._CheckIncludeOrderForScope(scope, mock_input_api, |
| + '', all_linenums) |
| + self.assertEqual(3, len(warnings)) |
| + self.assertTrue('15' in warnings[0]) |
| + self.assertTrue('25' in warnings[1]) |
| + self.assertTrue('35' in warnings[2]) |
| + |
| + def testSpecialFirstInclude1(self): |
| + mock_input_api = MockInputApi() |
| + contents = ['#include "some/path/foo.h"', |
| + '#include "a/header.h"'] |
| + mock_file = MockFile('some/path/foo.cc', contents) |
| + warnings = PRESUBMIT._CheckIncludeOrderInFile( |
| + mock_input_api, mock_file, True, range(1, len(contents) + 1)) |
| + self.assertEqual(0, len(warnings)) |
| + |
| + def testSpecialFirstInclude2(self): |
| + mock_input_api = MockInputApi() |
| + contents = ['#include "some/other/path/foo.h"', |
| + '#include "a/header.h"'] |
| + mock_file = MockFile('some/path/foo.cc', contents) |
| + warnings = PRESUBMIT._CheckIncludeOrderInFile( |
| + mock_input_api, mock_file, True, range(1, len(contents) + 1)) |
| + self.assertEqual(0, len(warnings)) |
| + |
| + def testSpecialFirstInclude3(self): |
| + mock_input_api = MockInputApi() |
| + contents = ['#include "some/path/foo.h"', |
| + '#include "a/header.h"'] |
| + mock_file = MockFile('some/path/foo_platform.cc', contents) |
| + warnings = PRESUBMIT._CheckIncludeOrderInFile( |
| + mock_input_api, mock_file, True, range(1, len(contents) + 1)) |
| + self.assertEqual(0, len(warnings)) |
| + |
| + def testSpecialFirstInclude4(self): |
| + mock_input_api = MockInputApi() |
| + contents = ['#include "some/path/bar.h"', |
| + '#include "a/header.h"'] |
| + mock_file = MockFile('some/path/foo_platform.cc', contents) |
| + warnings = PRESUBMIT._CheckIncludeOrderInFile( |
| + mock_input_api, mock_file, True, range(1, len(contents) + 1)) |
| + self.assertEqual(1, len(warnings)) |
| + self.assertTrue('2' in warnings[0]) |
| + |
| + def testOrderAlreadyWrong(self): |
| + scope = [(1, '#include "b.h"'), |
| + (2, '#include "a.h"'), |
| + (3, '#include "c.h"')] |
| + mock_input_api = MockInputApi() |
| + warnings = PRESUBMIT._CheckIncludeOrderForScope(scope, mock_input_api, |
| + '', [3]) |
| + self.assertEqual(0, len(warnings)) |
| + |
| + def testConflictAdded1(self): |
| + scope = [(1, '#include "a.h"'), |
| + (2, '#include "c.h"'), |
| + (3, '#include "b.h"')] |
| + mock_input_api = MockInputApi() |
| + warnings = PRESUBMIT._CheckIncludeOrderForScope(scope, mock_input_api, |
| + '', [2]) |
| + self.assertEqual(1, len(warnings)) |
| + self.assertTrue('3' in warnings[0]) |
| + |
| + def testConflictAdded2(self): |
| + scope = [(1, '#include "c.h"'), |
| + (2, '#include "b.h"'), |
| + (3, '#include "d.h"')] |
| + mock_input_api = MockInputApi() |
| + warnings = PRESUBMIT._CheckIncludeOrderForScope(scope, mock_input_api, |
| + '', [2]) |
| + self.assertEqual(1, len(warnings)) |
| + self.assertTrue('2' in warnings[0]) |
| + |
|
M-A Ruel
2012/11/15 16:49:31
two lines
marja
2012/11/15 17:48:46
Done.
|
| +if __name__ == '__main__': |
| + unittest.main() |