Skip to content

Commit

Permalink
nixos/tests/vpp: init
Browse files Browse the repository at this point in the history
  • Loading branch information
romner-set committed Dec 17, 2024
1 parent 1984959 commit e273f6e
Show file tree
Hide file tree
Showing 3 changed files with 145 additions and 4 deletions.
1 change: 1 addition & 0 deletions nixos/tests/all-tests.nix
Original file line number Diff line number Diff line change
Expand Up @@ -1137,6 +1137,7 @@ in {
victoriametrics = handleTest ./victoriametrics {};
vikunja = handleTest ./vikunja.nix {};
virtualbox = handleTestOn ["x86_64-linux"] ./virtualbox.nix {};
vpp = handleTest ./vpp.nix {};
vscode-remote-ssh = handleTestOn ["x86_64-linux"] ./vscode-remote-ssh.nix {};
vscodium = discoverTests (import ./vscodium.nix);
vsftpd = handleTest ./vsftpd.nix {};
Expand Down
132 changes: 132 additions & 0 deletions nixos/tests/vpp.nix
Original file line number Diff line number Diff line change
@@ -0,0 +1,132 @@
# This test runs FD.io's VPP and tests routing between two virtual networks.
# Topology is similar to the `nat` test, with a client on one network, a server
# on another, and a VPP-powered router inbetween connecting the two.

import ./make-test-python.nix (
{ pkgs, lib, ... }:
{
name = "vpp";

meta.maintainers = with lib.maintainers; [ romner-set ];

nodes = {
client =
{ ... }:
{
virtualisation.vlans = [ 1 ];
networking.interfaces = lib.mkForce {
eth1.ipv6.addresses = [
{
address = "fd01::2";
prefixLength = 64;
}
];
};
networking.defaultGateway6 = "fd01::1";
networking.useDHCP = false;
};
server =
{ ... }:
{
virtualisation.vlans = [ 2 ];
networking.interfaces = lib.mkForce {
eth1.ipv6.addresses = [
{
address = "fd02::2";
prefixLength = 64;
}
];
};
networking.defaultGateway6 = "fd02::1";
networking.useDHCP = false;

services.nginx.enable = true;
services.nginx.statusPage = true;

networking.firewall.allowedTCPPorts = [ 80 ];
};
router =
{ config, ... }:
{
virtualisation.vlans = [
1
2
];

# Disable netdevs so VPP can take over them
networking.useDHCP = false;
networking.interfaces = lib.mkForce { };

# install igb_uio driver
boot.extraModulePackages = [ config.boot.kernelPackages.dpdk-kmods ];

virtualisation.memorySize = 4096;
services.vpp.hugepages = {
autoSetup = true;
count = 1024;
};

services.vpp.instances.main = {
enable = true;
kernelModule = "igb_uio";
settings = {
unix.cli-listen = "/run/vpp/cli.sock"; # override a default value

plugins = {
# Selectively enable only necessary plugins
plugin.default.disable = true;
plugin."dpdk_plugin.so".enable = true;
};

dpdk.dev."0000:00:09.0".name = "vlan1";
dpdk.dev."0000:00:0a.0".name = "vlan2";
};
startupConfig = ''
set int state vlan1 up
set int state vlan2 up
set int ip addr vlan1 fd01::1/64
set int ip addr vlan2 fd02::1/64
'';
};
};
};

testScript = ''
start_all()
# wait for router
router.wait_for_unit("vpp-main.service")
router.wait_for_file("/run/vpp/cli.sock")
# make sure VPP initialized correctly
# the sleep is necessary since startupConfig executes *after* the service starts
router.sleep(2)
router.succeed("vppctl show int addr | grep -A1 vlan1 | grep -q fd01::1/64")
router.succeed("vppctl show int addr | grep -A1 vlan2 | grep -q fd02::1/64")
# wait for server, make sure nginx is reachable
server.wait_for_unit("nginx.service")
server.succeed("curl --fail http://[::1]")
# wait for client, make sure it can connect to the server through the router
client.wait_for_unit("network.target")
client.succeed("curl --fail http://[fd02::2]")
# test ICMP
server.succeed("ping -c 1 fd01::2")
client.succeed("ping -c 1 fd02::2")
# disable interfaces in VPP, make sure server isn't reachable
router.succeed("vppctl set int state vlan1 down")
router.succeed("vppctl set int state vlan2 down")
client.fail("curl --fail --connect-timeout 5 http://[fd02::2]")
client.fail("ping -c 1 fd02::2")
# restart VPP, make sure it restores its config & server becomes reachable again
router.succeed("systemctl restart vpp-main")
router.wait_for_unit("vpp-main.service")
client.succeed("curl --fail http://[fd02::2]")
client.succeed("ping -c 1 fd02::2")
'';
}
)
16 changes: 12 additions & 4 deletions pkgs/by-name/vp/vpp/package.nix
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,7 @@
stdenv,
fetchFromGitHub,
nix-update-script,
nixosTests,
cmake,
pkg-config,
check,
Expand Down Expand Up @@ -81,10 +82,13 @@ stdenv.mkDerivation rec {
"-DVPP_LIBRARY_DIR=lib"
] ++ lib.optional enableDpdk "-DVPP_USE_SYSTEM_DPDK=ON";

nativeBuildInputs = [
cmake
pkg-config
] ++ lib.optional enableDpdk dpdk' ++ lib.optional enableRdma rdma-core'.dev;
nativeBuildInputs =
[
cmake
pkg-config
]
++ lib.optional enableDpdk dpdk'
++ lib.optional enableRdma rdma-core'.dev;

buildInputs =
[
Expand Down Expand Up @@ -115,6 +119,10 @@ stdenv.mkDerivation rec {

passthru.updateScript = nix-update-script { };

passthru.tests = {
inherit (nixosTests) vpp;
};

meta = {
description = "Fast, scalable layer 2-4 multi-platform network stack running in user space";
homepage = "https://s3-docs.fd.io/vpp/${version}/";
Expand Down

0 comments on commit e273f6e

Please sign in to comment.