Home | History | Annotate | Download | only in test
      1 // Copyright 2008 Google Inc.
      2 // All Rights Reserved.
      3 //
      4 // Redistribution and use in source and binary forms, with or without
      5 // modification, are permitted provided that the following conditions are
      6 // met:
      7 //
      8 //     * Redistributions of source code must retain the above copyright
      9 // notice, this list of conditions and the following disclaimer.
     10 //     * Redistributions in binary form must reproduce the above
     11 // copyright notice, this list of conditions and the following disclaimer
     12 // in the documentation and/or other materials provided with the
     13 // distribution.
     14 //     * Neither the name of Google Inc. nor the names of its
     15 // contributors may be used to endorse or promote products derived from
     16 // this software without specific prior written permission.
     17 //
     18 // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS
     19 // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT
     20 // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR
     21 // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT
     22 // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
     23 // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
     24 // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
     25 // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
     26 // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
     27 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
     28 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     29 //
     30 // Author: mheule (at) google.com (Markus Heule)
     31 //
     32 
     33 #include "gtest/gtest-test-part.h"
     34 
     35 #include "gtest/gtest.h"
     36 
     37 using testing::Message;
     38 using testing::Test;
     39 using testing::TestPartResult;
     40 using testing::TestPartResultArray;
     41 
     42 namespace {
     43 
     44 // Tests the TestPartResult class.
     45 
     46 // The test fixture for testing TestPartResult.
     47 class TestPartResultTest : public Test {
     48  protected:
     49   TestPartResultTest()
     50       : r1_(TestPartResult::kSuccess, "foo/bar.cc", 10, "Success!"),
     51         r2_(TestPartResult::kNonFatalFailure, "foo/bar.cc", -1, "Failure!"),
     52         r3_(TestPartResult::kFatalFailure, NULL, -1, "Failure!") {}
     53 
     54   TestPartResult r1_, r2_, r3_;
     55 };
     56 
     57 
     58 TEST_F(TestPartResultTest, ConstructorWorks) {
     59   Message message;
     60   message << "something is terribly wrong";
     61   message << static_cast<const char*>(testing::internal::kStackTraceMarker);
     62   message << "some unimportant stack trace";
     63 
     64   const TestPartResult result(TestPartResult::kNonFatalFailure,
     65                               "some_file.cc",
     66                               42,
     67                               message.GetString().c_str());
     68 
     69   EXPECT_EQ(TestPartResult::kNonFatalFailure, result.type());
     70   EXPECT_STREQ("some_file.cc", result.file_name());
     71   EXPECT_EQ(42, result.line_number());
     72   EXPECT_STREQ(message.GetString().c_str(), result.message());
     73   EXPECT_STREQ("something is terribly wrong", result.summary());
     74 }
     75 
     76 TEST_F(TestPartResultTest, ResultAccessorsWork) {
     77   const TestPartResult success(TestPartResult::kSuccess,
     78                                "file.cc",
     79                                42,
     80                                "message");
     81   EXPECT_TRUE(success.passed());
     82   EXPECT_FALSE(success.failed());
     83   EXPECT_FALSE(success.nonfatally_failed());
     84   EXPECT_FALSE(success.fatally_failed());
     85 
     86   const TestPartResult nonfatal_failure(TestPartResult::kNonFatalFailure,
     87                                         "file.cc",
     88                                         42,
     89                                         "message");
     90   EXPECT_FALSE(nonfatal_failure.passed());
     91   EXPECT_TRUE(nonfatal_failure.failed());
     92   EXPECT_TRUE(nonfatal_failure.nonfatally_failed());
     93   EXPECT_FALSE(nonfatal_failure.fatally_failed());
     94 
     95   const TestPartResult fatal_failure(TestPartResult::kFatalFailure,
     96                                      "file.cc",
     97                                      42,
     98                                      "message");
     99   EXPECT_FALSE(fatal_failure.passed());
    100   EXPECT_TRUE(fatal_failure.failed());
    101   EXPECT_FALSE(fatal_failure.nonfatally_failed());
    102   EXPECT_TRUE(fatal_failure.fatally_failed());
    103 }
    104 
    105 // Tests TestPartResult::type().
    106 TEST_F(TestPartResultTest, type) {
    107   EXPECT_EQ(TestPartResult::kSuccess, r1_.type());
    108   EXPECT_EQ(TestPartResult::kNonFatalFailure, r2_.type());
    109   EXPECT_EQ(TestPartResult::kFatalFailure, r3_.type());
    110 }
    111 
    112 // Tests TestPartResult::file_name().
    113 TEST_F(TestPartResultTest, file_name) {
    114   EXPECT_STREQ("foo/bar.cc", r1_.file_name());
    115   EXPECT_STREQ(NULL, r3_.file_name());
    116 }
    117 
    118 // Tests TestPartResult::line_number().
    119 TEST_F(TestPartResultTest, line_number) {
    120   EXPECT_EQ(10, r1_.line_number());
    121   EXPECT_EQ(-1, r2_.line_number());
    122 }
    123 
    124 // Tests TestPartResult::message().
    125 TEST_F(TestPartResultTest, message) {
    126   EXPECT_STREQ("Success!", r1_.message());
    127 }
    128 
    129 // Tests TestPartResult::passed().
    130 TEST_F(TestPartResultTest, Passed) {
    131   EXPECT_TRUE(r1_.passed());
    132   EXPECT_FALSE(r2_.passed());
    133   EXPECT_FALSE(r3_.passed());
    134 }
    135 
    136 // Tests TestPartResult::failed().
    137 TEST_F(TestPartResultTest, Failed) {
    138   EXPECT_FALSE(r1_.failed());
    139   EXPECT_TRUE(r2_.failed());
    140   EXPECT_TRUE(r3_.failed());
    141 }
    142 
    143 // Tests TestPartResult::fatally_failed().
    144 TEST_F(TestPartResultTest, FatallyFailed) {
    145   EXPECT_FALSE(r1_.fatally_failed());
    146   EXPECT_FALSE(r2_.fatally_failed());
    147   EXPECT_TRUE(r3_.fatally_failed());
    148 }
    149 
    150 // Tests TestPartResult::nonfatally_failed().
    151 TEST_F(TestPartResultTest, NonfatallyFailed) {
    152   EXPECT_FALSE(r1_.nonfatally_failed());
    153   EXPECT_TRUE(r2_.nonfatally_failed());
    154   EXPECT_FALSE(r3_.nonfatally_failed());
    155 }
    156 
    157 // Tests the TestPartResultArray class.
    158 
    159 class TestPartResultArrayTest : public Test {
    160  protected:
    161   TestPartResultArrayTest()
    162       : r1_(TestPartResult::kNonFatalFailure, "foo/bar.cc", -1, "Failure 1"),
    163         r2_(TestPartResult::kFatalFailure, "foo/bar.cc", -1, "Failure 2") {}
    164 
    165   const TestPartResult r1_, r2_;
    166 };
    167 
    168 // Tests that TestPartResultArray initially has size 0.
    169 TEST_F(TestPartResultArrayTest, InitialSizeIsZero) {
    170   TestPartResultArray results;
    171   EXPECT_EQ(0, results.size());
    172 }
    173 
    174 // Tests that TestPartResultArray contains the given TestPartResult
    175 // after one Append() operation.
    176 TEST_F(TestPartResultArrayTest, ContainsGivenResultAfterAppend) {
    177   TestPartResultArray results;
    178   results.Append(r1_);
    179   EXPECT_EQ(1, results.size());
    180   EXPECT_STREQ("Failure 1", results.GetTestPartResult(0).message());
    181 }
    182 
    183 // Tests that TestPartResultArray contains the given TestPartResults
    184 // after two Append() operations.
    185 TEST_F(TestPartResultArrayTest, ContainsGivenResultsAfterTwoAppends) {
    186   TestPartResultArray results;
    187   results.Append(r1_);
    188   results.Append(r2_);
    189   EXPECT_EQ(2, results.size());
    190   EXPECT_STREQ("Failure 1", results.GetTestPartResult(0).message());
    191   EXPECT_STREQ("Failure 2", results.GetTestPartResult(1).message());
    192 }
    193 
    194 typedef TestPartResultArrayTest TestPartResultArrayDeathTest;
    195 
    196 // Tests that the program dies when GetTestPartResult() is called with
    197 // an invalid index.
    198 TEST_F(TestPartResultArrayDeathTest, DiesWhenIndexIsOutOfBound) {
    199   TestPartResultArray results;
    200   results.Append(r1_);
    201 
    202   EXPECT_DEATH_IF_SUPPORTED(results.GetTestPartResult(-1), "");
    203   EXPECT_DEATH_IF_SUPPORTED(results.GetTestPartResult(1), "");
    204 }
    205 
    206 // TODO(mheule (at) google.com): Add a test for the class HasNewFatalFailureHelper.
    207 
    208 }  // namespace
    209