| // Copyright 2021 Google LLC |
| // |
| // 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 "third_party/distributed_point_functions/prng/basic_rng.h" |
| |
| #include "testing/base/public/gmock.h" |
| #include "testing/base/public/gunit.h" |
| #include "third_party/absl/numeric/int128.h" |
| #include "third_party/distributed_point_functions/dpf/internal/status_matchers.h" |
| |
| namespace distributed_point_functions { |
| namespace { |
| |
| using ::testing::Test; |
| |
| const absl::string_view kSampleSeed = absl::string_view(); |
| |
| class BasicRngTest : public Test {}; |
| |
| TEST_F(BasicRngTest, Test8BitRand) { |
| DPF_ASSERT_OK_AND_ASSIGN(auto rng, BasicRng::Create(kSampleSeed)); |
| |
| // Two random 8 bit strings have 1/256 probability of being equal. Instead, |
| // we check that 8 consecutively generated strings are not all equal. |
| bool equal = true; |
| DPF_ASSERT_OK_AND_ASSIGN(uint8_t prev, rng->Rand8()); |
| for (int i = 0; i < 8; ++i) { |
| DPF_ASSERT_OK_AND_ASSIGN(uint8_t next, rng->Rand8()); |
| if (next != prev) { |
| equal = false; |
| } |
| prev = next; |
| } |
| EXPECT_FALSE(equal); |
| } |
| |
| TEST_F(BasicRngTest, Test64BitRand) { |
| DPF_ASSERT_OK_AND_ASSIGN(auto rng, BasicRng::Create(kSampleSeed)); |
| DPF_ASSERT_OK_AND_ASSIGN(uint64_t r1, rng->Rand64()); |
| DPF_ASSERT_OK_AND_ASSIGN(uint64_t r2, rng->Rand64()); |
| EXPECT_NE(r1, r2); |
| } |
| |
| TEST_F(BasicRngTest, Test128BitRand) { |
| DPF_ASSERT_OK_AND_ASSIGN(auto rng, BasicRng::Create(kSampleSeed)); |
| DPF_ASSERT_OK_AND_ASSIGN(absl::uint128 r1, rng->Rand128()); |
| DPF_ASSERT_OK_AND_ASSIGN(absl::uint128 r2, rng->Rand128()); |
| EXPECT_NE(r1, r2); |
| } |
| |
| } // namespace |
| } // namespace distributed_point_functions |