diff options
author | montag451 <montag451@laposte.net> | 2016-12-06 23:32:17 +0100 |
---|---|---|
committer | Jörg Thalheim <joerg@higgsboson.tk> | 2016-12-12 09:20:28 +0100 |
commit | ea5551b551d0d7f462b7f8e00e2bf86b2412a365 (patch) | |
tree | 90bb8e59d2dd9d3d22173c1a28c6055580599d92 /nixos/tests | |
parent | 4889c271cacf72a47dc2f081e6e718980fb80d60 (diff) | |
download | nixpkgs-ea5551b551d0d7f462b7f8e00e2bf86b2412a365.tar nixpkgs-ea5551b551d0d7f462b7f8e00e2bf86b2412a365.tar.gz nixpkgs-ea5551b551d0d7f462b7f8e00e2bf86b2412a365.tar.bz2 nixpkgs-ea5551b551d0d7f462b7f8e00e2bf86b2412a365.tar.lz nixpkgs-ea5551b551d0d7f462b7f8e00e2bf86b2412a365.tar.xz nixpkgs-ea5551b551d0d7f462b7f8e00e2bf86b2412a365.tar.zst nixpkgs-ea5551b551d0d7f462b7f8e00e2bf86b2412a365.zip |
containers: fix broken /etc/hosts entries when localAddress contains a netmask
Diffstat (limited to 'nixos/tests')
-rw-r--r-- | nixos/tests/containers-hosts.nix | 52 |
1 files changed, 52 insertions, 0 deletions
diff --git a/nixos/tests/containers-hosts.nix b/nixos/tests/containers-hosts.nix new file mode 100644 index 00000000000..c7a85f190a5 --- /dev/null +++ b/nixos/tests/containers-hosts.nix @@ -0,0 +1,52 @@ +# Test for NixOS' container support. + +import ./make-test.nix ({ pkgs, ...} : { + name = "containers-hosts"; + meta = with pkgs.stdenv.lib.maintainers; { + maintainers = [ montag451 ]; + }; + + machine = + { config, pkgs, lib, ... }: + { + virtualisation.memorySize = 256; + virtualisation.vlans = []; + + networking.bridges.br0.interfaces = []; + networking.interfaces.br0 = { + ip4 = [ { address = "10.11.0.254"; prefixLength = 24; } ]; + }; + + # Force /etc/hosts to be the only source for host name resolution + environment.etc."nsswitch.conf".text = lib.mkForce '' + hosts: files + ''; + + containers.simple = { + autoStart = true; + privateNetwork = true; + localAddress = "10.10.0.1"; + hostAddress = "10.10.0.254"; + + config = {}; + }; + + containers.netmask = { + autoStart = true; + privateNetwork = true; + hostBridge = "br0"; + localAddress = "10.11.0.1/24"; + + config = {}; + }; + }; + + testScript = '' + startAll; + $machine->waitForUnit("default.target"); + + # Ping the containers using the entries added in /etc/hosts + $machine->succeed("ping -n -c 1 simple.containers"); + $machine->succeed("ping -n -c 1 netmask.containers"); + ''; +}) |