52 HybridPrimeTable(
bool force_on_the_fly,
int max_precalculated)
54 precalc_impl_(force_on_the_fly ? NULL :
56 max_precalculated_(max_precalculated) {}
57 virtual ~HybridPrimeTable() {
58 delete on_the_fly_impl_;
62 virtual bool IsPrime(
int n)
const {
63 if (precalc_impl_ != NULL && n < max_precalculated_)
64 return precalc_impl_->IsPrime(n);
66 return on_the_fly_impl_->IsPrime(n);
71 if (precalc_impl_ != NULL &&
p < max_precalculated_)
72 next_prime = precalc_impl_->GetNextPrime(
p);
74 return next_prime != -1 ? next_prime : on_the_fly_impl_->GetNextPrime(
p);
80 int max_precalculated_;
83using ::testing::TestWithParam;
85using ::testing::Values;
86using ::testing::Combine;
93class PrimeTableTest :
public TestWithParam< ::testing::tuple<bool, int> > {
95 virtual void SetUp() {
104 bool force_on_the_fly = ::testing::get<0>(GetParam());
105 int max_precalculated = ::testing::get<1>(GetParam());
106 table_ =
new HybridPrimeTable(force_on_the_fly, max_precalculated);
108 virtual void TearDown() {
112 HybridPrimeTable* table_;
115TEST_P(PrimeTableTest, ReturnsFalseForNonPrimes) {
130TEST_P(PrimeTableTest, ReturnsTrueForPrimes) {
139TEST_P(PrimeTableTest, CanGetNextPrime) {
145 EXPECT_EQ(131, table_->GetNextPrime(128));
171TEST(DummyTest, CombineIsNotSupportedOnThisPlatform) {}
virtual bool IsPrime(int n) const =0
virtual int GetNextPrime(int p) const =0
#define INSTANTIATE_TEST_CASE_P(prefix, test_case_name, generator,...)
#define TEST_P(test_case_name, test_name)
#define EXPECT_EQ(val1, val2)
#define EXPECT_TRUE(condition)
#define TEST(test_case_name, test_name)
#define EXPECT_FALSE(condition)
internal::ValueArray1< T1 > Values(T1 v1)