about summary refs log tree commit diff
path: root/nixpkgs/nixos/tests/systemd-networkd-dhcpserver.nix
blob: cf0ccb74421181f1d4f037f6117c8a93f1c366c8 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
# This test predominantly tests systemd-networkd DHCP server, by
# setting up a DHCP server and client, and ensuring they are mutually
# reachable via the DHCP allocated address.
# Two DHCP servers are set up on bridge VLANs, testing to make sure that
# bridge VLAN settings are correctly applied.
#
# br0 ----untagged---v
#                    +---PVID 1+VLAN 2---[bridge]---PVID 2---eth1
# vlan2 ---VLAN 2----^
import ./make-test-python.nix ({pkgs, ...}: {
  name = "systemd-networkd-dhcpserver";
  meta = with pkgs.lib.maintainers; {
    maintainers = [ ];
  };
  nodes = {
    router = { config, pkgs, ... }: {
      virtualisation.vlans = [ 1 ];
      systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug";
      networking = {
        useNetworkd = true;
        useDHCP = false;
        firewall.enable = false;
      };
      systemd.network = {
        netdevs = {
          br0 = {
            enable = true;
            netdevConfig = {
              Name = "br0";
              Kind = "bridge";
            };
            extraConfig = ''
              [Bridge]
              VLANFiltering=yes
              DefaultPVID=none
            '';
          };
          vlan2 = {
            enable = true;
            netdevConfig = {
              Name = "vlan2";
              Kind = "vlan";
            };
            vlanConfig.Id = 2;
          };
        };
        networks = {
          # systemd-networkd will load the first network unit file
          # that matches, ordered lexiographically by filename.
          # /etc/systemd/network/{40-eth1,99-main}.network already
          # exists. This network unit must be loaded for the test,
          # however, hence why this network is named such.
          "01-eth1" = {
            name = "eth1";
            networkConfig.Bridge = "br0";
            bridgeVLANs = [
              { bridgeVLANConfig = { PVID = 2; EgressUntagged = 2; }; }
            ];
          };
          "02-br0" = {
            name = "br0";
            networkConfig = {
              DHCPServer = true;
              Address = "10.0.0.1/24";
              VLAN = ["vlan2"];
            };
            dhcpServerConfig = {
              PoolOffset = 100;
              PoolSize = 1;
            };
            bridgeVLANs = [
              { bridgeVLANConfig = { PVID = 1; EgressUntagged = 1; }; }
              { bridgeVLANConfig = { VLAN = 2; }; }
            ];
          };
          "02-vlan2" = {
            name = "vlan2";
            networkConfig = {
              DHCPServer = true;
              Address = "10.0.2.1/24";
            };
            dhcpServerConfig = {
              PoolOffset = 100;
              PoolSize = 1;
            };
          };
        };
      };
    };

    client = { config, pkgs, ... }: {
      virtualisation.vlans = [ 1 ];
      systemd.services.systemd-networkd.environment.SYSTEMD_LOG_LEVEL = "debug";
      networking = {
        useNetworkd = true;
        useDHCP = false;
        firewall.enable = false;
        interfaces.eth1.useDHCP = true;
      };
    };
  };
  testScript = { ... }: ''
    start_all()
    router.wait_for_unit("systemd-networkd-wait-online.service")
    client.wait_for_unit("systemd-networkd-wait-online.service")
    client.wait_until_succeeds("ping -c 5 10.0.2.1")
    router.wait_until_succeeds("ping -c 5 10.0.2.100")
  '';
})