/* * Copyright 2018 The WebRTC project authors. All Rights Reserved. * * Use of this source code is governed by a BSD-style license * that can be found in the LICENSE file in the root of the source * tree. An additional intellectual property rights grant can be found * in the file PATENTS. All contributing project authors may * be found in the AUTHORS file in the root of the source tree. */ #include "rtc_base/unique_id_generator.h" #include #include #include "absl/algorithm/container.h" #include "api/array_view.h" #include "rtc_base/gunit.h" #include "rtc_base/helpers.h" #include "test/gmock.h" using ::testing::IsEmpty; using ::testing::Test; namespace rtc { template class UniqueIdGeneratorTest : public Test {}; using test_types = ::testing::Types, UniqueNumberGenerator, UniqueNumberGenerator, UniqueNumberGenerator, UniqueRandomIdGenerator, UniqueStringGenerator>; TYPED_TEST_SUITE(UniqueIdGeneratorTest, test_types); TYPED_TEST(UniqueIdGeneratorTest, ElementsDoNotRepeat) { typedef TypeParam Generator; const size_t num_elements = 255; Generator generator; std::vector values; for (size_t i = 0; i < num_elements; i++) { values.push_back(generator()); } EXPECT_EQ(num_elements, values.size()); // Use a set to check uniqueness. std::set set(values.begin(), values.end()); EXPECT_EQ(values.size(), set.size()) << "Returned values were not unique."; } TYPED_TEST(UniqueIdGeneratorTest, KnownElementsAreNotGenerated) { typedef TypeParam Generator; const size_t num_elements = 100; rtc::InitRandom(0); Generator generator1; std::vector known_values; for (size_t i = 0; i < num_elements; i++) { known_values.push_back(generator1()); } EXPECT_EQ(num_elements, known_values.size()); rtc::InitRandom(0); Generator generator2(known_values); std::vector values; for (size_t i = 0; i < num_elements; i++) { values.push_back(generator2()); } EXPECT_THAT(values, ::testing::SizeIs(num_elements)); absl::c_sort(values); absl::c_sort(known_values); std::vector intersection; absl::c_set_intersection(values, known_values, std::back_inserter(intersection)); EXPECT_THAT(intersection, IsEmpty()); } TYPED_TEST(UniqueIdGeneratorTest, AddedElementsAreNotGenerated) { typedef TypeParam Generator; const size_t num_elements = 100; rtc::InitRandom(0); Generator generator1; std::vector known_values; for (size_t i = 0; i < num_elements; i++) { known_values.push_back(generator1()); } EXPECT_EQ(num_elements, known_values.size()); rtc::InitRandom(0); Generator generator2; for (const typename Generator::value_type& value : known_values) { generator2.AddKnownId(value); } std::vector values; for (size_t i = 0; i < num_elements; i++) { values.push_back(generator2()); } EXPECT_THAT(values, ::testing::SizeIs(num_elements)); absl::c_sort(values); absl::c_sort(known_values); std::vector intersection; absl::c_set_intersection(values, known_values, std::back_inserter(intersection)); EXPECT_THAT(intersection, IsEmpty()); } TYPED_TEST(UniqueIdGeneratorTest, AddKnownIdOnNewIdReturnsTrue) { typedef TypeParam Generator; rtc::InitRandom(0); Generator generator1; const typename Generator::value_type id = generator1(); rtc::InitRandom(0); Generator generator2; EXPECT_TRUE(generator2.AddKnownId(id)); } TYPED_TEST(UniqueIdGeneratorTest, AddKnownIdCalledAgainForSameIdReturnsFalse) { typedef TypeParam Generator; rtc::InitRandom(0); Generator generator1; const typename Generator::value_type id = generator1(); rtc::InitRandom(0); Generator generator2; ASSERT_TRUE(generator2.AddKnownId(id)); EXPECT_FALSE(generator2.AddKnownId(id)); } TYPED_TEST(UniqueIdGeneratorTest, AddKnownIdOnIdProvidedAsKnownToCtorReturnsFalse) { typedef TypeParam Generator; rtc::InitRandom(0); Generator generator1; const typename Generator::value_type id = generator1(); std::vector known_values = {id}; rtc::InitRandom(0); Generator generator2(known_values); EXPECT_FALSE(generator2.AddKnownId(id)); } } // namespace rtc