// Copyright 2021 gRPC authors. // // Licensed under the Apache License, Version 2.0 (the "License"); // you may not use this file except in compliance with the License. // You may obtain a copy of the License at // // http://www.apache.org/licenses/LICENSE-2.0 // // Unless required by applicable law or agreed to in writing, software // distributed under the License is distributed on an "AS IS" BASIS, // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. // See the License for the specific language governing permissions and // limitations under the License. #include "src/core/lib/gprpp/bitset.h" #include #include namespace grpc_core { namespace testing { // Stand in type to make the size to test a type template struct Size { static constexpr size_t kBits = K; }; using TestSizes = ::testing::Types< // All sizes up to 17 bits Size<1>, Size<2>, Size<3>, Size<4>, Size<5>, Size<6>, Size<7>, Size<8>, Size<9>, Size<10>, Size<11>, Size<12>, Size<13>, Size<14>, Size<15>, Size<16>, Size<17>, // Values around 32 bits Size<24>, Size<25>, Size<26>, Size<27>, Size<28>, Size<29>, Size<30>, Size<31>, Size<32>, Size<33>, // Values around 48 bits Size<47>, Size<48>, Size<49>, // Values around 64 bits Size<62>, Size<63>, Size<64>, Size<65>, Size<66>, // Values around 96 bits Size<95>, Size<96>, Size<97>, // Silly numbers of bits Size<1024>, Size<4000>, Size<4321> >; template struct BitSetTest : public ::testing::Test {}; TYPED_TEST_SUITE(BitSetTest, TestSizes); TYPED_TEST(BitSetTest, NoneAtInit) { BitSet b; EXPECT_TRUE(b.none()); } TYPED_TEST(BitSetTest, OneBit) { constexpr size_t kBits = TypeParam::kBits; for (size_t i = 0; i < kBits; i++) { BitSet b; b.set(i); EXPECT_FALSE(b.none()); for (size_t j = 0; j < kBits; j++) { EXPECT_EQ(b.is_set(j), i == j); } } } TYPED_TEST(BitSetTest, AllSet) { constexpr size_t kBits = TypeParam::kBits; BitSet b; for (size_t i = 0; i < kBits; i++) { EXPECT_FALSE(b.all()); b.set(i); } EXPECT_TRUE(b.all()); } TYPED_TEST(BitSetTest, Count) { constexpr size_t kBits = TypeParam::kBits; BitSet b; std::set bits_set; std::random_device rd; std::uniform_int_distribution dist(0, kBits - 1); for (size_t i = 0; i < 4 * kBits; i++) { size_t bit = dist(rd); bits_set.insert(bit); b.set(bit); EXPECT_EQ(b.count(), bits_set.size()); } } TEST(ToIntTest, ToInt) { auto make_bitset = [](bool b0, bool b1, bool b2) { BitSet<3> b; b.set(0, b0); b.set(1, b1); b.set(2, b2); return b; }; EXPECT_EQ(make_bitset(false, false, false).ToInt(), 0); EXPECT_EQ(make_bitset(true, false, false).ToInt(), 1); EXPECT_EQ(make_bitset(false, true, false).ToInt(), 2); EXPECT_EQ(make_bitset(true, true, false).ToInt(), 3); EXPECT_EQ(make_bitset(false, false, true).ToInt(), 4); EXPECT_EQ(make_bitset(true, false, true).ToInt(), 5); EXPECT_EQ(make_bitset(false, true, true).ToInt(), 6); EXPECT_EQ(make_bitset(true, true, true).ToInt(), 7); } TEST(EmptyBitSet, Empty) { BitSet<0> b; EXPECT_TRUE(b.all()); EXPECT_TRUE(b.none()); EXPECT_EQ(b.count(), 0); } } // namespace testing } // namespace grpc_core int main(int argc, char** argv) { ::testing::InitGoogleTest(&argc, argv); return RUN_ALL_TESTS(); }