| Alex Deymo | aea4c1c | 2015-08-19 20:24:43 -0700 | [diff] [blame] | 1 | // | 
|  | 2 | // Copyright (C) 2014 The Android Open Source Project | 
|  | 3 | // | 
|  | 4 | // Licensed under the Apache License, Version 2.0 (the "License"); | 
|  | 5 | // you may not use this file except in compliance with the License. | 
|  | 6 | // You may obtain a copy of the License at | 
|  | 7 | // | 
|  | 8 | //      http://www.apache.org/licenses/LICENSE-2.0 | 
|  | 9 | // | 
|  | 10 | // Unless required by applicable law or agreed to in writing, software | 
|  | 11 | // distributed under the License is distributed on an "AS IS" BASIS, | 
|  | 12 | // WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. | 
|  | 13 | // See the License for the specific language governing permissions and | 
|  | 14 | // limitations under the License. | 
|  | 15 | // | 
| Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 16 |  | 
| Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 17 | #include "update_engine/update_manager/prng.h" | 
| Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 18 |  | 
|  | 19 | #include <vector> | 
|  | 20 |  | 
|  | 21 | #include <gtest/gtest.h> | 
|  | 22 |  | 
|  | 23 | using std::vector; | 
|  | 24 |  | 
| Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 25 | namespace chromeos_update_manager { | 
| Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 26 |  | 
| Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 27 | TEST(UmPRNGTest, ShouldBeDeterministic) { | 
| Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 28 | PRNG a(42); | 
|  | 29 | PRNG b(42); | 
|  | 30 |  | 
|  | 31 | for (int i = 0; i < 1000; ++i) { | 
| Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 32 | EXPECT_EQ(a.Rand(), b.Rand()) << "Iteration i=" << i; | 
| Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 33 | } | 
|  | 34 | } | 
|  | 35 |  | 
| Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 36 | TEST(UmPRNGTest, SeedChangesGeneratedSequence) { | 
| Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 37 | PRNG a(42); | 
|  | 38 | PRNG b(5); | 
|  | 39 |  | 
| Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 40 | vector<uint32_t> values_a; | 
|  | 41 | vector<uint32_t> values_b; | 
| Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 42 |  | 
|  | 43 | for (int i = 0; i < 100; ++i) { | 
| Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 44 | values_a.push_back(a.Rand()); | 
|  | 45 | values_b.push_back(b.Rand()); | 
| Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 46 | } | 
|  | 47 | EXPECT_NE(values_a, values_b); | 
|  | 48 | } | 
|  | 49 |  | 
| Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 50 | TEST(UmPRNGTest, IsNotConstant) { | 
| Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 51 | PRNG prng(5); | 
|  | 52 |  | 
| Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 53 | uint32_t initial_value = prng.Rand(); | 
| Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 54 | bool prng_is_constant = true; | 
|  | 55 | for (int i = 0; i < 100; ++i) { | 
| Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 56 | if (prng.Rand() != initial_value) { | 
| Alex Deymo | edfa1d4 | 2014-04-28 16:53:51 -0700 | [diff] [blame] | 57 | prng_is_constant = false; | 
|  | 58 | break; | 
|  | 59 | } | 
|  | 60 | } | 
|  | 61 | EXPECT_FALSE(prng_is_constant) << "After 100 iterations."; | 
|  | 62 | } | 
|  | 63 |  | 
| Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 64 | TEST(UmPRNGTest, RandCoversRange) { | 
| Gilad Arnold | e121881 | 2014-05-07 12:21:36 -0700 | [diff] [blame] | 65 | PRNG a(42); | 
|  | 66 | int hits[11] = { 0 }; | 
|  | 67 |  | 
|  | 68 | for (int i = 0; i < 1000; i++) { | 
|  | 69 | int r = a.RandMinMax(0, 10); | 
|  | 70 | ASSERT_LE(0, r); | 
|  | 71 | ASSERT_GE(10, r); | 
|  | 72 | hits[r]++; | 
|  | 73 | } | 
|  | 74 |  | 
|  | 75 | for (auto& hit : hits) | 
|  | 76 | EXPECT_LT(0, hit); | 
|  | 77 | } | 
|  | 78 |  | 
| Alex Deymo | 63784a5 | 2014-05-28 10:46:14 -0700 | [diff] [blame] | 79 | }  // namespace chromeos_update_manager |