OpenCores
URL https://opencores.org/ocsvn/s80186/s80186/trunk

Subversion Repositories s80186

[/] [s80186/] [trunk/] [vendor/] [googletest/] [googletest/] [test/] [gtest_list_tests_unittest.py] - Blame information for rev 2

Details | Compare with Previous | View Log

Line No. Rev Author Line
1 2 jamieiles
#!/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()

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.