blob: b85587234a5701f0d20763dd0d758996e48a02c9 [file] [log] [blame]
henrike@webrtc.orgf0488722014-05-13 18:00:26 +00001/*
2 * Copyright 2004 The WebRTC Project Authors. All rights reserved.
3 *
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
6 * tree. An additional intellectual property rights grant can be found
7 * in the file PATENTS. All contributing project authors may
8 * be found in the AUTHORS file in the root of the source tree.
9 */
10
Jonas Olssona4d87372019-07-05 19:08:33 +020011#include "rtc_base/helpers.h"
12
Yves Gerey3e707812018-11-28 16:47:49 +010013#include <string.h>
Jonas Olssona4d87372019-07-05 19:08:33 +020014
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000015#include <string>
16
Mirko Bonadei92ea95e2017-09-15 06:47:31 +020017#include "rtc_base/buffer.h"
Yves Gerey3e707812018-11-28 16:47:49 +010018#include "test/gtest.h"
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000019
20namespace rtc {
21
Mirko Bonadei6a489f22019-04-09 15:11:12 +020022class RandomTest : public ::testing::Test {};
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000023
24TEST_F(RandomTest, TestCreateRandomId) {
25 CreateRandomId();
26}
27
28TEST_F(RandomTest, TestCreateRandomDouble) {
29 for (int i = 0; i < 100; ++i) {
30 double r = CreateRandomDouble();
31 EXPECT_GE(r, 0.0);
32 EXPECT_LT(r, 1.0);
33 }
34}
35
36TEST_F(RandomTest, TestCreateNonZeroRandomId) {
37 EXPECT_NE(0U, CreateRandomNonZeroId());
38}
39
40TEST_F(RandomTest, TestCreateRandomString) {
41 std::string random = CreateRandomString(256);
42 EXPECT_EQ(256U, random.size());
43 std::string random2;
44 EXPECT_TRUE(CreateRandomString(256, &random2));
45 EXPECT_NE(random, random2);
46 EXPECT_EQ(256U, random2.size());
47}
48
jbauchcb560652016-08-04 05:20:32 -070049TEST_F(RandomTest, TestCreateRandomData) {
50 static size_t kRandomDataLength = 32;
51 std::string random1;
52 std::string random2;
53 EXPECT_TRUE(CreateRandomData(kRandomDataLength, &random1));
54 EXPECT_EQ(kRandomDataLength, random1.size());
55 EXPECT_TRUE(CreateRandomData(kRandomDataLength, &random2));
56 EXPECT_EQ(kRandomDataLength, random2.size());
57 EXPECT_NE(0, memcmp(random1.data(), random2.data(), kRandomDataLength));
58}
59
jbauche3eff7c2016-08-08 17:13:33 -070060TEST_F(RandomTest, TestCreateRandomStringEvenlyDivideTable) {
61 static std::string kUnbiasedTable("01234567");
62 std::string random;
63 EXPECT_TRUE(CreateRandomString(256, kUnbiasedTable, &random));
64 EXPECT_EQ(256U, random.size());
65
66 static std::string kBiasedTable("0123456789");
67 EXPECT_FALSE(CreateRandomString(256, kBiasedTable, &random));
68 EXPECT_EQ(0U, random.size());
69}
70
deadbeeffac06552015-11-25 11:26:01 -080071TEST_F(RandomTest, TestCreateRandomUuid) {
72 std::string random = CreateRandomUuid();
73 EXPECT_EQ(36U, random.size());
74}
75
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000076TEST_F(RandomTest, TestCreateRandomForTest) {
77 // Make sure we get the output we expect.
78 SetRandomTestMode(true);
79 EXPECT_EQ(2154761789U, CreateRandomId());
80 EXPECT_EQ("h0ISP4S5SJKH/9EY", CreateRandomString(16));
deadbeeffac06552015-11-25 11:26:01 -080081 EXPECT_EQ("41706e92-cdd3-46d9-a22d-8ff1737ffb11", CreateRandomUuid());
jbauchcb560652016-08-04 05:20:32 -070082 static size_t kRandomDataLength = 32;
83 std::string random;
84 EXPECT_TRUE(CreateRandomData(kRandomDataLength, &random));
85 EXPECT_EQ(kRandomDataLength, random.size());
Yves Gerey665174f2018-06-19 15:03:05 +020086 Buffer expected(
87 "\xbd\x52\x2a\x4b\x97\x93\x2f\x1c"
jbauchcb560652016-08-04 05:20:32 -070088 "\xc4\x72\xab\xa2\x88\x68\x3e\xcc"
89 "\xa3\x8d\xaf\x13\x3b\xbc\x83\xbb"
Yves Gerey665174f2018-06-19 15:03:05 +020090 "\x16\xf1\xcf\x56\x0c\xf5\x4a\x8b",
91 kRandomDataLength);
jbauchcb560652016-08-04 05:20:32 -070092 EXPECT_EQ(0, memcmp(expected.data(), random.data(), kRandomDataLength));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +000093
94 // Reset and make sure we get the same output.
95 SetRandomTestMode(true);
96 EXPECT_EQ(2154761789U, CreateRandomId());
97 EXPECT_EQ("h0ISP4S5SJKH/9EY", CreateRandomString(16));
deadbeeffac06552015-11-25 11:26:01 -080098 EXPECT_EQ("41706e92-cdd3-46d9-a22d-8ff1737ffb11", CreateRandomUuid());
jbauchcb560652016-08-04 05:20:32 -070099 EXPECT_TRUE(CreateRandomData(kRandomDataLength, &random));
100 EXPECT_EQ(kRandomDataLength, random.size());
101 EXPECT_EQ(0, memcmp(expected.data(), random.data(), kRandomDataLength));
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000102
103 // Test different character sets.
104 SetRandomTestMode(true);
105 std::string str;
106 EXPECT_TRUE(CreateRandomString(16, "a", &str));
107 EXPECT_EQ("aaaaaaaaaaaaaaaa", str);
jbauche3eff7c2016-08-08 17:13:33 -0700108 EXPECT_TRUE(CreateRandomString(16, "abcd", &str));
109 EXPECT_EQ("dbaaabdaccbcabbd", str);
henrike@webrtc.orgf0488722014-05-13 18:00:26 +0000110
111 // Turn off test mode for other tests.
112 SetRandomTestMode(false);
113}
114
115} // namespace rtc