diff options
Diffstat (limited to 'third_party/abseil-cpp/absl/random/internal/explicit_seed_seq_test.cc')
-rw-r--r-- | third_party/abseil-cpp/absl/random/internal/explicit_seed_seq_test.cc | 49 |
1 files changed, 9 insertions, 40 deletions
diff --git a/third_party/abseil-cpp/absl/random/internal/explicit_seed_seq_test.cc b/third_party/abseil-cpp/absl/random/internal/explicit_seed_seq_test.cc index f867f610d0..a55ad73948 100644 --- a/third_party/abseil-cpp/absl/random/internal/explicit_seed_seq_test.cc +++ b/third_party/abseil-cpp/absl/random/internal/explicit_seed_seq_test.cc @@ -24,8 +24,6 @@ namespace { -using ::absl::random_internal::ExplicitSeedSeq; - template <typename Sseq> bool ConformsToInterface() { // Check that the SeedSequence can be default-constructed. @@ -66,14 +64,14 @@ TEST(SeedSequences, CheckInterfaces) { EXPECT_TRUE(ConformsToInterface<std::seed_seq>()); // Abseil classes - EXPECT_TRUE(ConformsToInterface<ExplicitSeedSeq>()); + EXPECT_TRUE(ConformsToInterface<absl::random_internal::ExplicitSeedSeq>()); } TEST(ExplicitSeedSeq, DefaultConstructorGeneratesZeros) { const size_t kNumBlocks = 128; uint32_t outputs[kNumBlocks]; - ExplicitSeedSeq seq; + absl::random_internal::ExplicitSeedSeq seq; seq.generate(outputs, &outputs[kNumBlocks]); for (uint32_t& seed : outputs) { @@ -89,7 +87,8 @@ TEST(ExplicitSeeqSeq, SeedMaterialIsForwardedIdentically) { for (uint32_t& seed : seed_material) { seed = urandom(); } - ExplicitSeedSeq seq(seed_material, &seed_material[kNumBlocks]); + absl::random_internal::ExplicitSeedSeq seq(seed_material, + &seed_material[kNumBlocks]); // Check that output is same as seed-material provided to constructor. { @@ -134,10 +133,11 @@ TEST(ExplicitSeedSeq, CopyAndMoveConstructors) { for (uint32_t& entry : entropy) { entry = urandom(); } - ExplicitSeedSeq seq_from_entropy(std::begin(entropy), std::end(entropy)); + absl::random_internal::ExplicitSeedSeq seq_from_entropy(std::begin(entropy), + std::end(entropy)); // Copy constructor. { - ExplicitSeedSeq seq_copy(seq_from_entropy); + absl::random_internal::ExplicitSeedSeq seq_copy(seq_from_entropy); EXPECT_EQ(seq_copy.size(), seq_from_entropy.size()); std::vector<uint32_t> seeds_1; @@ -155,7 +155,8 @@ TEST(ExplicitSeedSeq, CopyAndMoveConstructors) { for (uint32_t& entry : entropy) { entry = urandom(); } - ExplicitSeedSeq another_seq(std::begin(entropy), std::end(entropy)); + absl::random_internal::ExplicitSeedSeq another_seq(std::begin(entropy), + std::end(entropy)); std::vector<uint32_t> seeds_1; seeds_1.resize(1000, 0); @@ -201,35 +202,3 @@ TEST(ExplicitSeedSeq, CopyAndMoveConstructors) { EXPECT_THAT(seeds_1, Each(Eq(0))); } } - -TEST(ExplicitSeedSeq, StdURBGGoldenTests) { - // Verify that for std::- URBG instances the results are stable across - // platforms (these should have deterministic output). - { - ExplicitSeedSeq seed_sequence{12, 34, 56}; - std::minstd_rand rng(seed_sequence); - - std::minstd_rand::result_type values[4] = {rng(), rng(), rng(), rng()}; - EXPECT_THAT(values, - testing::ElementsAre(579252, 43785881, 464353103, 1501811174)); - } - - { - ExplicitSeedSeq seed_sequence{12, 34, 56}; - std::mt19937 rng(seed_sequence); - - std::mt19937::result_type values[4] = {rng(), rng(), rng(), rng()}; - EXPECT_THAT(values, testing::ElementsAre(138416803, 151130212, 33817739, - 138416803)); - } - - { - ExplicitSeedSeq seed_sequence{12, 34, 56}; - std::mt19937_64 rng(seed_sequence); - - std::mt19937_64::result_type values[4] = {rng(), rng(), rng(), rng()}; - EXPECT_THAT(values, - testing::ElementsAre(19738651785169348, 1464811352364190456, - 18054685302720800, 19738651785169348)); - } -} |