blob: 33ec6ef75ba60224e84a0065c4a6bb57a23421c7 [file] [log] [blame]
Austin Schuh4385b142021-03-14 21:31:13 -07001#include "aos/uuid.h"
Austin Schuh64fab802020-09-09 22:47:47 -07002
3#include "glog/logging.h"
4#include "gtest/gtest.h"
5
6namespace aos {
7namespace testing {
8
9// Tests that random UUIDs are actually random, and we can convert them to a
10// string. Not very exhaustive, but it is a good smoke test.
11TEST(UUIDTest, GetOne) {
Austin Schuh5e2bfb82021-03-13 22:46:55 -080012 LOG(INFO) << UUID::Random();
13
14 UUID r = UUID::Random();
15
16 std::stringstream ss;
17 ss << r;
18
19 UUID r2 = UUID::FromString(ss.str());
20 EXPECT_EQ(r2, r);
Austin Schuh64fab802020-09-09 22:47:47 -070021
22 EXPECT_NE(UUID::Random(), UUID::Random());
Brian Silverman1f345222020-09-24 21:14:48 -070023 EXPECT_NE(UUID::Random(), UUID::Zero());
24 EXPECT_EQ(UUID::Zero(), UUID::Zero());
Austin Schuh64fab802020-09-09 22:47:47 -070025}
26
Austin Schuh5e2bfb82021-03-13 22:46:55 -080027// Tests that converting to and from various formats produces the same UUID.
28TEST(UUIDTest, FromString) {
29 std::string_view str = "4b88ab00-556a-455b-a395-17d1a0c6f906";
30 std::array<uint8_t, UUID::kDataSize> data = {
31 0x4b, 0x88, 0xab, 0x00, 0x55, 0x6a, 0x45, 0x5b,
32 0xa3, 0x95, 0x17, 0xd1, 0xa0, 0xc6, 0xf9, 0x06};
33
34 const UUID u = UUID::FromString(str);
35
36 EXPECT_EQ(u.span(), absl::Span<uint8_t>(data.data(), data.size()));
37 EXPECT_EQ(u.ToString(), str);
38
39 flatbuffers::FlatBufferBuilder fbb;
40 flatbuffers::Offset<flatbuffers::Vector<uint8_t>> data_offset =
41 fbb.CreateVector(data.data(), data.size());
42
43 const flatbuffers::Vector<uint8_t> *data_vector =
44 flatbuffers::GetTemporaryPointer(fbb, data_offset);
45
46 const UUID u2 = UUID::FromVector(data_vector);
47
48 EXPECT_EQ(u, u2);
49}
50
Austin Schuh64fab802020-09-09 22:47:47 -070051} // namespace testing
52} // namespace aos