Home Explore Blog CI



nixpkgs

nixos/doc/manual/development/testing-hardware-features.section.md
71e5d6775d9b78e933924d6181d2fc5c54b7909c07bd27430000000300000eb5
# Testing Hardware Features {#sec-nixos-test-testing-hardware-features}

This section covers how to test various features using NixOS tests that would
normally only be possible with hardware. It is designed to showcase the NixOS test
framework's flexibility when combined with various hardware simulation libraries
or kernel modules.

## Wi-Fi {#sec-nixos-test-wifi}

Use `services.vwifi` to set up a virtual Wi-Fi physical layer. Create at least two nodes
for this kind of test: one with vwifi active, and either a station or an access point.
Give each a static IP address on the test network so they will never collide.
This module likely supports other topologies too; document them if you make one.

This NixOS module leverages [vwifi](https://github.com/Raizo62/vwifi). Read the
upstream repository's documentation for more information.

### vwifi server {#sec-nixos-test-wifi-vwifi-server}

This node runs the vwifi server, and otherwise does not interact with the network.
You can run `vwifi-ctrl` on this node to control characteristics of the simulated
physical layer.

```nix
airgap =
  { config, ... }:
  {
    networking.interfaces.eth1.ipv4.addresses = lib.mkForce [
      {
        address = "192.168.1.2";
        prefixLength = 24;
      }
    ];
    services.vwifi = {
      server = {
        enable = true;
        ports.tcp = 8212;
        # uncomment if you want to enable monitor mode on another node
        # ports.spy = 8213;
        openFirewall = true;
      };
    };
  };
```

### AP {#sec-nixos-test-wifi-ap}

A node like this will act as a wireless access point in infrastructure mode.

```nix
ap =
  { config, ... }:
  {
    networking.interfaces.eth1.ipv4.addresses = lib.mkForce [
      {
        address = "192.168.1.3";
        prefixLength = 24;
      }
    ];
    services.hostapd = {
      enable = true;
      radios.wlan0 = {
        channel = 1;
        networks.wlan0 = {
          ssid = "NixOS Test Wi-Fi Network";
          authentication = {
            mode = "wpa3-sae";
            saePasswords = [ { password = "supersecret"; } ];
            enableRecommendedPairwiseCiphers = true;
          };
        };
      };
    };
    services.vwifi = {
      module = {
        enable = true;
        macPrefix = "74:F8:F6:00:01";
      };
      client = {
        enable = true;
        serverAddress = "192.168.1.2";
      };
    };
  };
```

### Station {#sec-nixos-test-wifi-station}

A node like this acts as a wireless client.

```nix
station =
  { config, ... }:
  {
    networking.interfaces.eth1.ipv4.addresses = lib.mkForce [
      {
        address = "192.168.1.3";
        prefixLength = 24;
      }
    ];
    networking.wireless = {
      # No, really, we want it enabled!
      enable = lib.mkOverride 0 true;
      interfaces = [ "wlan0" ];
      networks = {
        "NixOS Test Wi-Fi Network" = {
          psk = "supersecret";
          authProtocols = [ "SAE" ];
        };
      };
    };
    services.vwifi = {
      module = {
        enable = true;
        macPrefix = "74:F8:F6:00:02";
      };
      client = {
        enable = true;
        serverAddress = "192.168.1.2";
      };
    };
  };
```

### Monitor {#sec-nixos-test-wifi-monitor}

When the monitor mode interface is enabled, this node will receive
all packets broadcast by all other nodes through the spy interface.

```nix
monitor =
  { config, ... }:
  {
    networking.interfaces.eth1.ipv4.addresses = lib.mkForce [
      {
        address = "192.168.1.4";
        prefixLength = 24;
      }
    ];

    services.vwifi = {
      module = {
        enable = true;
        macPrefix = "74:F8:F6:00:03";
      };
      client = {
        enable = true;
        spy = true;
        serverAddress = "192.168.1.2";
      };
    };
```

Chunks
3aeda590 (1st chunk of `nixos/doc/manual/development/testing-hardware-features.section.md`)
Title: Testing Hardware Features: Wi-Fi
Summary
This section describes how to test Wi-Fi functionality using NixOS tests and the `vwifi` module. It outlines the configuration for a vwifi server, an access point (AP), a station (client), and a monitor node. The vwifi server simulates the physical layer, while the AP and station nodes emulate wireless network components. The monitor node captures all broadcast packets.