| // | 
 | // Copyright (C) 2014 The Android Open Source Project | 
 | // | 
 | // 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 "update_engine/update_manager/prng.h" | 
 |  | 
 | #include <vector> | 
 |  | 
 | #include <gtest/gtest.h> | 
 |  | 
 | using std::vector; | 
 |  | 
 | namespace chromeos_update_manager { | 
 |  | 
 | TEST(UmPRNGTest, ShouldBeDeterministic) { | 
 |   PRNG a(42); | 
 |   PRNG b(42); | 
 |  | 
 |   for (int i = 0; i < 1000; ++i) { | 
 |     EXPECT_EQ(a.Rand(), b.Rand()) << "Iteration i=" << i; | 
 |   } | 
 | } | 
 |  | 
 | TEST(UmPRNGTest, SeedChangesGeneratedSequence) { | 
 |   PRNG a(42); | 
 |   PRNG b(5); | 
 |  | 
 |   vector<uint32_t> values_a; | 
 |   vector<uint32_t> values_b; | 
 |  | 
 |   for (int i = 0; i < 100; ++i) { | 
 |     values_a.push_back(a.Rand()); | 
 |     values_b.push_back(b.Rand()); | 
 |   } | 
 |   EXPECT_NE(values_a, values_b); | 
 | } | 
 |  | 
 | TEST(UmPRNGTest, IsNotConstant) { | 
 |   PRNG prng(5); | 
 |  | 
 |   uint32_t initial_value = prng.Rand(); | 
 |   bool prng_is_constant = true; | 
 |   for (int i = 0; i < 100; ++i) { | 
 |     if (prng.Rand() != initial_value) { | 
 |       prng_is_constant = false; | 
 |       break; | 
 |     } | 
 |   } | 
 |   EXPECT_FALSE(prng_is_constant) << "After 100 iterations."; | 
 | } | 
 |  | 
 | TEST(UmPRNGTest, RandCoversRange) { | 
 |   PRNG a(42); | 
 |   int hits[11] = {0}; | 
 |  | 
 |   for (int i = 0; i < 1000; i++) { | 
 |     int r = a.RandMinMax(0, 10); | 
 |     ASSERT_LE(0, r); | 
 |     ASSERT_GE(10, r); | 
 |     hits[r]++; | 
 |   } | 
 |  | 
 |   for (auto& hit : hits) | 
 |     EXPECT_LT(0, hit); | 
 | } | 
 |  | 
 | }  // namespace chromeos_update_manager |