OLD | NEW |
1 /* | 1 /* |
2 * Copyright 2004 The WebRTC Project Authors. All rights reserved. | 2 * Copyright 2004 The WebRTC Project Authors. All rights reserved. |
3 * | 3 * |
4 * Use of this source code is governed by a BSD-style license | 4 * Use of this source code is governed by a BSD-style license |
5 * that can be found in the LICENSE file in the root of the source | 5 * that can be found in the LICENSE file in the root of the source |
6 * tree. An additional intellectual property rights grant can be found | 6 * tree. An additional intellectual property rights grant can be found |
7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
9 */ | 9 */ |
10 | 10 |
(...skipping 25 matching lines...) Expand all Loading... |
36 | 36 |
37 TEST_F(RandomTest, TestCreateRandomString) { | 37 TEST_F(RandomTest, TestCreateRandomString) { |
38 std::string random = CreateRandomString(256); | 38 std::string random = CreateRandomString(256); |
39 EXPECT_EQ(256U, random.size()); | 39 EXPECT_EQ(256U, random.size()); |
40 std::string random2; | 40 std::string random2; |
41 EXPECT_TRUE(CreateRandomString(256, &random2)); | 41 EXPECT_TRUE(CreateRandomString(256, &random2)); |
42 EXPECT_NE(random, random2); | 42 EXPECT_NE(random, random2); |
43 EXPECT_EQ(256U, random2.size()); | 43 EXPECT_EQ(256U, random2.size()); |
44 } | 44 } |
45 | 45 |
| 46 TEST_F(RandomTest, TestCreateRandomStringEvenlyDivideTable) { |
| 47 static std::string kUnbiasedTable("01234567"); |
| 48 std::string random; |
| 49 EXPECT_TRUE(CreateRandomString(256, kUnbiasedTable, &random)); |
| 50 EXPECT_EQ(256U, random.size()); |
| 51 |
| 52 static std::string kBiasedTable("0123456789"); |
| 53 EXPECT_FALSE(CreateRandomString(256, kBiasedTable, &random)); |
| 54 EXPECT_EQ(0U, random.size()); |
| 55 } |
| 56 |
46 TEST_F(RandomTest, TestCreateRandomUuid) { | 57 TEST_F(RandomTest, TestCreateRandomUuid) { |
47 std::string random = CreateRandomUuid(); | 58 std::string random = CreateRandomUuid(); |
48 EXPECT_EQ(36U, random.size()); | 59 EXPECT_EQ(36U, random.size()); |
49 } | 60 } |
50 | 61 |
51 TEST_F(RandomTest, TestCreateRandomForTest) { | 62 TEST_F(RandomTest, TestCreateRandomForTest) { |
52 // Make sure we get the output we expect. | 63 // Make sure we get the output we expect. |
53 SetRandomTestMode(true); | 64 SetRandomTestMode(true); |
54 EXPECT_EQ(2154761789U, CreateRandomId()); | 65 EXPECT_EQ(2154761789U, CreateRandomId()); |
55 EXPECT_EQ("h0ISP4S5SJKH/9EY", CreateRandomString(16)); | 66 EXPECT_EQ("h0ISP4S5SJKH/9EY", CreateRandomString(16)); |
56 EXPECT_EQ("41706e92-cdd3-46d9-a22d-8ff1737ffb11", CreateRandomUuid()); | 67 EXPECT_EQ("41706e92-cdd3-46d9-a22d-8ff1737ffb11", CreateRandomUuid()); |
57 | 68 |
58 // Reset and make sure we get the same output. | 69 // Reset and make sure we get the same output. |
59 SetRandomTestMode(true); | 70 SetRandomTestMode(true); |
60 EXPECT_EQ(2154761789U, CreateRandomId()); | 71 EXPECT_EQ(2154761789U, CreateRandomId()); |
61 EXPECT_EQ("h0ISP4S5SJKH/9EY", CreateRandomString(16)); | 72 EXPECT_EQ("h0ISP4S5SJKH/9EY", CreateRandomString(16)); |
62 EXPECT_EQ("41706e92-cdd3-46d9-a22d-8ff1737ffb11", CreateRandomUuid()); | 73 EXPECT_EQ("41706e92-cdd3-46d9-a22d-8ff1737ffb11", CreateRandomUuid()); |
63 | 74 |
64 // Test different character sets. | 75 // Test different character sets. |
65 SetRandomTestMode(true); | 76 SetRandomTestMode(true); |
66 std::string str; | 77 std::string str; |
67 EXPECT_TRUE(CreateRandomString(16, "a", &str)); | 78 EXPECT_TRUE(CreateRandomString(16, "a", &str)); |
68 EXPECT_EQ("aaaaaaaaaaaaaaaa", str); | 79 EXPECT_EQ("aaaaaaaaaaaaaaaa", str); |
69 EXPECT_TRUE(CreateRandomString(16, "abc", &str)); | 80 EXPECT_TRUE(CreateRandomString(16, "abcd", &str)); |
70 EXPECT_EQ("acbccaaaabbaacbb", str); | 81 EXPECT_EQ("dbaaabdaccbcabbd", str); |
71 | 82 |
72 // Turn off test mode for other tests. | 83 // Turn off test mode for other tests. |
73 SetRandomTestMode(false); | 84 SetRandomTestMode(false); |
74 } | 85 } |
75 | 86 |
76 } // namespace rtc | 87 } // namespace rtc |
OLD | NEW |