f2d2fd1b1c5d5e01c1746740fe96847035ab4dab
[platform/upstream/gtest.git] / test / gtest_list_tests_unittest.py
1 #!/usr/bin/env python
2 #
3 # Copyright 2006, Google Inc.
4 # All rights reserved.
5 #
6 # Redistribution and use in source and binary forms, with or without
7 # modification, are permitted provided that the following conditions are
8 # met:
9 #
10 #     * Redistributions of source code must retain the above copyright
11 # notice, this list of conditions and the following disclaimer.
12 #     * Redistributions in binary form must reproduce the above
13 # copyright notice, this list of conditions and the following disclaimer
14 # in the documentation and/or other materials provided with the
15 # distribution.
16 #     * Neither the name of Google Inc. nor the names of its
17 # contributors may be used to endorse or promote products derived from
18 # this software without specific prior written permission.
19 #
20 # THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
21 # "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
22 # LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
23 # A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
24 # OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
25 # SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
26 # LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
27 # DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
28 # THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 # (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
30 # OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31
32 """Unit test for Google Test's --gtest_list_tests flag.
33
34 A user can ask Google Test to list all tests by specifying the
35 --gtest_list_tests flag.  This script tests such functionality
36 by invoking gtest_list_tests_unittest_ (a program written with
37 Google Test) the command line flags.
38 """
39
40 __author__ = 'phanna@google.com (Patrick Hanna)'
41
42 import gtest_test_utils
43 import re
44
45
46 # Constants.
47
48 # The command line flag for enabling/disabling listing all tests.
49 LIST_TESTS_FLAG = 'gtest_list_tests'
50
51 # Path to the gtest_list_tests_unittest_ program.
52 EXE_PATH = gtest_test_utils.GetTestExecutablePath('gtest_list_tests_unittest_')
53
54 # The expected output when running gtest_list_tests_unittest_ with
55 # --gtest_list_tests
56 EXPECTED_OUTPUT_NO_FILTER_RE = re.compile(r"""FooDeathTest\.
57   Test1
58 Foo\.
59   Bar1
60   Bar2
61   DISABLED_Bar3
62 Abc\.
63   Xyz
64   Def
65 FooBar\.
66   Baz
67 FooTest\.
68   Test1
69   DISABLED_Test2
70   Test3
71 TypedTest/0\.  # TypeParam = (VeryLo{245}|class VeryLo{239})\.\.\.
72   TestA
73   TestB
74 TypedTest/1\.  # TypeParam = int\s*\*( __ptr64)?
75   TestA
76   TestB
77 TypedTest/2\.  # TypeParam = .*MyArray<bool,\s*42>
78   TestA
79   TestB
80 My/TypeParamTest/0\.  # TypeParam = (VeryLo{245}|class VeryLo{239})\.\.\.
81   TestA
82   TestB
83 My/TypeParamTest/1\.  # TypeParam = int\s*\*( __ptr64)?
84   TestA
85   TestB
86 My/TypeParamTest/2\.  # TypeParam = .*MyArray<bool,\s*42>
87   TestA
88   TestB
89 MyInstantiation/ValueParamTest\.
90   TestA/0  # GetParam\(\) = one line
91   TestA/1  # GetParam\(\) = two\\nlines
92   TestA/2  # GetParam\(\) = a very\\nlo{241}\.\.\.
93   TestB/0  # GetParam\(\) = one line
94   TestB/1  # GetParam\(\) = two\\nlines
95   TestB/2  # GetParam\(\) = a very\\nlo{241}\.\.\.
96 """)
97
98 # The expected output when running gtest_list_tests_unittest_ with
99 # --gtest_list_tests and --gtest_filter=Foo*.
100 EXPECTED_OUTPUT_FILTER_FOO_RE = re.compile(r"""FooDeathTest\.
101   Test1
102 Foo\.
103   Bar1
104   Bar2
105   DISABLED_Bar3
106 FooBar\.
107   Baz
108 FooTest\.
109   Test1
110   DISABLED_Test2
111   Test3
112 """)
113
114 # Utilities.
115
116
117 def Run(args):
118   """Runs gtest_list_tests_unittest_ and returns the list of tests printed."""
119
120   return gtest_test_utils.Subprocess([EXE_PATH] + args,
121                                      capture_stderr=False).output
122
123
124 # The unit test.
125
126 class GTestListTestsUnitTest(gtest_test_utils.TestCase):
127   """Tests using the --gtest_list_tests flag to list all tests."""
128
129   def RunAndVerify(self, flag_value, expected_output_re, other_flag):
130     """Runs gtest_list_tests_unittest_ and verifies that it prints
131     the correct tests.
132
133     Args:
134       flag_value:         value of the --gtest_list_tests flag;
135                           None if the flag should not be present.
136       expected_output_re: regular expression that matches the expected
137                           output after running command;
138       other_flag:         a different flag to be passed to command
139                           along with gtest_list_tests;
140                           None if the flag should not be present.
141     """
142
143     if flag_value is None:
144       flag = ''
145       flag_expression = 'not set'
146     elif flag_value == '0':
147       flag = '--%s=0' % LIST_TESTS_FLAG
148       flag_expression = '0'
149     else:
150       flag = '--%s' % LIST_TESTS_FLAG
151       flag_expression = '1'
152
153     args = [flag]
154
155     if other_flag is not None:
156       args += [other_flag]
157
158     output = Run(args)
159
160     if expected_output_re:
161       self.assert_(
162           expected_output_re.match(output),
163           ('when %s is %s, the output of "%s" is "%s",\n'
164            'which does not match regex "%s"' %
165            (LIST_TESTS_FLAG, flag_expression, ' '.join(args), output,
166             expected_output_re.pattern)))
167     else:
168       self.assert_(
169           not EXPECTED_OUTPUT_NO_FILTER_RE.match(output),
170           ('when %s is %s, the output of "%s" is "%s"'%
171            (LIST_TESTS_FLAG, flag_expression, ' '.join(args), output)))
172
173   def testDefaultBehavior(self):
174     """Tests the behavior of the default mode."""
175
176     self.RunAndVerify(flag_value=None,
177                       expected_output_re=None,
178                       other_flag=None)
179
180   def testFlag(self):
181     """Tests using the --gtest_list_tests flag."""
182
183     self.RunAndVerify(flag_value='0',
184                       expected_output_re=None,
185                       other_flag=None)
186     self.RunAndVerify(flag_value='1',
187                       expected_output_re=EXPECTED_OUTPUT_NO_FILTER_RE,
188                       other_flag=None)
189
190   def testOverrideNonFilterFlags(self):
191     """Tests that --gtest_list_tests overrides the non-filter flags."""
192
193     self.RunAndVerify(flag_value='1',
194                       expected_output_re=EXPECTED_OUTPUT_NO_FILTER_RE,
195                       other_flag='--gtest_break_on_failure')
196
197   def testWithFilterFlags(self):
198     """Tests that --gtest_list_tests takes into account the
199     --gtest_filter flag."""
200
201     self.RunAndVerify(flag_value='1',
202                       expected_output_re=EXPECTED_OUTPUT_FILTER_FOO_RE,
203                       other_flag='--gtest_filter=Foo*')
204
205
206 if __name__ == '__main__':
207   gtest_test_utils.Main()