mirror of
https://github.com/NixOS/nixpkgs.git
synced 2025-06-09 19:13:26 +03:00

Format all Nix files using the officially approved formatter,
making the CI check introduced in the previous commit succeed:
nix-build ci -A fmt.check
This is the next step of the of the [implementation](https://github.com/NixOS/nixfmt/issues/153)
of the accepted [RFC 166](https://github.com/NixOS/rfcs/pull/166).
This commit will lead to merge conflicts for a number of PRs,
up to an estimated ~1100 (~33%) among the PRs with activity in the past 2
months, but that should be lower than what it would be without the previous
[partial treewide format](https://github.com/NixOS/nixpkgs/pull/322537).
Merge conflicts caused by this commit can now automatically be resolved while rebasing using the
[auto-rebase script](8616af08d9/maintainers/scripts/auto-rebase
).
If you run into any problems regarding any of this, please reach out to the
[formatting team](https://nixos.org/community/teams/formatting/) by
pinging @NixOS/nix-formatting.
87 lines
2.6 KiB
Nix
87 lines
2.6 KiB
Nix
{
|
|
system ? builtins.currentSystem,
|
|
config ? { },
|
|
pkgs ? import ../.. { inherit system config; },
|
|
}:
|
|
|
|
with import ../lib/testing-python.nix { inherit system pkgs; };
|
|
with pkgs.lib;
|
|
|
|
let
|
|
makeHostNameTest =
|
|
hostName: domain: fqdnOrNull:
|
|
let
|
|
fqdn = hostName + (optionalString (domain != null) ".${domain}");
|
|
getStr =
|
|
str: # maybeString2String
|
|
let
|
|
res = builtins.tryEval str;
|
|
in
|
|
if (res.success && res.value != null) then res.value else "null";
|
|
in
|
|
makeTest {
|
|
name = "hostname-${fqdn}";
|
|
meta = with pkgs.lib.maintainers; {
|
|
maintainers = [
|
|
primeos
|
|
blitz
|
|
];
|
|
};
|
|
|
|
nodes.machine =
|
|
{ lib, ... }:
|
|
{
|
|
networking.hostName = hostName;
|
|
networking.domain = domain;
|
|
|
|
environment.systemPackages = with pkgs; [
|
|
inetutils
|
|
];
|
|
};
|
|
|
|
testScript =
|
|
{ nodes, ... }:
|
|
''
|
|
start_all()
|
|
|
|
machine = ${hostName}
|
|
|
|
machine.systemctl("start network-online.target")
|
|
machine.wait_for_unit("network-online.target")
|
|
|
|
# Test if NixOS computes the correct FQDN (either a FQDN or an error/null):
|
|
assert "${getStr nodes.machine.networking.fqdn}" == "${getStr fqdnOrNull}"
|
|
|
|
# The FQDN, domain name, and hostname detection should work as expected:
|
|
assert "${fqdn}" == machine.succeed("hostname --fqdn").strip()
|
|
assert "${optionalString (domain != null) domain}" == machine.succeed("dnsdomainname").strip()
|
|
assert (
|
|
"${hostName}"
|
|
== machine.succeed(
|
|
'hostnamectl status | grep "Static hostname" | cut -d: -f2'
|
|
).strip()
|
|
)
|
|
|
|
# 127.0.0.1 and ::1 should resolve back to "localhost":
|
|
assert (
|
|
"localhost" == machine.succeed("getent hosts 127.0.0.1 | awk '{print $2}'").strip()
|
|
)
|
|
assert "localhost" == machine.succeed("getent hosts ::1 | awk '{print $2}'").strip()
|
|
|
|
# 127.0.0.2 should resolve back to the FQDN and hostname:
|
|
fqdn_and_host_name = "${optionalString (domain != null) "${hostName}.${domain} "}${hostName}"
|
|
assert (
|
|
fqdn_and_host_name
|
|
== machine.succeed("getent hosts 127.0.0.2 | awk '{print $2,$3}'").strip()
|
|
)
|
|
|
|
assert "${fqdn}" == machine.succeed("getent hosts ${hostName} | awk '{print $2}'").strip()
|
|
'';
|
|
};
|
|
|
|
in
|
|
{
|
|
noExplicitDomain = makeHostNameTest "ahost" null null;
|
|
|
|
explicitDomain = makeHostNameTest "ahost" "adomain" "ahost.adomain";
|
|
}
|