nixos/tests/timezone: port to python

gstqt5
x123 2019-12-02 23:28:53 +01:00 committed by Florian Klink
parent bfee3a4989
commit 07be580889
2 changed files with 42 additions and 36 deletions

View File

@ -267,6 +267,7 @@ in
taskserver = handleTest ./taskserver.nix {}; taskserver = handleTest ./taskserver.nix {};
telegraf = handleTest ./telegraf.nix {}; telegraf = handleTest ./telegraf.nix {};
tiddlywiki = handleTest ./tiddlywiki.nix {}; tiddlywiki = handleTest ./tiddlywiki.nix {};
timezone = handleTest ./timezone.nix {};
tinydns = handleTest ./tinydns.nix {}; tinydns = handleTest ./tinydns.nix {};
tor = handleTest ./tor.nix {}; tor = handleTest ./tor.nix {};
transmission = handleTest ./transmission.nix {}; transmission = handleTest ./transmission.nix {};

View File

@ -1,45 +1,50 @@
{ import ./make-test-python.nix ({ pkgs, ...} : {
timezone-static = import ./make-test.nix ({ pkgs, ... }: { name = "timezone";
name = "timezone-static"; meta.maintainers = with pkgs.lib.maintainers; [ lheckemann ];
meta.maintainers = with pkgs.lib.maintainers; [ lheckemann ];
machine.time.timeZone = "Europe/Amsterdam"; nodes = {
node_eutz = { pkgs, ... }: {
time.timeZone = "Europe/Amsterdam";
};
testScript = '' node_nulltz = { pkgs, ... }: {
$machine->waitForUnit("dbus.socket"); time.timeZone = null;
$machine->fail("timedatectl set-timezone Asia/Tokyo"); };
my @dateResult = $machine->execute('date -d @0 "+%Y-%m-%d %H:%M:%S"'); };
$dateResult[1] eq "1970-01-01 01:00:00\n" or die "Timezone seems to be wrong";
'';
});
timezone-imperative = import ./make-test.nix ({ pkgs, ... }: { testScript = { nodes, ... }: ''
name = "timezone-imperative"; node_eutz.wait_for_unit("dbus.socket")
meta.maintainers = with pkgs.lib.maintainers; [ lheckemann ];
machine.time.timeZone = null; with subtest("static - Ensure timezone change gives the correct result"):
node_eutz.fail("timedatectl set-timezone Asia/Tokyo")
date_result = node_eutz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"')
assert date_result == "1970-01-01 01:00:00\n", "Timezone seems to be wrong"
testScript = '' node_nulltz.wait_for_unit("dbus.socket")
$machine->waitForUnit("dbus.socket");
# Should default to UTC with subtest("imperative - Ensure timezone defaults to UTC"):
my @dateResult = $machine->execute('date -d @0 "+%Y-%m-%d %H:%M:%S"'); date_result = node_nulltz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"')
print $dateResult[1]; print(date_result)
$dateResult[1] eq "1970-01-01 00:00:00\n" or die "Timezone seems to be wrong"; assert (
date_result == "1970-01-01 00:00:00\n"
), "Timezone seems to be wrong (not UTC)"
$machine->succeed("timedatectl set-timezone Asia/Tokyo"); with subtest("imperative - Ensure timezone adjustment produces expected result"):
node_nulltz.succeed("timedatectl set-timezone Asia/Tokyo")
# Adjustment should be taken into account # Adjustment should be taken into account
my @dateResult = $machine->execute('date -d @0 "+%Y-%m-%d %H:%M:%S"'); date_result = node_nulltz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"')
print $dateResult[1]; print(date_result)
$dateResult[1] eq "1970-01-01 09:00:00\n" or die "Timezone was not adjusted"; assert date_result == "1970-01-01 09:00:00\n", "Timezone was not adjusted"
# Adjustment should persist across a reboot with subtest("imperative - Ensure timezone adjustment persists across reboot"):
$machine->shutdown; # Adjustment should persist across a reboot
$machine->waitForUnit("dbus.socket"); node_nulltz.shutdown()
my @dateResult = $machine->execute('date -d @0 "+%Y-%m-%d %H:%M:%S"'); node_nulltz.wait_for_unit("dbus.socket")
print $dateResult[1]; date_result = node_nulltz.succeed('date -d @0 "+%Y-%m-%d %H:%M:%S"')
$dateResult[1] eq "1970-01-01 09:00:00\n" or die "Timezone adjustment was not persisted"; print(date_result)
''; assert (
}); date_result == "1970-01-01 09:00:00\n"
} ), "Timezone adjustment was not persisted"
'';
})