mirror of
https://github.com/ilyakooo0/nixpkgs.git
synced 2025-01-01 08:25:55 +03:00
83 lines
2.2 KiB
Nix
83 lines
2.2 KiB
Nix
|
# Test for NixOS' container support.
|
||
|
|
||
|
let
|
||
|
# containers IP on VLAN 1
|
||
|
containerIp1 = "192.168.1.253";
|
||
|
containerIp2 = "192.168.1.254";
|
||
|
in
|
||
|
|
||
|
import ./make-test.nix ({ pkgs, ...} : {
|
||
|
name = "containers-macvlans";
|
||
|
meta = with pkgs.stdenv.lib.maintainers; {
|
||
|
maintainers = [ montag451 ];
|
||
|
};
|
||
|
|
||
|
nodes = {
|
||
|
|
||
|
machine1 =
|
||
|
{ config, pkgs, lib, ... }:
|
||
|
{
|
||
|
virtualisation.memorySize = 256;
|
||
|
virtualisation.vlans = [ 1 ];
|
||
|
|
||
|
# To be able to ping containers from the host, it is necessary
|
||
|
# to create a macvlan on the host on the VLAN 1 network.
|
||
|
networking.macvlans.mv-eth1-host = {
|
||
|
interface = "eth1";
|
||
|
mode = "bridge";
|
||
|
};
|
||
|
networking.interfaces.eth1.ip4 = lib.mkForce [];
|
||
|
networking.interfaces.mv-eth1-host = {
|
||
|
ip4 = [ { address = "192.168.1.1"; prefixLength = 24; } ];
|
||
|
};
|
||
|
|
||
|
containers.test1 = {
|
||
|
autoStart = true;
|
||
|
macvlans = [ "eth1" ];
|
||
|
|
||
|
config = {
|
||
|
networking.interfaces.mv-eth1 = {
|
||
|
ip4 = [ { address = containerIp1; prefixLength = 24; } ];
|
||
|
};
|
||
|
};
|
||
|
};
|
||
|
|
||
|
containers.test2 = {
|
||
|
autoStart = true;
|
||
|
macvlans = [ "eth1" ];
|
||
|
|
||
|
config = {
|
||
|
networking.interfaces.mv-eth1 = {
|
||
|
ip4 = [ { address = containerIp2; prefixLength = 24; } ];
|
||
|
};
|
||
|
};
|
||
|
};
|
||
|
};
|
||
|
|
||
|
machine2 =
|
||
|
{ config, pkgs, ... }:
|
||
|
{
|
||
|
virtualisation.memorySize = 256;
|
||
|
virtualisation.vlans = [ 1 ];
|
||
|
};
|
||
|
|
||
|
};
|
||
|
|
||
|
testScript = ''
|
||
|
startAll;
|
||
|
$machine1->waitForUnit("default.target");
|
||
|
$machine2->waitForUnit("default.target");
|
||
|
|
||
|
# Ping between containers to check that macvlans are created in bridge mode
|
||
|
$machine1->succeed("nixos-container run test1 -- ping -n -c 1 ${containerIp2}");
|
||
|
|
||
|
# Ping containers from the host (machine1)
|
||
|
$machine1->succeed("ping -n -c 1 ${containerIp1}");
|
||
|
$machine1->succeed("ping -n -c 1 ${containerIp2}");
|
||
|
|
||
|
# Ping containers from the second machine to check that containers are reachable from the outside
|
||
|
$machine2->succeed("ping -n -c 1 ${containerIp1}");
|
||
|
$machine2->succeed("ping -n -c 1 ${containerIp2}");
|
||
|
'';
|
||
|
})
|