003 File Manager
Current Path:
/usr/src/contrib/googletest/googletest/test
usr
/
src
/
contrib
/
googletest
/
googletest
/
test
/
📁
..
📄
BUILD.bazel
(13.24 KB)
📄
googletest-break-on-failure-unittest.py
(7.13 KB)
📄
googletest-break-on-failure-unittest_.cc
(3.16 KB)
📄
googletest-catch-exceptions-test.py
(9.64 KB)
📄
googletest-catch-exceptions-test_.cc
(8.63 KB)
📄
googletest-color-test.py
(4.76 KB)
📄
googletest-color-test_.cc
(2.45 KB)
📄
googletest-death-test-test.cc
(43.63 KB)
📄
googletest-death-test_ex_test.cc
(3.53 KB)
📄
googletest-env-var-test.py
(3.91 KB)
📄
googletest-env-var-test_.cc
(3.39 KB)
📄
googletest-filepath-test.cc
(22.16 KB)
📄
googletest-filter-unittest.py
(20.88 KB)
📄
googletest-filter-unittest_.cc
(3.38 KB)
📄
googletest-json-outfiles-test.py
(5.36 KB)
📄
googletest-json-output-unittest.py
(20.67 KB)
📄
googletest-linked-ptr-test.cc
(3.93 KB)
📄
googletest-list-tests-unittest.py
(6.37 KB)
📄
googletest-list-tests-unittest_.cc
(4.55 KB)
📄
googletest-listener-test.cc
(9.57 KB)
📄
googletest-message-test.cc
(5.14 KB)
📄
googletest-options-test.cc
(7.46 KB)
📄
googletest-output-test-golden-lin.txt
(34.9 KB)
📄
googletest-output-test.py
(12.34 KB)
📄
googletest-output-test_.cc
(33.82 KB)
📄
googletest-param-test-invalid-name1-test.py
(2.32 KB)
📄
googletest-param-test-invalid-name1-test_.cc
(1.97 KB)
📄
googletest-param-test-invalid-name2-test.py
(2.28 KB)
📄
googletest-param-test-invalid-name2-test_.cc
(2.08 KB)
📄
googletest-param-test-test.cc
(39.39 KB)
📄
googletest-param-test-test.h
(2.2 KB)
📄
googletest-param-test2-test.cc
(2.74 KB)
📄
googletest-port-test.cc
(39.4 KB)
📄
googletest-printers-test.cc
(55.58 KB)
📄
googletest-shuffle-test.py
(12.22 KB)
📄
googletest-shuffle-test_.cc
(3.19 KB)
📄
googletest-test-part-test.cc
(7.98 KB)
📄
googletest-test2_test.cc
(2.74 KB)
📄
googletest-throw-on-failure-test.py
(5.6 KB)
📄
googletest-throw-on-failure-test_.cc
(2.99 KB)
📄
googletest-tuple-test.cc
(8.99 KB)
📄
googletest-uninitialized-test.py
(2.41 KB)
📄
googletest-uninitialized-test_.cc
(1.83 KB)
📄
gtest-typed-test2_test.cc
(1.97 KB)
📄
gtest-typed-test_test.cc
(14.62 KB)
📄
gtest-typed-test_test.h
(2.38 KB)
📄
gtest-unittest-api_test.cc
(12.86 KB)
📄
gtest_all_test.cc
(2.23 KB)
📄
gtest_assert_by_exception_test.cc
(3.8 KB)
📄
gtest_environment_test.cc
(6.31 KB)
📄
gtest_help_test.py
(5.69 KB)
📄
gtest_help_test_.cc
(2.04 KB)
📄
gtest_json_test_utils.py
(2.35 KB)
📄
gtest_list_output_unittest.py
(4.8 KB)
📄
gtest_list_output_unittest_.cc
(2.07 KB)
📄
gtest_main_unittest.cc
(1.8 KB)
📄
gtest_no_test_unittest.cc
(2.35 KB)
📄
gtest_pred_impl_unittest.cc
(75.56 KB)
📄
gtest_premature_exit_test.cc
(4.16 KB)
📄
gtest_prod_test.cc
(2.1 KB)
📄
gtest_repeat_test.cc
(7.31 KB)
📄
gtest_skip_in_environment_setup_test.cc
(2.17 KB)
📄
gtest_skip_test.cc
(1.93 KB)
📄
gtest_sole_header_test.cc
(2.12 KB)
📄
gtest_stress_test.cc
(9.12 KB)
📄
gtest_test_macro_stack_footprint_test.cc
(3.68 KB)
📄
gtest_test_utils.py
(10.44 KB)
📄
gtest_testbridge_test.py
(2.42 KB)
📄
gtest_testbridge_test_.cc
(1.88 KB)
📄
gtest_throw_on_failure_ex_test.cc
(3.32 KB)
📄
gtest_unittest.cc
(245.37 KB)
📄
gtest_xml_outfile1_test_.cc
(1.92 KB)
📄
gtest_xml_outfile2_test_.cc
(1.92 KB)
📄
gtest_xml_outfiles_test.py
(5.42 KB)
📄
gtest_xml_output_unittest.py
(16.91 KB)
📄
gtest_xml_output_unittest_.cc
(5.96 KB)
📄
gtest_xml_test_utils.py
(9 KB)
📄
production.cc
(1.64 KB)
📄
production.h
(2.07 KB)
Editing: gtest_environment_test.cc
// Copyright 2007, Google Inc. // All rights reserved. // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions are // met: // // * Redistributions of source code must retain the above copyright // notice, this list of conditions and the following disclaimer. // * Redistributions in binary form must reproduce the above // copyright notice, this list of conditions and the following disclaimer // in the documentation and/or other materials provided with the // distribution. // * Neither the name of Google Inc. nor the names of its // contributors may be used to endorse or promote products derived from // this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // // Tests using global test environments. #include <stdlib.h> #include <stdio.h> #include "gtest/gtest.h" #include "src/gtest-internal-inl.h" namespace testing { GTEST_DECLARE_string_(filter); } namespace { enum FailureType { NO_FAILURE, NON_FATAL_FAILURE, FATAL_FAILURE }; // For testing using global test environments. class MyEnvironment : public testing::Environment { public: MyEnvironment() { Reset(); } // Depending on the value of failure_in_set_up_, SetUp() will // generate a non-fatal failure, generate a fatal failure, or // succeed. virtual void SetUp() { set_up_was_run_ = true; switch (failure_in_set_up_) { case NON_FATAL_FAILURE: ADD_FAILURE() << "Expected non-fatal failure in global set-up."; break; case FATAL_FAILURE: FAIL() << "Expected fatal failure in global set-up."; break; default: break; } } // Generates a non-fatal failure. virtual void TearDown() { tear_down_was_run_ = true; ADD_FAILURE() << "Expected non-fatal failure in global tear-down."; } // Resets the state of the environment s.t. it can be reused. void Reset() { failure_in_set_up_ = NO_FAILURE; set_up_was_run_ = false; tear_down_was_run_ = false; } // We call this function to set the type of failure SetUp() should // generate. void set_failure_in_set_up(FailureType type) { failure_in_set_up_ = type; } // Was SetUp() run? bool set_up_was_run() const { return set_up_was_run_; } // Was TearDown() run? bool tear_down_was_run() const { return tear_down_was_run_; } private: FailureType failure_in_set_up_; bool set_up_was_run_; bool tear_down_was_run_; }; // Was the TEST run? bool test_was_run; // The sole purpose of this TEST is to enable us to check whether it // was run. TEST(FooTest, Bar) { test_was_run = true; } // Prints the message and aborts the program if condition is false. void Check(bool condition, const char* msg) { if (!condition) { printf("FAILED: %s\n", msg); testing::internal::posix::Abort(); } } // Runs the tests. Return true iff successful. // // The 'failure' parameter specifies the type of failure that should // be generated by the global set-up. int RunAllTests(MyEnvironment* env, FailureType failure) { env->Reset(); env->set_failure_in_set_up(failure); test_was_run = false; testing::internal::GetUnitTestImpl()->ClearAdHocTestResult(); return RUN_ALL_TESTS(); } } // namespace int main(int argc, char **argv) { testing::InitGoogleTest(&argc, argv); // Registers a global test environment, and verifies that the // registration function returns its argument. MyEnvironment* const env = new MyEnvironment; Check(testing::AddGlobalTestEnvironment(env) == env, "AddGlobalTestEnvironment() should return its argument."); // Verifies that RUN_ALL_TESTS() runs the tests when the global // set-up is successful. Check(RunAllTests(env, NO_FAILURE) != 0, "RUN_ALL_TESTS() should return non-zero, as the global tear-down " "should generate a failure."); Check(test_was_run, "The tests should run, as the global set-up should generate no " "failure"); Check(env->tear_down_was_run(), "The global tear-down should run, as the global set-up was run."); // Verifies that RUN_ALL_TESTS() runs the tests when the global // set-up generates no fatal failure. Check(RunAllTests(env, NON_FATAL_FAILURE) != 0, "RUN_ALL_TESTS() should return non-zero, as both the global set-up " "and the global tear-down should generate a non-fatal failure."); Check(test_was_run, "The tests should run, as the global set-up should generate no " "fatal failure."); Check(env->tear_down_was_run(), "The global tear-down should run, as the global set-up was run."); // Verifies that RUN_ALL_TESTS() runs no test when the global set-up // generates a fatal failure. Check(RunAllTests(env, FATAL_FAILURE) != 0, "RUN_ALL_TESTS() should return non-zero, as the global set-up " "should generate a fatal failure."); Check(!test_was_run, "The tests should not run, as the global set-up should generate " "a fatal failure."); Check(env->tear_down_was_run(), "The global tear-down should run, as the global set-up was run."); // Verifies that RUN_ALL_TESTS() doesn't do global set-up or // tear-down when there is no test to run. testing::GTEST_FLAG(filter) = "-*"; Check(RunAllTests(env, NO_FAILURE) == 0, "RUN_ALL_TESTS() should return zero, as there is no test to run."); Check(!env->set_up_was_run(), "The global set-up should not run, as there is no test to run."); Check(!env->tear_down_was_run(), "The global tear-down should not run, " "as the global set-up was not run."); printf("PASS\n"); return 0; }
Upload File
Create Folder