mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-01-12 16:03:32 +00:00
4f0dadbf38
After final improvements to the official formatter implementation, this commit now performs the first treewide reformat of Nix files using it. This is part of the implementation of RFC 166. Only "inactive" files are reformatted, meaning only files that aren't being touched by any PR with activity in the past 2 months. This is to avoid conflicts for PRs that might soon be merged. Later we can do a full treewide reformat to get the rest, which should not cause as many conflicts. A CI check has already been running for some time to ensure that new and already-formatted files are formatted, so the files being reformatted here should also stay formatted. This commit was automatically created and can be verified using nix-builda08b3a4d19
.tar.gz \ --argstr baseRevb32a094368
result/bin/apply-formatting $NIXPKGS_PATH
137 lines
3.4 KiB
Nix
137 lines
3.4 KiB
Nix
# This test does a basic functionality check for all bird variants and demonstrates a use
|
|
# of the preCheckConfig option.
|
|
|
|
{
|
|
system ? builtins.currentSystem,
|
|
pkgs ? import ../.. {
|
|
inherit system;
|
|
config = { };
|
|
},
|
|
}:
|
|
|
|
let
|
|
inherit (import ../lib/testing-python.nix { inherit system pkgs; }) makeTest;
|
|
inherit (pkgs.lib) optionalString;
|
|
|
|
makeBird2Host =
|
|
hostId:
|
|
{ pkgs, ... }:
|
|
{
|
|
virtualisation.vlans = [ 1 ];
|
|
|
|
environment.systemPackages = with pkgs; [ jq ];
|
|
|
|
networking = {
|
|
useNetworkd = true;
|
|
useDHCP = false;
|
|
firewall.enable = false;
|
|
};
|
|
|
|
systemd.network.networks."01-eth1" = {
|
|
name = "eth1";
|
|
networkConfig.Address = "10.0.0.${hostId}/24";
|
|
};
|
|
|
|
services.bird2 = {
|
|
enable = true;
|
|
|
|
config = ''
|
|
log syslog all;
|
|
|
|
debug protocols all;
|
|
|
|
router id 10.0.0.${hostId};
|
|
|
|
protocol device {
|
|
}
|
|
|
|
protocol kernel kernel4 {
|
|
ipv4 {
|
|
import none;
|
|
export all;
|
|
};
|
|
}
|
|
|
|
protocol static static4 {
|
|
ipv4;
|
|
include "static4.conf";
|
|
}
|
|
|
|
protocol ospf v2 ospf4 {
|
|
ipv4 {
|
|
export all;
|
|
};
|
|
area 0 {
|
|
interface "eth1" {
|
|
hello 5;
|
|
wait 5;
|
|
};
|
|
};
|
|
}
|
|
|
|
protocol kernel kernel6 {
|
|
ipv6 {
|
|
import none;
|
|
export all;
|
|
};
|
|
}
|
|
|
|
protocol static static6 {
|
|
ipv6;
|
|
include "static6.conf";
|
|
}
|
|
|
|
protocol ospf v3 ospf6 {
|
|
ipv6 {
|
|
export all;
|
|
};
|
|
area 0 {
|
|
interface "eth1" {
|
|
hello 5;
|
|
wait 5;
|
|
};
|
|
};
|
|
}
|
|
'';
|
|
|
|
preCheckConfig = ''
|
|
echo "route 1.2.3.4/32 blackhole;" > static4.conf
|
|
echo "route fd00::/128 blackhole;" > static6.conf
|
|
'';
|
|
};
|
|
|
|
systemd.tmpfiles.rules = [
|
|
"f /etc/bird/static4.conf - - - - route 10.10.0.${hostId}/32 blackhole;"
|
|
"f /etc/bird/static6.conf - - - - route fdff::${hostId}/128 blackhole;"
|
|
];
|
|
};
|
|
in
|
|
makeTest {
|
|
name = "bird2";
|
|
|
|
nodes.host1 = makeBird2Host "1";
|
|
nodes.host2 = makeBird2Host "2";
|
|
|
|
testScript = ''
|
|
start_all()
|
|
|
|
host1.wait_for_unit("bird2.service")
|
|
host2.wait_for_unit("bird2.service")
|
|
host1.succeed("systemctl reload bird2.service")
|
|
|
|
with subtest("Waiting for advertised IPv4 routes"):
|
|
host1.wait_until_succeeds("ip --json r | jq -e 'map(select(.dst == \"10.10.0.2\")) | any'")
|
|
host2.wait_until_succeeds("ip --json r | jq -e 'map(select(.dst == \"10.10.0.1\")) | any'")
|
|
with subtest("Waiting for advertised IPv6 routes"):
|
|
host1.wait_until_succeeds("ip --json -6 r | jq -e 'map(select(.dst == \"fdff::2\")) | any'")
|
|
host2.wait_until_succeeds("ip --json -6 r | jq -e 'map(select(.dst == \"fdff::1\")) | any'")
|
|
|
|
with subtest("Check fake routes in preCheckConfig do not exists"):
|
|
host1.fail("ip --json r | jq -e 'map(select(.dst == \"1.2.3.4\")) | any'")
|
|
host2.fail("ip --json r | jq -e 'map(select(.dst == \"1.2.3.4\")) | any'")
|
|
|
|
host1.fail("ip --json -6 r | jq -e 'map(select(.dst == \"fd00::\")) | any'")
|
|
host2.fail("ip --json -6 r | jq -e 'map(select(.dst == \"fd00::\")) | any'")
|
|
'';
|
|
}
|