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: vladl@google.com (Vlad Losev) 31 32// This sample shows how to test common properties of multiple 33// implementations of an interface (aka interface tests) using 34// value-parameterized tests. Each test in the test case has 35// a parameter that is an interface pointer to an implementation 36// tested. 37 38// The interface and its implementations are in this header. 39#include "prime_tables.h" 40 41#include <gtest/gtest.h> 42 43#if GTEST_HAS_PARAM_TEST 44 45using ::testing::TestWithParam; 46using ::testing::Values; 47 48// As a general rule, tested objects should not be reused between tests. 49// Also, their constructors and destructors of tested objects can have 50// side effects. Thus you should create and destroy them for each test. 51// In this sample we will define a simple factory function for PrimeTable 52// objects. We will instantiate objects in test's SetUp() method and 53// delete them in TearDown() method. 54typedef PrimeTable* CreatePrimeTableFunc(); 55 56PrimeTable* CreateOnTheFlyPrimeTable() { 57 return new OnTheFlyPrimeTable(); 58} 59 60template <size_t max_precalculated> 61PrimeTable* CreatePreCalculatedPrimeTable() { 62 return new PreCalculatedPrimeTable(max_precalculated); 63} 64 65// Inside the test body, fixture constructor, SetUp(), and TearDown() 66// you can refer to the test parameter by GetParam(). 67// In this case, the test parameter is a PrimeTableFactory interface pointer 68// which we use in fixture's SetUp() to create and store an instance of 69// PrimeTable. 70class PrimeTableTest : public TestWithParam<CreatePrimeTableFunc*> { 71 public: 72 virtual ~PrimeTableTest() { delete table_; } 73 virtual void SetUp() { table_ = (*GetParam())(); } 74 virtual void TearDown() { 75 delete table_; 76 table_ = NULL; 77 } 78 79 protected: 80 PrimeTable* table_; 81}; 82 83TEST_P(PrimeTableTest, ReturnsFalseForNonPrimes) { 84 EXPECT_FALSE(table_->IsPrime(-5)); 85 EXPECT_FALSE(table_->IsPrime(0)); 86 EXPECT_FALSE(table_->IsPrime(1)); 87 EXPECT_FALSE(table_->IsPrime(4)); 88 EXPECT_FALSE(table_->IsPrime(6)); 89 EXPECT_FALSE(table_->IsPrime(100)); 90} 91 92TEST_P(PrimeTableTest, ReturnsTrueForPrimes) { 93 EXPECT_TRUE(table_->IsPrime(2)); 94 EXPECT_TRUE(table_->IsPrime(3)); 95 EXPECT_TRUE(table_->IsPrime(5)); 96 EXPECT_TRUE(table_->IsPrime(7)); 97 EXPECT_TRUE(table_->IsPrime(11)); 98 EXPECT_TRUE(table_->IsPrime(131)); 99} 100 101TEST_P(PrimeTableTest, CanGetNextPrime) { 102 EXPECT_EQ(2, table_->GetNextPrime(0)); 103 EXPECT_EQ(3, table_->GetNextPrime(2)); 104 EXPECT_EQ(5, table_->GetNextPrime(3)); 105 EXPECT_EQ(7, table_->GetNextPrime(5)); 106 EXPECT_EQ(11, table_->GetNextPrime(7)); 107 EXPECT_EQ(131, table_->GetNextPrime(128)); 108} 109 110// In order to run value-parameterized tests, you need to instantiate them, 111// or bind them to a list of values which will be used as test parameters. 112// You can instantiate them in a different translation module, or even 113// instantiate them several times. 114// 115// Here, we instantiate our tests with a list of two PrimeTable object 116// factory functions: 117INSTANTIATE_TEST_CASE_P( 118 OnTheFlyAndPreCalculated, 119 PrimeTableTest, 120 Values(&CreateOnTheFlyPrimeTable, &CreatePreCalculatedPrimeTable<1000>)); 121 122#else 123 124// Google Test may not support value-parameterized tests with some 125// compilers. If we use conditional compilation to compile out all 126// code referring to the gtest_main library, MSVC linker will not link 127// that library at all and consequently complain about missing entry 128// point defined in that library (fatal error LNK1561: entry point 129// must be defined). This dummy test keeps gtest_main linked in. 130TEST(DummyTest, ValueParameterizedTestsAreNotSupportedOnThisPlatform) {} 131 132#endif // GTEST_HAS_PARAM_TEST 133