mirror of
https://github.com/ceph/ceph
synced 2025-01-02 00:52:22 +00:00
test/pybind/rbd: convert from nose to pytest
* use fixtures for temporary images and groups * use pytest.skip instead of nose.SkipTest * replace setUp/tearDown with setup/teardown_method * add @pytest.mark.skip_if_crimson * replace nose assertions Signed-off-by: Casey Bodley <cbodley@redhat.com>
This commit is contained in:
parent
744c8b0841
commit
af04457a43
@ -7,6 +7,6 @@ tasks:
|
||||
- workunit:
|
||||
clients:
|
||||
client.0:
|
||||
- rbd/test_librbd_python.sh --eval-attr 'not (SKIP_IF_CRIMSON)'
|
||||
- rbd/test_librbd_python.sh -m 'not skip_if_crimson'
|
||||
env:
|
||||
RBD_FEATURES: "61"
|
||||
|
@ -7,4 +7,4 @@ tasks:
|
||||
- workunit:
|
||||
clients:
|
||||
client.0:
|
||||
- rbd/test_librbd_python.sh --eval-attr 'not (SKIP_IF_CRIMSON)'
|
||||
- rbd/test_librbd_python.sh -m 'not skip_if_crimson'
|
||||
|
@ -5,8 +5,8 @@ relpath=$(dirname $0)/../../../src/test/pybind
|
||||
if [ -n "${VALGRIND}" ]; then
|
||||
valgrind ${VALGRIND} --suppressions=${TESTDIR}/valgrind.supp \
|
||||
--errors-for-leak-kinds=definite --error-exitcode=1 \
|
||||
python3 -m nose -v $relpath/test_rbd.py "$@"
|
||||
python3 -m pytest -v $relpath/test_rbd.py "$@"
|
||||
else
|
||||
python3 -m nose -v $relpath/test_rbd.py "$@"
|
||||
python3 -m pytest -v $relpath/test_rbd.py "$@"
|
||||
fi
|
||||
exit 0
|
||||
|
23
src/test/pybind/assertions.py
Normal file
23
src/test/pybind/assertions.py
Normal file
@ -0,0 +1,23 @@
|
||||
def assert_equal(a, b):
|
||||
assert a == b
|
||||
|
||||
def assert_not_equal(a, b):
|
||||
assert a != b
|
||||
|
||||
def assert_greater_equal(a, b):
|
||||
assert a >= b
|
||||
|
||||
def assert_raises(excClass, callableObj, *args, **kwargs):
|
||||
"""
|
||||
Like unittest.TestCase.assertRaises, but returns the exception.
|
||||
"""
|
||||
try:
|
||||
callableObj(*args, **kwargs)
|
||||
except excClass as e:
|
||||
return e
|
||||
else:
|
||||
if hasattr(excClass, '__name__'):
|
||||
excName = excClass.__name__
|
||||
else:
|
||||
excName = str(excClass)
|
||||
raise AssertionError("%s not raised" % excName)
|
3
src/test/pybind/pytest.ini
Normal file
3
src/test/pybind/pytest.ini
Normal file
@ -0,0 +1,3 @@
|
||||
[pytest]
|
||||
markers =
|
||||
skip_if_crimson
|
@ -7,14 +7,13 @@ import json
|
||||
import socket
|
||||
import os
|
||||
import platform
|
||||
import pytest
|
||||
import time
|
||||
import sys
|
||||
|
||||
from datetime import datetime, timedelta
|
||||
from nose import with_setup, SkipTest
|
||||
from nose.plugins.attrib import attr
|
||||
from nose.tools import (eq_ as eq, assert_raises, assert_not_equal,
|
||||
from assertions import (assert_equal as eq, assert_raises, assert_not_equal,
|
||||
assert_greater_equal)
|
||||
from datetime import datetime, timedelta
|
||||
from rados import (Rados,
|
||||
LIBRADOS_OP_FLAG_FADVISE_DONTNEED,
|
||||
LIBRADOS_OP_FLAG_FADVISE_NOCACHE,
|
||||
@ -121,6 +120,12 @@ def remove_image():
|
||||
if image_name is not None:
|
||||
RBD().remove(ioctx, image_name)
|
||||
|
||||
@pytest.fixture
|
||||
def tmp_image():
|
||||
create_image()
|
||||
yield
|
||||
remove_image()
|
||||
|
||||
def create_group():
|
||||
global group_name
|
||||
group_name = get_temp_group_name()
|
||||
@ -130,6 +135,12 @@ def remove_group():
|
||||
if group_name is not None:
|
||||
RBD().group_remove(ioctx, group_name)
|
||||
|
||||
@pytest.fixture
|
||||
def tmp_group():
|
||||
create_group()
|
||||
yield
|
||||
remove_group()
|
||||
|
||||
def rename_group():
|
||||
new_group_name = "new" + group_name
|
||||
RBD().group_rename(ioctx, group_name, new_group_name)
|
||||
@ -139,7 +150,7 @@ def require_new_format():
|
||||
def _require_new_format(*args, **kwargs):
|
||||
global features
|
||||
if features is None:
|
||||
raise SkipTest
|
||||
pytest.skip('requires new format')
|
||||
return fn(*args, **kwargs)
|
||||
return functools.wraps(fn)(_require_new_format)
|
||||
return wrapper
|
||||
@ -149,10 +160,10 @@ def require_features(required_features):
|
||||
def _require_features(*args, **kwargs):
|
||||
global features
|
||||
if features is None:
|
||||
raise SkipTest
|
||||
pytest.skip('requires new format')
|
||||
for feature in required_features:
|
||||
if feature & features != feature:
|
||||
raise SkipTest
|
||||
pytest.skip('missing required feature')
|
||||
return fn(*args, **kwargs)
|
||||
return functools.wraps(fn)(_require_features)
|
||||
return wrapper
|
||||
@ -161,7 +172,7 @@ def require_linux():
|
||||
def wrapper(fn):
|
||||
def _require_linux(*args, **kwargs):
|
||||
if platform.system() != "Linux":
|
||||
raise SkipTest
|
||||
pytest.skip('requires linux')
|
||||
return fn(*args, **kwargs)
|
||||
return functools.wraps(fn)(_require_linux)
|
||||
return wrapper
|
||||
@ -172,7 +183,7 @@ def blocklist_features(blocklisted_features):
|
||||
global features
|
||||
for feature in blocklisted_features:
|
||||
if features is not None and feature & features == feature:
|
||||
raise SkipTest
|
||||
pytest.skip('blocklisted feature enabled')
|
||||
return fn(*args, **kwargs)
|
||||
return functools.wraps(fn)(_blocklist_features)
|
||||
return wrapper
|
||||
@ -380,16 +391,15 @@ def test_remove_dne():
|
||||
def test_list_empty():
|
||||
eq([], RBD().list(ioctx))
|
||||
|
||||
@with_setup(create_image, remove_image)
|
||||
def test_list():
|
||||
def test_list(tmp_image):
|
||||
eq([image_name], RBD().list(ioctx))
|
||||
|
||||
with Image(ioctx, image_name) as image:
|
||||
image_id = image.id()
|
||||
eq([{'id': image_id, 'name': image_name}], list(RBD().list2(ioctx)))
|
||||
|
||||
@with_setup(create_image)
|
||||
def test_remove_with_progress():
|
||||
create_image()
|
||||
d = {'received_callback': False}
|
||||
def progress_cb(current, total):
|
||||
d['received_callback'] = True
|
||||
@ -398,16 +408,14 @@ def test_remove_with_progress():
|
||||
RBD().remove(ioctx, image_name, on_progress=progress_cb)
|
||||
eq(True, d['received_callback'])
|
||||
|
||||
@with_setup(create_image)
|
||||
def test_remove_canceled():
|
||||
def test_remove_canceled(tmp_image):
|
||||
def progress_cb(current, total):
|
||||
return -ECANCELED
|
||||
|
||||
assert_raises(OperationCanceled, RBD().remove, ioctx, image_name,
|
||||
on_progress=progress_cb)
|
||||
|
||||
@with_setup(create_image, remove_image)
|
||||
def test_rename():
|
||||
def test_rename(tmp_image):
|
||||
rbd = RBD()
|
||||
image_name2 = get_temp_image_name()
|
||||
rbd.rename(ioctx, image_name, image_name2)
|
||||
@ -566,12 +574,12 @@ def test_features_from_string():
|
||||
|
||||
class TestImage(object):
|
||||
|
||||
def setUp(self):
|
||||
def setup_method(self, method):
|
||||
self.rbd = RBD()
|
||||
create_image()
|
||||
self.image = Image(ioctx, image_name)
|
||||
|
||||
def tearDown(self):
|
||||
def teardown_method(self, method):
|
||||
self.image.close()
|
||||
remove_image()
|
||||
self.image = None
|
||||
@ -783,7 +791,7 @@ class TestImage(object):
|
||||
self._test_copy(features, self.image.stat()['order'],
|
||||
self.image.stripe_unit(), self.image.stripe_count())
|
||||
|
||||
@attr('SKIP_IF_CRIMSON')
|
||||
@pytest.mark.skip_if_crimson
|
||||
def test_deep_copy(self):
|
||||
global ioctx
|
||||
global features
|
||||
@ -1410,13 +1418,13 @@ class TestImage(object):
|
||||
|
||||
class TestImageId(object):
|
||||
|
||||
def setUp(self):
|
||||
def setup_method(self, method):
|
||||
self.rbd = RBD()
|
||||
create_image()
|
||||
self.image = Image(ioctx, image_name)
|
||||
self.image2 = Image(ioctx, None, None, False, self.image.id())
|
||||
|
||||
def tearDown(self):
|
||||
def teardown_method(self, method):
|
||||
self.image.close()
|
||||
self.image2.close()
|
||||
remove_image()
|
||||
@ -1447,7 +1455,7 @@ def check_diff(image, offset, length, from_snapshot, expected):
|
||||
class TestClone(object):
|
||||
|
||||
@require_features([RBD_FEATURE_LAYERING])
|
||||
def setUp(self):
|
||||
def setup_method(self, method):
|
||||
global ioctx
|
||||
global features
|
||||
self.rbd = RBD()
|
||||
@ -1463,7 +1471,7 @@ class TestClone(object):
|
||||
features)
|
||||
self.clone = Image(ioctx, self.clone_name)
|
||||
|
||||
def tearDown(self):
|
||||
def teardown_method(self, method):
|
||||
global ioctx
|
||||
self.clone.close()
|
||||
self.rbd.remove(ioctx, self.clone_name)
|
||||
@ -1548,7 +1556,7 @@ class TestClone(object):
|
||||
# can't remove a snapshot that has dependent clones
|
||||
assert_raises(ImageBusy, self.image.remove_snap, 'snap1')
|
||||
|
||||
# validate parent info of clone created by TestClone.setUp
|
||||
# validate parent info of clone created by TestClone.setup_method
|
||||
(pool, image, snap) = self.clone.parent_info()
|
||||
eq(pool, pool_name)
|
||||
eq(image, image_name)
|
||||
@ -1914,7 +1922,7 @@ class TestClone(object):
|
||||
class TestExclusiveLock(object):
|
||||
|
||||
@require_features([RBD_FEATURE_EXCLUSIVE_LOCK])
|
||||
def setUp(self):
|
||||
def setup_method(self, method):
|
||||
global rados2
|
||||
rados2 = Rados(conffile='')
|
||||
rados2.connect()
|
||||
@ -1922,7 +1930,7 @@ class TestExclusiveLock(object):
|
||||
ioctx2 = rados2.open_ioctx(pool_name)
|
||||
create_image()
|
||||
|
||||
def tearDown(self):
|
||||
def teardown_method(self, method):
|
||||
remove_image()
|
||||
global ioctx2
|
||||
ioctx2.close()
|
||||
@ -2036,7 +2044,7 @@ class TestExclusiveLock(object):
|
||||
image.lock_acquire(RBD_LOCK_MODE_EXCLUSIVE)
|
||||
image.lock_release()
|
||||
|
||||
@attr('SKIP_IF_CRIMSON')
|
||||
@pytest.mark.skip_if_crimson
|
||||
def test_break_lock(self):
|
||||
blocklist_rados = Rados(conffile='')
|
||||
blocklist_rados.connect()
|
||||
@ -2087,14 +2095,14 @@ class TestMirroring(object):
|
||||
if primary is not None:
|
||||
eq(primary, info['primary'])
|
||||
|
||||
def setUp(self):
|
||||
def setup_method(self, method):
|
||||
self.rbd = RBD()
|
||||
self.initial_mirror_mode = self.rbd.mirror_mode_get(ioctx)
|
||||
self.rbd.mirror_mode_set(ioctx, RBD_MIRROR_MODE_POOL)
|
||||
create_image()
|
||||
self.image = Image(ioctx, image_name)
|
||||
|
||||
def tearDown(self):
|
||||
def teardown_method(self, method):
|
||||
self.image.close()
|
||||
remove_image()
|
||||
self.rbd.mirror_mode_set(ioctx, self.initial_mirror_mode)
|
||||
@ -2387,14 +2395,14 @@ class TestMirroring(object):
|
||||
|
||||
class TestTrash(object):
|
||||
|
||||
def setUp(self):
|
||||
def setup_method(self, method):
|
||||
global rados2
|
||||
rados2 = Rados(conffile='')
|
||||
rados2.connect()
|
||||
global ioctx2
|
||||
ioctx2 = rados2.open_ioctx(pool_name)
|
||||
|
||||
def tearDown(self):
|
||||
def teardown_method(self, method):
|
||||
global ioctx2
|
||||
ioctx2.close()
|
||||
global rados2
|
||||
@ -2524,18 +2532,17 @@ def test_rename_group():
|
||||
def test_list_groups_empty():
|
||||
eq([], RBD().group_list(ioctx))
|
||||
|
||||
@with_setup(create_group, remove_group)
|
||||
def test_list_groups():
|
||||
def test_list_groups(tmp_group):
|
||||
eq([group_name], RBD().group_list(ioctx))
|
||||
|
||||
@with_setup(create_group)
|
||||
def test_list_groups_after_removed():
|
||||
create_group()
|
||||
remove_group()
|
||||
eq([], RBD().group_list(ioctx))
|
||||
|
||||
class TestGroups(object):
|
||||
|
||||
def setUp(self):
|
||||
def setup_method(self, method):
|
||||
global snap_name
|
||||
self.rbd = RBD()
|
||||
create_image()
|
||||
@ -2546,7 +2553,7 @@ class TestGroups(object):
|
||||
snap_name = get_temp_snap_name()
|
||||
self.group = Group(ioctx, group_name)
|
||||
|
||||
def tearDown(self):
|
||||
def teardown_method(self, method):
|
||||
remove_group()
|
||||
self.image = None
|
||||
for name in self.image_names:
|
||||
@ -2703,11 +2710,6 @@ class TestGroups(object):
|
||||
self.group.remove_snap(snap_name)
|
||||
eq([], list(self.group.list_snaps()))
|
||||
|
||||
@with_setup(create_image, remove_image)
|
||||
def test_rename():
|
||||
rbd = RBD()
|
||||
image_name2 = get_temp_image_name()
|
||||
|
||||
class TestMigration(object):
|
||||
|
||||
def test_migration(self):
|
||||
|
Loading…
Reference in New Issue
Block a user