-
Notifications
You must be signed in to change notification settings - Fork 10
Expand file tree
/
Copy pathtest_xfs_sr.py
More file actions
158 lines (139 loc) · 5.96 KB
/
Copy pathtest_xfs_sr.py
File metadata and controls
158 lines (139 loc) · 5.96 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
from __future__ import annotations
import pytest
import logging
import time
from lib.commands import SSHCommandFailed
from lib.common import Defer, vm_image, wait_for
from lib.host import Host
from lib.sr import SR
from lib.vdi import VDI
from lib.vm import VM
from tests.storage import (
CoalesceOperation,
ImageFormat,
XVACompression,
coalesce_integrity,
vdi_export_import,
vdi_is_open,
xva_export_import,
)
# Requirements:
# - one XCP-ng host >= 8.2 with an additional unused disk for the SR
# - access to XCP-ng RPM repository from the host
class TestXFSSRCreateDestroy:
"""
Tests that do not use fixtures that setup the SR or import VMs,
because they precisely need to test SR creation and destruction,
and VM import.
"""
def test_create_xfs_sr_without_xfsprogs(self,
host: Host,
unused_512B_disks: dict[Host, list[Host.BlockDeviceInfo]],
image_format: ImageFormat
) -> None:
# This test must be the first in the series in this module
assert not host.file_exists('/usr/sbin/mkfs.xfs'), \
"xfsprogs must not be installed on the host at the beginning of the tests"
sr_disk = unused_512B_disks[host][0]["name"]
sr: SR | None = None
try:
sr = host.sr_create('xfs', "XFS-local-SR-test", {
'device': '/dev/' + sr_disk,
'preferred-image-formats': image_format
})
except Exception:
logging.info("SR creation failed, as expected.")
if sr is not None:
sr.destroy()
assert False, "SR creation should not have succeeded!"
def test_create_and_destroy_sr(self,
unused_512B_disks: dict[Host, list[Host.BlockDeviceInfo]],
host_with_xfsprogs: Host
) -> None:
# Create and destroy tested in the same test to leave the host as unchanged as possible
host = host_with_xfsprogs
sr_disk = unused_512B_disks[host][0]["name"]
sr = host.sr_create('xfs', "XFS-local-SR-test", {'device': '/dev/' + sr_disk}, verify=True)
# import a VM in order to detect vm import issues here rather than in the vm_on_xfs fixture used in
# the next tests, because errors in fixtures break teardown
vm = host.import_vm(vm_image('mini-linux-x86_64-bios'), sr_uuid=sr.uuid)
vm.destroy(verify=True)
sr.destroy(verify=True)
@pytest.mark.usefixtures("xfs_sr")
class TestXFSSR:
@pytest.mark.quicktest
def test_quicktest(self, xfs_sr: SR) -> None:
xfs_sr.run_quicktest()
def test_vdi_is_not_open(self, vdi_on_xfs_sr: VDI) -> None:
assert not vdi_is_open(vdi_on_xfs_sr)
def test_vdi_image_format(self, vdi_on_xfs_sr: VDI, image_format: ImageFormat) -> None:
fmt = vdi_on_xfs_sr.get_image_format()
# feature-detect: if the SM doesn't report image-format, skip this check
if not fmt:
pytest.skip("SM does not report sm-config:image-format; skipping format check")
assert fmt == image_format
@pytest.mark.small_vm # run with a small VM to test the features
@pytest.mark.big_vm # and ideally with a big VM to test it scales
def test_start_and_shutdown_VM(self, vm_on_xfs_sr: VM) -> None:
vm = vm_on_xfs_sr
vm.start()
vm.wait_for_os_booted()
vm.shutdown(verify=True)
@pytest.mark.small_vm
@pytest.mark.big_vm
def test_snapshot(self, vm_on_xfs_sr: VM) -> None:
vm = vm_on_xfs_sr
vm.start()
try:
vm.wait_for_os_booted()
vm.test_snapshot_on_running_vm()
finally:
vm.shutdown(verify=True)
@pytest.mark.small_vm
@pytest.mark.parametrize("vdi_op", ["snapshot", "clone"])
def test_coalesce(self, storage_test_vm: VM, vdi_on_xfs_sr: VDI, vdi_op: CoalesceOperation, defer: Defer) -> None:
coalesce_integrity(storage_test_vm, vdi_on_xfs_sr, vdi_op, defer)
@pytest.mark.small_vm
@pytest.mark.parametrize("compression", ["none", "gzip", "zstd"])
def test_xva_export_import(self, vm_on_xfs_sr: VM, compression: XVACompression, defer: Defer) -> None:
xva_export_import(vm_on_xfs_sr, compression, defer)
@pytest.mark.small_vm
def test_vdi_export_import(self, storage_test_vm: VM, xfs_sr: SR, image_format: ImageFormat, defer: Defer) -> None:
vdi_export_import(storage_test_vm, xfs_sr, image_format, defer)
# *** tests with reboots (longer tests).
@pytest.mark.reboot
@pytest.mark.small_vm
def test_reboot(self, vm_on_xfs_sr: VM, host: Host, xfs_sr: SR) -> None:
sr = xfs_sr
vm = vm_on_xfs_sr
host.reboot(verify=True)
wait_for(sr.all_pbds_attached, "Wait for PBD attached")
# start the VM as a way to check that the underlying SR is operational
vm.start()
vm.wait_for_os_booted()
vm.shutdown(verify=True)
@pytest.mark.reboot
def test_xfsprogs_missing(self, host: Host, xfs_sr: SR) -> None:
sr = xfs_sr
xfsprogs_installed = True
try:
host.yum_remove(['xfsprogs'])
xfsprogs_installed = False
try:
sr.scan()
assert False, "SR scan should have failed"
except SSHCommandFailed:
logging.info("SR scan failed as expected.")
host.reboot(verify=True)
# give the host some time to try to attach the SR
time.sleep(10)
logging.info("Assert PBD not attached")
assert not sr.all_pbds_attached()
host.yum_install(['xfsprogs'])
xfsprogs_installed = True
sr.plug_pbds(verify=True)
sr.scan()
finally:
if not xfsprogs_installed:
host.yum_install(['xfsprogs'])
# *** End of tests with reboots