Merge pull request #212685 from rnhmjoj/pr-connman
nixos/wireless: fix failure on missing config file
This commit is contained in:
commit
72c6c848ee
4 changed files with 92 additions and 6 deletions
|
@ -121,11 +121,15 @@ let
|
||||||
''}
|
''}
|
||||||
|
|
||||||
# substitute environment variables
|
# substitute environment variables
|
||||||
|
if [ -f "${configFile}" ]; then
|
||||||
${pkgs.gawk}/bin/awk '{
|
${pkgs.gawk}/bin/awk '{
|
||||||
for(varname in ENVIRON)
|
for(varname in ENVIRON)
|
||||||
gsub("@"varname"@", ENVIRON[varname])
|
gsub("@"varname"@", ENVIRON[varname])
|
||||||
print
|
print
|
||||||
}' "${configFile}" > "${finalConfig}"
|
}' "${configFile}" > "${finalConfig}"
|
||||||
|
else
|
||||||
|
touch "${finalConfig}"
|
||||||
|
fi
|
||||||
|
|
||||||
iface_args="-s ${optionalString cfg.dbusControlled "-u"} -D${cfg.driver} ${configStr}"
|
iface_args="-s ${optionalString cfg.dbusControlled "-u"} -D${cfg.driver} ${configStr}"
|
||||||
|
|
||||||
|
|
|
@ -135,6 +135,7 @@ in {
|
||||||
cntr = handleTestOn ["aarch64-linux" "x86_64-linux"] ./cntr.nix {};
|
cntr = handleTestOn ["aarch64-linux" "x86_64-linux"] ./cntr.nix {};
|
||||||
cockroachdb = handleTestOn ["x86_64-linux"] ./cockroachdb.nix {};
|
cockroachdb = handleTestOn ["x86_64-linux"] ./cockroachdb.nix {};
|
||||||
collectd = handleTest ./collectd.nix {};
|
collectd = handleTest ./collectd.nix {};
|
||||||
|
connman = handleTest ./connman.nix {};
|
||||||
consul = handleTest ./consul.nix {};
|
consul = handleTest ./consul.nix {};
|
||||||
containers-bridge = handleTest ./containers-bridge.nix {};
|
containers-bridge = handleTest ./containers-bridge.nix {};
|
||||||
containers-custom-pkgs.nix = handleTest ./containers-custom-pkgs.nix {};
|
containers-custom-pkgs.nix = handleTest ./containers-custom-pkgs.nix {};
|
||||||
|
|
77
nixos/tests/connman.nix
Normal file
77
nixos/tests/connman.nix
Normal file
|
@ -0,0 +1,77 @@
|
||||||
|
import ./make-test-python.nix ({ pkgs, lib, ...}:
|
||||||
|
{
|
||||||
|
name = "connman";
|
||||||
|
meta = with lib.maintainers; {
|
||||||
|
maintainers = [ rnhmjoj ];
|
||||||
|
};
|
||||||
|
|
||||||
|
# Router running radvd on VLAN 1
|
||||||
|
nodes.router = { ... }: {
|
||||||
|
imports = [ ../modules/profiles/minimal.nix ];
|
||||||
|
|
||||||
|
virtualisation.vlans = [ 1 ];
|
||||||
|
|
||||||
|
boot.kernel.sysctl."net.ipv6.conf.all.forwarding" = true;
|
||||||
|
|
||||||
|
networking = {
|
||||||
|
useDHCP = false;
|
||||||
|
interfaces.eth1.ipv6.addresses =
|
||||||
|
[ { address = "fd12::1"; prefixLength = 64; } ];
|
||||||
|
};
|
||||||
|
|
||||||
|
services.radvd = {
|
||||||
|
enable = true;
|
||||||
|
config = ''
|
||||||
|
interface eth1 {
|
||||||
|
AdvSendAdvert on;
|
||||||
|
AdvManagedFlag on;
|
||||||
|
AdvOtherConfigFlag on;
|
||||||
|
prefix fd12::/64 {
|
||||||
|
AdvAutonomous off;
|
||||||
|
};
|
||||||
|
};
|
||||||
|
'';
|
||||||
|
};
|
||||||
|
};
|
||||||
|
|
||||||
|
# Client running connman, connected to VLAN 1
|
||||||
|
nodes.client = { ... }: {
|
||||||
|
virtualisation.vlans = [ 1 ];
|
||||||
|
|
||||||
|
# add a virtual wlan interface
|
||||||
|
boot.kernelModules = [ "mac80211_hwsim" ];
|
||||||
|
boot.extraModprobeConfig = ''
|
||||||
|
options mac80211_hwsim radios=1
|
||||||
|
'';
|
||||||
|
|
||||||
|
# Note: the overrides are needed because the wifi is
|
||||||
|
# disabled with mkVMOverride in qemu-vm.nix.
|
||||||
|
services.connman.enable = lib.mkOverride 0 true;
|
||||||
|
services.connman.networkInterfaceBlacklist = [ "eth0" ];
|
||||||
|
networking.wireless.enable = lib.mkOverride 0 true;
|
||||||
|
networking.wireless.interfaces = [ "wlan0" ];
|
||||||
|
};
|
||||||
|
|
||||||
|
testScript =
|
||||||
|
''
|
||||||
|
start_all()
|
||||||
|
|
||||||
|
with subtest("Router is ready"):
|
||||||
|
router.wait_for_unit("radvd.service")
|
||||||
|
|
||||||
|
with subtest("Daemons are running"):
|
||||||
|
client.wait_for_unit("wpa_supplicant-wlan0.service")
|
||||||
|
client.wait_for_unit("connman.service")
|
||||||
|
client.wait_until_succeeds("connmanctl state | grep -q ready")
|
||||||
|
|
||||||
|
with subtest("Wired interface is configured"):
|
||||||
|
client.wait_until_succeeds("ip -6 route | grep -q fd12::/64")
|
||||||
|
client.wait_until_succeeds("ping -c 1 fd12::1")
|
||||||
|
|
||||||
|
with subtest("Can set up a wireless access point"):
|
||||||
|
client.succeed("connmanctl enable wifi")
|
||||||
|
client.wait_until_succeeds("connmanctl tether wifi on nixos-test reproducibility | grep -q 'Enabled'")
|
||||||
|
client.wait_until_succeeds("iw wlan0 info | grep -q nixos-test")
|
||||||
|
'';
|
||||||
|
})
|
||||||
|
|
|
@ -1,4 +1,6 @@
|
||||||
{ lib, stdenv
|
{ lib
|
||||||
|
, nixosTests
|
||||||
|
, stdenv
|
||||||
, fetchurl
|
, fetchurl
|
||||||
, fetchpatch
|
, fetchpatch
|
||||||
, pkg-config
|
, pkg-config
|
||||||
|
@ -170,6 +172,8 @@ stdenv.mkDerivation rec {
|
||||||
|
|
||||||
doCheck = true;
|
doCheck = true;
|
||||||
|
|
||||||
|
passthru.tests.connman = nixosTests.connman;
|
||||||
|
|
||||||
meta = with lib; {
|
meta = with lib; {
|
||||||
description = "A daemon for managing internet connections";
|
description = "A daemon for managing internet connections";
|
||||||
homepage = "https://git.kernel.org/pub/scm/network/connman/connman.git/";
|
homepage = "https://git.kernel.org/pub/scm/network/connman/connman.git/";
|
||||||
|
|
Loading…
Reference in a new issue