Skip to content

Commit 8c91ece

Browse files
committed
Merge pull request #2517 from snarkmaster:master
PiperOrigin-RevId: 275869169
2 parents de11283 + cbf019d commit 8c91ece

File tree

6 files changed

+71
-5
lines changed

6 files changed

+71
-5
lines changed

googletest/CMakeLists.txt

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -266,6 +266,7 @@ $env:Path = \"$project_bin;$env:Path\"
266266
cxx_executable(googletest-break-on-failure-unittest_ test gtest)
267267
py_test(googletest-break-on-failure-unittest)
268268

269+
py_test(gtest_skip_check_output_test)
269270
py_test(gtest_skip_environment_check_output_test)
270271

271272
# Visual Studio .NET 2003 does not support STL with exceptions disabled.

googletest/include/gtest/gtest.h

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -1889,7 +1889,7 @@ class TestWithParam : public Test, public WithParamInterface<T> {
18891889
// Skips test in runtime.
18901890
// Skipping test aborts current function.
18911891
// Skipped tests are neither successful nor failed.
1892-
#define GTEST_SKIP() GTEST_SKIP_("Skipped")
1892+
#define GTEST_SKIP() GTEST_SKIP_("")
18931893

18941894
// ADD_FAILURE unconditionally adds a failure to the current test.
18951895
// SUCCEED generates a success - it doesn't automatically make the

googletest/src/gtest.cc

Lines changed: 1 addition & 3 deletions
Original file line numberDiff line numberDiff line change
@@ -3220,9 +3220,7 @@ void PrettyUnitTestResultPrinter::OnTestStart(const TestInfo& test_info) {
32203220
void PrettyUnitTestResultPrinter::OnTestPartResult(
32213221
const TestPartResult& result) {
32223222
switch (result.type()) {
3223-
// If the test part succeeded, or was skipped,
3224-
// we don't need to do anything.
3225-
case TestPartResult::kSkip:
3223+
// If the test part succeeded, we don't need to do anything.
32263224
case TestPartResult::kSuccess:
32273225
return;
32283226
default:

googletest/test/BUILD.bazel

Lines changed: 8 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -295,6 +295,14 @@ cc_test(
295295
deps = ["//:gtest_main"],
296296
)
297297

298+
py_test(
299+
name = "gtest_skip_check_output_test",
300+
size = "small",
301+
srcs = ["gtest_skip_check_output_test.py"],
302+
data = [":gtest_skip_test"],
303+
deps = [":gtest_test_utils"],
304+
)
305+
298306
py_test(
299307
name = "gtest_skip_environment_check_output_test",
300308
size = "small",
Lines changed: 59 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,59 @@
1+
#!/usr/bin/env python
2+
#
3+
# Copyright 2019 Google LLC. All Rights Reserved.
4+
#
5+
# Redistribution and use in source and binary forms, with or without
6+
# modification, are permitted provided that the following conditions are
7+
# met:
8+
#
9+
# * Redistributions of source code must retain the above copyright
10+
# notice, this list of conditions and the following disclaimer.
11+
# * Redistributions in binary form must reproduce the above
12+
# copyright notice, this list of conditions and the following disclaimer
13+
# in the documentation and/or other materials provided with the
14+
# distribution.
15+
# * Neither the name of Google Inc. nor the names of its
16+
# contributors may be used to endorse or promote products derived from
17+
# this software without specific prior written permission.
18+
#
19+
# THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
20+
# "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
21+
# LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
22+
# A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
23+
# OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24+
# SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
25+
# LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
26+
# DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
27+
# THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
28+
# (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
29+
# OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30+
"""Tests Google Test's gtest skip in environment setup behavior.
31+
32+
This script invokes gtest_skip_in_environment_setup_test_ and verifies its
33+
output.
34+
"""
35+
36+
import re
37+
38+
import gtest_test_utils
39+
40+
# Path to the gtest_skip_in_environment_setup_test binary
41+
EXE_PATH = gtest_test_utils.GetTestExecutablePath('gtest_skip_test')
42+
43+
OUTPUT = gtest_test_utils.Subprocess([EXE_PATH]).output
44+
45+
46+
# Test.
47+
class SkipEntireEnvironmentTest(gtest_test_utils.TestCase):
48+
49+
def testSkipEntireEnvironmentTest(self):
50+
self.assertIn('Skipped\nskipping single test\n', OUTPUT)
51+
skip_fixture = 'Skipped\nskipping all tests for this fixture\n'
52+
self.assertIsNotNone(
53+
re.search(skip_fixture + '.*' + skip_fixture, OUTPUT, flags=re.DOTALL),
54+
repr(OUTPUT))
55+
self.assertNotIn('FAILED', OUTPUT)
56+
57+
58+
if __name__ == '__main__':
59+
gtest_test_utils.Main()

googletest/test/gtest_skip_test.cc

Lines changed: 1 addition & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -35,7 +35,7 @@
3535
using ::testing::Test;
3636

3737
TEST(SkipTest, DoesSkip) {
38-
GTEST_SKIP();
38+
GTEST_SKIP() << "skipping single test";
3939
EXPECT_EQ(0, 1);
4040
}
4141

0 commit comments

Comments
 (0)