tangled
alpha
login
or
join now
pyrox.dev
/
nixpkgs
lol
0
fork
atom
overview
issues
pulls
pipelines
nixosTests.udisks2: port to python
worldofpeace
6 years ago
ceec19f6
7d331eae
+26
-18
1 changed file
expand all
collapse all
unified
split
nixos
tests
udisks2.nix
+26
-18
nixos/tests/udisks2.nix
···
1
1
-
import ./make-test.nix ({ pkgs, ... }:
1
1
+
import ./make-test-python.nix ({ pkgs, ... }:
2
2
3
3
let
4
4
···
30
30
31
31
testScript =
32
32
''
33
33
-
my $stick = $machine->stateDir . "/usbstick.img";
34
34
-
system("xz -d < ${stick} > $stick") == 0 or die;
33
33
+
import lzma
35
34
36
36
-
$machine->succeed("udisksctl info -b /dev/vda >&2");
37
37
-
$machine->fail("udisksctl info -b /dev/sda1");
35
35
+
with lzma.open(
36
36
+
"${stick}"
37
37
+
) as data, open(machine.state_dir + "/usbstick.img", "wb") as stick:
38
38
+
stick.write(data.read())
39
39
+
40
40
+
machine.succeed("udisksctl info -b /dev/vda >&2")
41
41
+
machine.fail("udisksctl info -b /dev/sda1")
38
42
39
43
# Attach a USB stick and wait for it to show up.
40
40
-
$machine->sendMonitorCommand("drive_add 0 id=stick,if=none,file=$stick,format=raw");
41
41
-
$machine->sendMonitorCommand("device_add usb-storage,id=stick,drive=stick");
42
42
-
$machine->waitUntilSucceeds("udisksctl info -b /dev/sda1");
43
43
-
$machine->succeed("udisksctl info -b /dev/sda1 | grep 'IdLabel:.*USBSTICK'");
44
44
+
machine.send_monitor_command(
45
45
+
f"drive_add 0 id=stick,if=none,file={stick.name},format=raw"
46
46
+
)
47
47
+
machine.send_monitor_command("device_add usb-storage,id=stick,drive=stick")
48
48
+
machine.wait_until_succeeds("udisksctl info -b /dev/sda1")
49
49
+
machine.succeed("udisksctl info -b /dev/sda1 | grep 'IdLabel:.*USBSTICK'")
44
50
45
51
# Mount the stick as a non-root user and do some stuff with it.
46
46
-
$machine->succeed("su - alice -c 'udisksctl info -b /dev/sda1'");
47
47
-
$machine->succeed("su - alice -c 'udisksctl mount -b /dev/sda1'");
48
48
-
$machine->succeed("su - alice -c 'cat /run/media/alice/USBSTICK/test.txt'") =~ /Hello World/ or die;
49
49
-
$machine->succeed("su - alice -c 'echo foo > /run/media/alice/USBSTICK/bar.txt'");
52
52
+
machine.succeed("su - alice -c 'udisksctl info -b /dev/sda1'")
53
53
+
machine.succeed("su - alice -c 'udisksctl mount -b /dev/sda1'")
54
54
+
machine.succeed(
55
55
+
"su - alice -c 'cat /run/media/alice/USBSTICK/test.txt' | grep -q 'Hello World'"
56
56
+
)
57
57
+
machine.succeed("su - alice -c 'echo foo > /run/media/alice/USBSTICK/bar.txt'")
50
58
51
59
# Unmounting the stick should make the mountpoint disappear.
52
52
-
$machine->succeed("su - alice -c 'udisksctl unmount -b /dev/sda1'");
53
53
-
$machine->fail("[ -d /run/media/alice/USBSTICK ]");
60
60
+
machine.succeed("su - alice -c 'udisksctl unmount -b /dev/sda1'")
61
61
+
machine.fail("[ -d /run/media/alice/USBSTICK ]")
54
62
55
63
# Remove the USB stick.
56
56
-
$machine->sendMonitorCommand("device_del stick");
57
57
-
$machine->waitUntilFails("udisksctl info -b /dev/sda1");
58
58
-
$machine->fail("[ -e /dev/sda ]");
64
64
+
machine.send_monitor_command("device_del stick")
65
65
+
machine.wait_until_fails("udisksctl info -b /dev/sda1")
66
66
+
machine.fail("[ -e /dev/sda ]")
59
67
'';
60
68
61
69
})