blob: 1a04651ca1130245eda730eefa1c1d47f6388e84 [file] [log] [blame]
Garrick Evans0dbd4182019-03-07 08:38:38 +09001// Copyright 2019 The Chromium OS Authors. All rights reserved.
2// Use of this source code is governed by a BSD-style license that can be
3// found in the LICENSE file.
4
Garrick Evans3388a032020-03-24 11:25:55 +09005#include "patchpanel/address_manager.h"
Garrick Evans0dbd4182019-03-07 08:38:38 +09006
7#include <map>
8#include <utility>
9#include <vector>
10
11#include <arpa/inet.h>
12
Garrick Evans3388a032020-03-24 11:25:55 +090013#include "patchpanel/net_util.h"
Hugo Benichi2ac4d072019-05-28 14:51:23 +090014
Garrick Evans7d9a2322020-04-02 11:59:56 +090015#include <base/rand_util.h>
Garrick Evans0dbd4182019-03-07 08:38:38 +090016#include <gtest/gtest.h>
17
Garrick Evans3388a032020-03-24 11:25:55 +090018namespace patchpanel {
Garrick Evans0dbd4182019-03-07 08:38:38 +090019
Garrick Evans0dbd4182019-03-07 08:38:38 +090020TEST(AddressManager, BaseAddresses) {
21 std::map<AddressManager::Guest, size_t> addrs = {
Hugo Benichi6c63ae22019-05-29 11:19:15 +090022 {AddressManager::Guest::ARC, Ipv4Addr(100, 115, 92, 0)},
23 {AddressManager::Guest::VM_ARC, Ipv4Addr(100, 115, 92, 4)},
24 {AddressManager::Guest::ARC_NET, Ipv4Addr(100, 115, 92, 8)},
25 {AddressManager::Guest::VM_TERMINA, Ipv4Addr(100, 115, 92, 24)},
Garrick Evans1fa4e642020-03-13 11:43:41 +090026 {AddressManager::Guest::VM_PLUGIN, Ipv4Addr(100, 115, 93, 0)},
Garrick Evans43b4e2d2019-12-11 13:43:08 +090027 {AddressManager::Guest::CONTAINER, Ipv4Addr(100, 115, 92, 192)},
Hugo Benichiadf1ec52020-01-17 16:23:58 +090028 {AddressManager::Guest::MINIJAIL_NETNS, Ipv4Addr(100, 115, 92, 128)},
Garrick Evans0dbd4182019-03-07 08:38:38 +090029 };
Garrick Evans4ee5ce22020-03-18 07:05:17 +090030 AddressManager mgr;
Garrick Evans0dbd4182019-03-07 08:38:38 +090031 for (const auto a : addrs) {
32 auto subnet = mgr.AllocateIPv4Subnet(a.first);
33 ASSERT_TRUE(subnet != nullptr);
34 // The first address (offset 0) returned by Subnet is not the base address,
35 // rather it's the first usable IP address... so the base is 1 less.
Hugo Benichi6c63ae22019-05-29 11:19:15 +090036 EXPECT_EQ(a.second, htonl(ntohl(subnet->AddressAtOffset(0)) - 1));
Garrick Evans0dbd4182019-03-07 08:38:38 +090037 }
38}
39
40TEST(AddressManager, AddressesPerSubnet) {
41 std::map<AddressManager::Guest, size_t> addrs = {
42 {AddressManager::Guest::ARC, 2},
43 {AddressManager::Guest::VM_ARC, 2},
44 {AddressManager::Guest::ARC_NET, 2},
45 {AddressManager::Guest::VM_TERMINA, 2},
Garrick Evans1fa4e642020-03-13 11:43:41 +090046 {AddressManager::Guest::VM_PLUGIN, 6},
Garrick Evans43b4e2d2019-12-11 13:43:08 +090047 {AddressManager::Guest::CONTAINER, 14},
Hugo Benichiadf1ec52020-01-17 16:23:58 +090048 {AddressManager::Guest::MINIJAIL_NETNS, 2},
Garrick Evans0dbd4182019-03-07 08:38:38 +090049 };
Garrick Evans4ee5ce22020-03-18 07:05:17 +090050 AddressManager mgr;
Garrick Evans0dbd4182019-03-07 08:38:38 +090051 for (const auto a : addrs) {
52 auto subnet = mgr.AllocateIPv4Subnet(a.first);
53 ASSERT_TRUE(subnet != nullptr);
54 EXPECT_EQ(a.second, subnet->AvailableCount());
55 }
56}
57
58TEST(AddressManager, SubnetsPerPool) {
59 std::map<AddressManager::Guest, size_t> addrs = {
60 {AddressManager::Guest::ARC, 1},
61 {AddressManager::Guest::VM_ARC, 1},
62 {AddressManager::Guest::ARC_NET, 4},
63 {AddressManager::Guest::VM_TERMINA, 26},
Garrick Evans1fa4e642020-03-13 11:43:41 +090064 {AddressManager::Guest::VM_PLUGIN, 32},
Garrick Evans43b4e2d2019-12-11 13:43:08 +090065 {AddressManager::Guest::CONTAINER, 4},
Hugo Benichiadf1ec52020-01-17 16:23:58 +090066 {AddressManager::Guest::MINIJAIL_NETNS, 8},
Garrick Evans0dbd4182019-03-07 08:38:38 +090067 };
Garrick Evans4ee5ce22020-03-18 07:05:17 +090068 AddressManager mgr;
Garrick Evans0dbd4182019-03-07 08:38:38 +090069 for (const auto a : addrs) {
70 std::vector<std::unique_ptr<Subnet>> subnets;
71 for (size_t i = 0; i < a.second; ++i) {
72 auto subnet = mgr.AllocateIPv4Subnet(a.first);
73 EXPECT_TRUE(subnet != nullptr);
74 subnets.emplace_back(std::move(subnet));
75 }
76 auto subnet = mgr.AllocateIPv4Subnet(a.first);
77 EXPECT_TRUE(subnet == nullptr);
78 }
79}
80
Garrick Evans43b4e2d2019-12-11 13:43:08 +090081TEST(AddressManager, SubnetIndexing) {
Garrick Evans4ee5ce22020-03-18 07:05:17 +090082 AddressManager mgr;
Garrick Evans53a2a982020-02-05 10:53:35 +090083 EXPECT_FALSE(mgr.AllocateIPv4Subnet(AddressManager::Guest::ARC, 1));
84 EXPECT_FALSE(mgr.AllocateIPv4Subnet(AddressManager::Guest::VM_ARC, 1));
85 EXPECT_FALSE(mgr.AllocateIPv4Subnet(AddressManager::Guest::ARC_NET, 1));
86 EXPECT_FALSE(mgr.AllocateIPv4Subnet(AddressManager::Guest::VM_TERMINA, 1));
Garrick Evans1fa4e642020-03-13 11:43:41 +090087 EXPECT_TRUE(mgr.AllocateIPv4Subnet(AddressManager::Guest::VM_PLUGIN, 1));
Garrick Evans53a2a982020-02-05 10:53:35 +090088 EXPECT_FALSE(mgr.AllocateIPv4Subnet(AddressManager::Guest::CONTAINER, 1));
Hugo Benichiadf1ec52020-01-17 16:23:58 +090089 EXPECT_FALSE(
90 mgr.AllocateIPv4Subnet(AddressManager::Guest::MINIJAIL_NETNS, 1));
Garrick Evans43b4e2d2019-12-11 13:43:08 +090091}
92
Garrick Evans7d9a2322020-04-02 11:59:56 +090093TEST(AddressManager, StableMacAddresses) {
Garrick Evans20132ee2020-04-06 11:24:42 +090094 AddressManager mgr;
Garrick Evans7d9a2322020-04-02 11:59:56 +090095 EXPECT_NE(mgr.GenerateMacAddress(), mgr.GenerateMacAddress());
96 EXPECT_NE(mgr.GenerateMacAddress(kAnySubnetIndex),
97 mgr.GenerateMacAddress(kAnySubnetIndex));
98 for (int i = 0; i < 100; ++i) {
99 uint8_t index = 0;
100 while (index == 0) {
101 base::RandBytes(&index, 1);
102 }
103 EXPECT_EQ(mgr.GenerateMacAddress(index), mgr.GenerateMacAddress(index));
104 }
105}
106
Garrick Evans3388a032020-03-24 11:25:55 +0900107} // namespace patchpanel