1*3f982cf4SFabien Sanglard // Copyright 2020 The Chromium Authors. All rights reserved.
2*3f982cf4SFabien Sanglard // Use of this source code is governed by a BSD-style license that can be
3*3f982cf4SFabien Sanglard // found in the LICENSE file.
4*3f982cf4SFabien Sanglard
5*3f982cf4SFabien Sanglard #include "util/crypto/random_bytes.h"
6*3f982cf4SFabien Sanglard
7*3f982cf4SFabien Sanglard #include <algorithm>
8*3f982cf4SFabien Sanglard #include <utility>
9*3f982cf4SFabien Sanglard
10*3f982cf4SFabien Sanglard #include "gtest/gtest.h"
11*3f982cf4SFabien Sanglard
12*3f982cf4SFabien Sanglard namespace openscreen {
13*3f982cf4SFabien Sanglard namespace {
14*3f982cf4SFabien Sanglard
15*3f982cf4SFabien Sanglard struct NonZero {
16*3f982cf4SFabien Sanglard NonZero() = default;
operator ()openscreen::__anon46f9b8ff0111::NonZero17*3f982cf4SFabien Sanglard bool operator()(int n) const { return n > 0; }
18*3f982cf4SFabien Sanglard };
19*3f982cf4SFabien Sanglard
20*3f982cf4SFabien Sanglard } // namespace
21*3f982cf4SFabien Sanglard
TEST(RandomBytesTest,CanGenerateRandomBytes)22*3f982cf4SFabien Sanglard TEST(RandomBytesTest, CanGenerateRandomBytes) {
23*3f982cf4SFabien Sanglard std::array<uint8_t, 4> bytes;
24*3f982cf4SFabien Sanglard GenerateRandomBytes(bytes.begin(), bytes.size());
25*3f982cf4SFabien Sanglard
26*3f982cf4SFabien Sanglard NonZero pred;
27*3f982cf4SFabien Sanglard ASSERT_TRUE(std::any_of(bytes.begin(), bytes.end(), pred));
28*3f982cf4SFabien Sanglard }
29*3f982cf4SFabien Sanglard
TEST(RandomBytesTest,CanGenerate16RandomBytes)30*3f982cf4SFabien Sanglard TEST(RandomBytesTest, CanGenerate16RandomBytes) {
31*3f982cf4SFabien Sanglard std::array<uint8_t, 16> bytes = GenerateRandomBytes16();
32*3f982cf4SFabien Sanglard
33*3f982cf4SFabien Sanglard NonZero pred;
34*3f982cf4SFabien Sanglard ASSERT_TRUE(std::any_of(bytes.begin(), bytes.end(), pred));
35*3f982cf4SFabien Sanglard }
36*3f982cf4SFabien Sanglard
TEST(RandomBytesTest,KeysAreNotIdentical)37*3f982cf4SFabien Sanglard TEST(RandomBytesTest, KeysAreNotIdentical) {
38*3f982cf4SFabien Sanglard constexpr int kNumKeys = 100;
39*3f982cf4SFabien Sanglard constexpr int kKeyLength = 100;
40*3f982cf4SFabien Sanglard std::array<std::array<uint8_t, kKeyLength>, kNumKeys> keys;
41*3f982cf4SFabien Sanglard for (int i = 0; i < kNumKeys; ++i) {
42*3f982cf4SFabien Sanglard GenerateRandomBytes(keys[i].begin(), kKeyLength);
43*3f982cf4SFabien Sanglard }
44*3f982cf4SFabien Sanglard
45*3f982cf4SFabien Sanglard std::sort(std::begin(keys), std::end(keys));
46*3f982cf4SFabien Sanglard ASSERT_TRUE(std::adjacent_find(std::begin(keys), std::end(keys)) ==
47*3f982cf4SFabien Sanglard std::end(keys));
48*3f982cf4SFabien Sanglard }
49*3f982cf4SFabien Sanglard
50*3f982cf4SFabien Sanglard } // namespace openscreen
51