No longer import nose
Since Python 2.7, unittest in the standard library has included mulitple facilities for skipping tests by decorators as well as an exception. Switch to that directly, rather than importing nose. Change-Id: I4009033473ea24f0d0faed3670db844f40051f30
This commit is contained in:
parent
13116fefd8
commit
5a06e3da3b
@ -103,8 +103,8 @@ swift_test_domain = ['', '', '', '', '', '']
|
|||||||
swift_test_user_id = ['', '', '', '', '', '']
|
swift_test_user_id = ['', '', '', '', '', '']
|
||||||
swift_test_tenant_id = ['', '', '', '', '', '']
|
swift_test_tenant_id = ['', '', '', '', '', '']
|
||||||
|
|
||||||
skip, skip2, skip3, skip_service_tokens, skip_if_no_reseller_admin = \
|
skip, skip2, skip3, skip_if_not_v3, skip_service_tokens, \
|
||||||
False, False, False, False, False
|
skip_if_no_reseller_admin = False, False, False, False, False, False
|
||||||
|
|
||||||
orig_collate = ''
|
orig_collate = ''
|
||||||
insecure = False
|
insecure = False
|
||||||
|
@ -20,7 +20,6 @@ import uuid
|
|||||||
from random import shuffle
|
from random import shuffle
|
||||||
|
|
||||||
from keystoneclient.v3 import client
|
from keystoneclient.v3 import client
|
||||||
from nose import SkipTest
|
|
||||||
from swiftclient import get_auth, http_connection
|
from swiftclient import get_auth, http_connection
|
||||||
|
|
||||||
import test.functional as tf
|
import test.functional as tf
|
||||||
@ -3223,7 +3222,7 @@ class TestRBAC(BaseTestAC):
|
|||||||
def test_rbac(self):
|
def test_rbac(self):
|
||||||
if any((tf.skip, tf.skip2, tf.skip3, tf.skip_if_not_v3,
|
if any((tf.skip, tf.skip2, tf.skip3, tf.skip_if_not_v3,
|
||||||
tf.skip_if_no_reseller_admin)):
|
tf.skip_if_no_reseller_admin)):
|
||||||
raise SkipTest
|
raise unittest.SkipTest
|
||||||
scenario_rbac = RBAC_PUT + RBAC_DELETE + RBAC_GET +\
|
scenario_rbac = RBAC_PUT + RBAC_DELETE + RBAC_GET +\
|
||||||
RBAC_HEAD + RBAC_POST + RBAC_OPTIONS
|
RBAC_HEAD + RBAC_POST + RBAC_OPTIONS
|
||||||
shuffle(scenario_rbac)
|
shuffle(scenario_rbac)
|
||||||
@ -3232,7 +3231,7 @@ class TestRBAC(BaseTestAC):
|
|||||||
def test_rbac_with_service_prefix(self):
|
def test_rbac_with_service_prefix(self):
|
||||||
if any((tf.skip, tf.skip2, tf.skip3, tf.skip_if_not_v3,
|
if any((tf.skip, tf.skip2, tf.skip3, tf.skip_if_not_v3,
|
||||||
tf.skip_service_tokens, tf.skip_if_no_reseller_admin)):
|
tf.skip_service_tokens, tf.skip_if_no_reseller_admin)):
|
||||||
raise SkipTest
|
raise unittest.SkipTest
|
||||||
scenario_rbac = RBAC_PUT_WITH_SERVICE_PREFIX +\
|
scenario_rbac = RBAC_PUT_WITH_SERVICE_PREFIX +\
|
||||||
RBAC_DELETE_WITH_SERVICE_PREFIX +\
|
RBAC_DELETE_WITH_SERVICE_PREFIX +\
|
||||||
RBAC_GET_WITH_SERVICE_PREFIX +\
|
RBAC_GET_WITH_SERVICE_PREFIX +\
|
||||||
@ -3271,7 +3270,7 @@ class TestRBACInfo(BaseTestAC):
|
|||||||
def test_rbac_info(self):
|
def test_rbac_info(self):
|
||||||
if any((tf.skip, tf.skip2, tf.skip3, tf.skip_if_not_v3,
|
if any((tf.skip, tf.skip2, tf.skip3, tf.skip_if_not_v3,
|
||||||
tf.skip_if_no_reseller_admin)):
|
tf.skip_if_no_reseller_admin)):
|
||||||
raise SkipTest
|
raise unittest.SkipTest
|
||||||
self.info_url = self._get_info_url()
|
self.info_url = self._get_info_url()
|
||||||
scenario_rbac_info = RBAC_INFO_GET + RBAC_INFO_HEAD + RBAC_INFO_OPTIONS
|
scenario_rbac_info = RBAC_INFO_GET + RBAC_INFO_HEAD + RBAC_INFO_OPTIONS
|
||||||
shuffle(scenario_rbac_info)
|
shuffle(scenario_rbac_info)
|
||||||
@ -3280,7 +3279,7 @@ class TestRBACInfo(BaseTestAC):
|
|||||||
def test_rbac_info_with_service_prefix(self):
|
def test_rbac_info_with_service_prefix(self):
|
||||||
if any((tf.skip, tf.skip2, tf.skip3, tf.skip_if_not_v3,
|
if any((tf.skip, tf.skip2, tf.skip3, tf.skip_if_not_v3,
|
||||||
tf.skip_service_tokens, tf.skip_if_no_reseller_admin)):
|
tf.skip_service_tokens, tf.skip_if_no_reseller_admin)):
|
||||||
raise SkipTest
|
raise unittest.SkipTest
|
||||||
self.info_url = self._get_info_url()
|
self.info_url = self._get_info_url()
|
||||||
scenario_rbac_info = RBAC_INFO_GET_WITH_SERVICE_PREFIX +\
|
scenario_rbac_info = RBAC_INFO_GET_WITH_SERVICE_PREFIX +\
|
||||||
RBAC_INFO_HEAD_WITH_SERVICE_PREFIX +\
|
RBAC_INFO_HEAD_WITH_SERVICE_PREFIX +\
|
||||||
@ -3302,7 +3301,7 @@ class TestContainerACL(BaseTestAC):
|
|||||||
def test_container_acl(self):
|
def test_container_acl(self):
|
||||||
if any((tf.skip, tf.skip2, tf.skip3, tf.skip_if_not_v3,
|
if any((tf.skip, tf.skip2, tf.skip3, tf.skip_if_not_v3,
|
||||||
tf.skip_if_no_reseller_admin)):
|
tf.skip_if_no_reseller_admin)):
|
||||||
raise SkipTest
|
raise unittest.SkipTest
|
||||||
self.id_info = KeystoneClient().get_id_info()
|
self.id_info = KeystoneClient().get_id_info()
|
||||||
scenario_container_acl = ACL_PUT + ACL_DELETE + ACL_GET +\
|
scenario_container_acl = ACL_PUT + ACL_DELETE + ACL_GET +\
|
||||||
ACL_HEAD + ACL_POST + ACL_OPTIONS
|
ACL_HEAD + ACL_POST + ACL_OPTIONS
|
||||||
|
@ -24,7 +24,6 @@ from collections import defaultdict
|
|||||||
import unittest
|
import unittest
|
||||||
from hashlib import md5
|
from hashlib import md5
|
||||||
from uuid import uuid4
|
from uuid import uuid4
|
||||||
from nose import SkipTest
|
|
||||||
|
|
||||||
from six.moves.http_client import HTTPConnection
|
from six.moves.http_client import HTTPConnection
|
||||||
import shutil
|
import shutil
|
||||||
@ -204,12 +203,12 @@ def get_ring(ring_name, required_replicas, required_devices,
|
|||||||
return ring
|
return ring
|
||||||
# easy sanity checks
|
# easy sanity checks
|
||||||
if ring.replica_count != required_replicas:
|
if ring.replica_count != required_replicas:
|
||||||
raise SkipTest('%s has %s replicas instead of %s' % (
|
raise unittest.SkipTest('%s has %s replicas instead of %s' % (
|
||||||
ring.serialized_path, ring.replica_count, required_replicas))
|
ring.serialized_path, ring.replica_count, required_replicas))
|
||||||
|
|
||||||
devs = [dev for dev in ring.devs if dev is not None]
|
devs = [dev for dev in ring.devs if dev is not None]
|
||||||
if len(devs) != required_devices:
|
if len(devs) != required_devices:
|
||||||
raise SkipTest('%s has %s devices instead of %s' % (
|
raise unittest.SkipTest('%s has %s devices instead of %s' % (
|
||||||
ring.serialized_path, len(devs), required_devices))
|
ring.serialized_path, len(devs), required_devices))
|
||||||
for dev in devs:
|
for dev in devs:
|
||||||
# verify server is exposing mounted device
|
# verify server is exposing mounted device
|
||||||
@ -221,12 +220,12 @@ def get_ring(ring_name, required_replicas, required_devices,
|
|||||||
dev_path = os.path.join(conf['devices'], device)
|
dev_path = os.path.join(conf['devices'], device)
|
||||||
full_path = os.path.realpath(dev_path)
|
full_path = os.path.realpath(dev_path)
|
||||||
if not os.path.exists(full_path):
|
if not os.path.exists(full_path):
|
||||||
raise SkipTest(
|
raise unittest.SkipTest(
|
||||||
'device %s in %s was not found (%s)' %
|
'device %s in %s was not found (%s)' %
|
||||||
(device, conf['devices'], full_path))
|
(device, conf['devices'], full_path))
|
||||||
break
|
break
|
||||||
else:
|
else:
|
||||||
raise SkipTest(
|
raise unittest.SkipTest(
|
||||||
"unable to find ring device %s under %s's devices (%s)" % (
|
"unable to find ring device %s under %s's devices (%s)" % (
|
||||||
dev['device'], server, conf['devices']))
|
dev['device'], server, conf['devices']))
|
||||||
# verify server is exposing rsync device
|
# verify server is exposing rsync device
|
||||||
@ -237,14 +236,14 @@ def get_ring(ring_name, required_replicas, required_devices,
|
|||||||
p = Popen(cmd, shell=True, stdout=PIPE)
|
p = Popen(cmd, shell=True, stdout=PIPE)
|
||||||
stdout, _stderr = p.communicate()
|
stdout, _stderr = p.communicate()
|
||||||
if p.returncode:
|
if p.returncode:
|
||||||
raise SkipTest('unable to connect to rsync '
|
raise unittest.SkipTest('unable to connect to rsync '
|
||||||
'export %s (%s)' % (rsync_export, cmd))
|
'export %s (%s)' % (rsync_export, cmd))
|
||||||
for line in stdout.splitlines():
|
for line in stdout.splitlines():
|
||||||
if line.rsplit(None, 1)[-1] == dev['device']:
|
if line.rsplit(None, 1)[-1] == dev['device']:
|
||||||
break
|
break
|
||||||
else:
|
else:
|
||||||
raise SkipTest("unable to find ring device %s under rsync's "
|
raise unittest.SkipTest("unable to find ring device %s under "
|
||||||
"exported devices for %s (%s)" %
|
"rsync's exported devices for %s (%s)" %
|
||||||
(dev['device'], rsync_export, cmd))
|
(dev['device'], rsync_export, cmd))
|
||||||
return ring
|
return ring
|
||||||
|
|
||||||
@ -264,7 +263,7 @@ def get_policy(**kwargs):
|
|||||||
matches = False
|
matches = False
|
||||||
if matches:
|
if matches:
|
||||||
return policy
|
return policy
|
||||||
raise SkipTest('No policy matching %s' % kwargs)
|
raise unittest.SkipTest('No policy matching %s' % kwargs)
|
||||||
|
|
||||||
|
|
||||||
def resetswift():
|
def resetswift():
|
||||||
@ -501,13 +500,13 @@ if __name__ == "__main__":
|
|||||||
try:
|
try:
|
||||||
get_ring(server, 3, 4,
|
get_ring(server, 3, 4,
|
||||||
force_validate=True)
|
force_validate=True)
|
||||||
except SkipTest as err:
|
except unittest.SkipTest as err:
|
||||||
sys.exit('%s ERROR: %s' % (server, err))
|
sys.exit('%s ERROR: %s' % (server, err))
|
||||||
print('%s OK' % server)
|
print('%s OK' % server)
|
||||||
for policy in POLICIES:
|
for policy in POLICIES:
|
||||||
try:
|
try:
|
||||||
get_ring(policy.ring_name, 3, 4,
|
get_ring(policy.ring_name, 3, 4,
|
||||||
server='object', force_validate=True)
|
server='object', force_validate=True)
|
||||||
except SkipTest as err:
|
except unittest.SkipTest as err:
|
||||||
sys.exit('object ERROR (%s): %s' % (policy.name, err))
|
sys.exit('object ERROR (%s): %s' % (policy.name, err))
|
||||||
print('object OK (%s)' % policy.name)
|
print('object OK (%s)' % policy.name)
|
||||||
|
@ -18,8 +18,6 @@ import uuid
|
|||||||
import random
|
import random
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from nose import SkipTest
|
|
||||||
|
|
||||||
from six.moves.urllib.parse import urlparse
|
from six.moves.urllib.parse import urlparse
|
||||||
from swift.common.manager import Manager
|
from swift.common.manager import Manager
|
||||||
from swift.common.internal_client import InternalClient
|
from swift.common.internal_client import InternalClient
|
||||||
@ -37,9 +35,8 @@ TIMEOUT = 60
|
|||||||
|
|
||||||
class TestContainerMergePolicyIndex(ReplProbeTest):
|
class TestContainerMergePolicyIndex(ReplProbeTest):
|
||||||
|
|
||||||
|
@unittest.skipIf(len(ENABLED_POLICIES) < 2, "Need more than one policy")
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
if len(ENABLED_POLICIES) < 2:
|
|
||||||
raise SkipTest('Need more than one policy')
|
|
||||||
super(TestContainerMergePolicyIndex, self).setUp()
|
super(TestContainerMergePolicyIndex, self).setUp()
|
||||||
self.container_name = 'container-%s' % uuid.uuid4()
|
self.container_name = 'container-%s' % uuid.uuid4()
|
||||||
self.object_name = 'object-%s' % uuid.uuid4()
|
self.object_name = 'object-%s' % uuid.uuid4()
|
||||||
@ -247,10 +244,10 @@ class TestContainerMergePolicyIndex(ReplProbeTest):
|
|||||||
urlparse(self.url).netloc)
|
urlparse(self.url).netloc)
|
||||||
proxy_conn = client.http_connection(info_url)
|
proxy_conn = client.http_connection(info_url)
|
||||||
cluster_info = client.get_capabilities(proxy_conn)
|
cluster_info = client.get_capabilities(proxy_conn)
|
||||||
if 'slo' not in cluster_info:
|
|
||||||
raise SkipTest("SLO not enabled in proxy; "
|
|
||||||
"can't test manifest reconciliation")
|
|
||||||
|
|
||||||
|
if 'slo' not in cluster_info:
|
||||||
|
raise unittest.SkipTest(
|
||||||
|
"SLO not enabled in proxy; can't test manifest reconciliation")
|
||||||
# this test is not only testing a split brain scenario on
|
# this test is not only testing a split brain scenario on
|
||||||
# multiple policies with mis-placed objects - it even writes out
|
# multiple policies with mis-placed objects - it even writes out
|
||||||
# a static large object directly to the storage nodes while the
|
# a static large object directly to the storage nodes while the
|
||||||
|
@ -14,7 +14,6 @@
|
|||||||
import json
|
import json
|
||||||
import uuid
|
import uuid
|
||||||
import random
|
import random
|
||||||
from nose import SkipTest
|
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from six.moves.urllib.parse import urlparse
|
from six.moves.urllib.parse import urlparse
|
||||||
@ -33,16 +32,16 @@ def get_current_realm_cluster(url):
|
|||||||
try:
|
try:
|
||||||
info = client.get_capabilities(http_conn)
|
info = client.get_capabilities(http_conn)
|
||||||
except client.ClientException:
|
except client.ClientException:
|
||||||
raise SkipTest('Unable to retrieve cluster info')
|
raise unittest.SkipTest('Unable to retrieve cluster info')
|
||||||
try:
|
try:
|
||||||
realms = info['container_sync']['realms']
|
realms = info['container_sync']['realms']
|
||||||
except KeyError:
|
except KeyError:
|
||||||
raise SkipTest('Unable to find container sync realms')
|
raise unittest.SkipTest('Unable to find container sync realms')
|
||||||
for realm, realm_info in realms.items():
|
for realm, realm_info in realms.items():
|
||||||
for cluster, options in realm_info['clusters'].items():
|
for cluster, options in realm_info['clusters'].items():
|
||||||
if options.get('current', False):
|
if options.get('current', False):
|
||||||
return realm, cluster
|
return realm, cluster
|
||||||
raise SkipTest('Unable find current realm cluster')
|
raise unittest.SkipTest('Unable find current realm cluster')
|
||||||
|
|
||||||
|
|
||||||
class TestContainerSync(ReplProbeTest):
|
class TestContainerSync(ReplProbeTest):
|
||||||
|
@ -15,11 +15,9 @@
|
|||||||
# limitations under the License.
|
# limitations under the License.
|
||||||
|
|
||||||
from io import StringIO
|
from io import StringIO
|
||||||
from unittest import main
|
from unittest import main, SkipTest
|
||||||
from uuid import uuid4
|
from uuid import uuid4
|
||||||
|
|
||||||
from nose import SkipTest
|
|
||||||
|
|
||||||
from swiftclient import client
|
from swiftclient import client
|
||||||
from swiftclient.exceptions import ClientException
|
from swiftclient.exceptions import ClientException
|
||||||
|
|
||||||
@ -65,7 +63,7 @@ class TestObjectAsyncUpdate(ReplProbeTest):
|
|||||||
# In this test, we need to put container at handoff devices, so we
|
# In this test, we need to put container at handoff devices, so we
|
||||||
# need container devices more than replica count
|
# need container devices more than replica count
|
||||||
if len(self.container_ring.devs) <= self.container_ring.replica_count:
|
if len(self.container_ring.devs) <= self.container_ring.replica_count:
|
||||||
raise SkipTest('Need devices more that replica count')
|
raise SkipTest("Need devices more that replica count")
|
||||||
|
|
||||||
container = 'container-%s' % uuid4()
|
container = 'container-%s' % uuid4()
|
||||||
cpart, cnodes = self.container_ring.get_nodes(self.account, container)
|
cpart, cnodes = self.container_ring.get_nodes(self.account, container)
|
||||||
|
@ -17,8 +17,6 @@ import time
|
|||||||
import uuid
|
import uuid
|
||||||
import unittest
|
import unittest
|
||||||
|
|
||||||
from nose import SkipTest
|
|
||||||
|
|
||||||
from swift.common.internal_client import InternalClient, UnexpectedResponse
|
from swift.common.internal_client import InternalClient, UnexpectedResponse
|
||||||
from swift.common.manager import Manager
|
from swift.common.manager import Manager
|
||||||
from swift.common.utils import Timestamp
|
from swift.common.utils import Timestamp
|
||||||
@ -36,7 +34,7 @@ class TestObjectExpirer(ReplProbeTest):
|
|||||||
self.expirer.start()
|
self.expirer.start()
|
||||||
err = self.expirer.stop()
|
err = self.expirer.stop()
|
||||||
if err:
|
if err:
|
||||||
raise SkipTest('Unable to verify object-expirer service')
|
raise unittest.SkipTest('Unable to verify object-expirer service')
|
||||||
|
|
||||||
conf_files = []
|
conf_files = []
|
||||||
for server in self.expirer.servers:
|
for server in self.expirer.servers:
|
||||||
@ -59,10 +57,8 @@ class TestObjectExpirer(ReplProbeTest):
|
|||||||
|
|
||||||
return False
|
return False
|
||||||
|
|
||||||
|
@unittest.skipIf(len(ENABLED_POLICIES) < 2, "Need more than one policy")
|
||||||
def test_expirer_object_split_brain(self):
|
def test_expirer_object_split_brain(self):
|
||||||
if len(ENABLED_POLICIES) < 2:
|
|
||||||
raise SkipTest('Need more than one policy')
|
|
||||||
|
|
||||||
old_policy = random.choice(ENABLED_POLICIES)
|
old_policy = random.choice(ENABLED_POLICIES)
|
||||||
wrong_policy = random.choice([p for p in ENABLED_POLICIES
|
wrong_policy = random.choice([p for p in ENABLED_POLICIES
|
||||||
if p != old_policy])
|
if p != old_policy])
|
||||||
|
@ -15,7 +15,6 @@
|
|||||||
|
|
||||||
import unittest
|
import unittest
|
||||||
import mock
|
import mock
|
||||||
from nose import SkipTest
|
|
||||||
|
|
||||||
try:
|
try:
|
||||||
# this test requires the dnspython package to be installed
|
# this test requires the dnspython package to be installed
|
||||||
@ -50,9 +49,8 @@ def start_response(*args):
|
|||||||
|
|
||||||
class TestCNAMELookup(unittest.TestCase):
|
class TestCNAMELookup(unittest.TestCase):
|
||||||
|
|
||||||
|
@unittest.skipIf(skip, "can't import dnspython")
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
if skip:
|
|
||||||
raise SkipTest
|
|
||||||
self.app = cname_lookup.CNAMELookupMiddleware(FakeApp(),
|
self.app = cname_lookup.CNAMELookupMiddleware(FakeApp(),
|
||||||
{'lookup_depth': 2})
|
{'lookup_depth': 2})
|
||||||
|
|
||||||
|
@ -18,7 +18,6 @@ import json
|
|||||||
import shutil
|
import shutil
|
||||||
import tempfile
|
import tempfile
|
||||||
import unittest
|
import unittest
|
||||||
from nose import SkipTest
|
|
||||||
|
|
||||||
from six import BytesIO
|
from six import BytesIO
|
||||||
|
|
||||||
@ -49,9 +48,8 @@ class FakeApp(object):
|
|||||||
|
|
||||||
class TestXProfile(unittest.TestCase):
|
class TestXProfile(unittest.TestCase):
|
||||||
|
|
||||||
|
@unittest.skipIf(xprofile is None, "can't import xprofile")
|
||||||
def test_get_profiler(self):
|
def test_get_profiler(self):
|
||||||
if xprofile is None:
|
|
||||||
raise SkipTest
|
|
||||||
self.assertTrue(xprofile.get_profiler('cProfile') is not None)
|
self.assertTrue(xprofile.get_profiler('cProfile') is not None)
|
||||||
self.assertTrue(xprofile.get_profiler('eventlet.green.profile')
|
self.assertTrue(xprofile.get_profiler('eventlet.green.profile')
|
||||||
is not None)
|
is not None)
|
||||||
@ -59,9 +57,8 @@ class TestXProfile(unittest.TestCase):
|
|||||||
|
|
||||||
class TestProfilers(unittest.TestCase):
|
class TestProfilers(unittest.TestCase):
|
||||||
|
|
||||||
|
@unittest.skipIf(xprofile is None, "can't import xprofile")
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
if xprofile is None:
|
|
||||||
raise SkipTest
|
|
||||||
self.profilers = [xprofile.get_profiler('cProfile'),
|
self.profilers = [xprofile.get_profiler('cProfile'),
|
||||||
xprofile.get_profiler('eventlet.green.profile')]
|
xprofile.get_profiler('eventlet.green.profile')]
|
||||||
|
|
||||||
@ -83,9 +80,8 @@ class TestProfilers(unittest.TestCase):
|
|||||||
|
|
||||||
class TestProfileMiddleware(unittest.TestCase):
|
class TestProfileMiddleware(unittest.TestCase):
|
||||||
|
|
||||||
|
@unittest.skipIf(xprofile is None, "can't import xprofile")
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
if xprofile is None:
|
|
||||||
raise SkipTest
|
|
||||||
self.got_statuses = []
|
self.got_statuses = []
|
||||||
self.app = ProfileMiddleware(FakeApp, {})
|
self.app = ProfileMiddleware(FakeApp, {})
|
||||||
self.tempdir = os.path.dirname(self.app.log_filename_prefix)
|
self.tempdir = os.path.dirname(self.app.log_filename_prefix)
|
||||||
@ -191,10 +187,8 @@ class TestProfileMiddleware(unittest.TestCase):
|
|||||||
|
|
||||||
class Test_profile_log(unittest.TestCase):
|
class Test_profile_log(unittest.TestCase):
|
||||||
|
|
||||||
|
@unittest.skipIf(xprofile is None, "can't import xprofile")
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
if xprofile is None:
|
|
||||||
raise SkipTest
|
|
||||||
|
|
||||||
self.dir1 = tempfile.mkdtemp()
|
self.dir1 = tempfile.mkdtemp()
|
||||||
self.log_filename_prefix1 = self.dir1 + '/unittest.profile'
|
self.log_filename_prefix1 = self.dir1 + '/unittest.profile'
|
||||||
self.profile_log1 = ProfileLog(self.log_filename_prefix1, False)
|
self.profile_log1 = ProfileLog(self.log_filename_prefix1, False)
|
||||||
@ -282,9 +276,8 @@ class Test_profile_log(unittest.TestCase):
|
|||||||
|
|
||||||
class Test_html_viewer(unittest.TestCase):
|
class Test_html_viewer(unittest.TestCase):
|
||||||
|
|
||||||
|
@unittest.skipIf(xprofile is None, "can't import xprofile")
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
if xprofile is None:
|
|
||||||
raise SkipTest
|
|
||||||
self.app = ProfileMiddleware(FakeApp, {})
|
self.app = ProfileMiddleware(FakeApp, {})
|
||||||
self.log_files = []
|
self.log_files = []
|
||||||
self.tempdir = tempfile.mkdtemp()
|
self.tempdir = tempfile.mkdtemp()
|
||||||
@ -473,9 +466,8 @@ class Test_html_viewer(unittest.TestCase):
|
|||||||
|
|
||||||
class TestStats2(unittest.TestCase):
|
class TestStats2(unittest.TestCase):
|
||||||
|
|
||||||
|
@unittest.skipIf(xprofile is None, "can't import xprofile")
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
if xprofile is None:
|
|
||||||
raise SkipTest
|
|
||||||
self.profile_file = tempfile.mktemp('profile', 'unittest')
|
self.profile_file = tempfile.mktemp('profile', 'unittest')
|
||||||
self.profilers = [xprofile.get_profiler('cProfile'),
|
self.profilers = [xprofile.get_profiler('cProfile'),
|
||||||
xprofile.get_profiler('eventlet.green.profile')]
|
xprofile.get_profiler('eventlet.green.profile')]
|
||||||
|
@ -25,7 +25,6 @@ import contextlib
|
|||||||
import re
|
import re
|
||||||
|
|
||||||
import mock
|
import mock
|
||||||
import nose
|
|
||||||
import six
|
import six
|
||||||
|
|
||||||
from swift.common.splice import splice, tee
|
from swift.common.splice import splice, tee
|
||||||
@ -73,7 +72,7 @@ class TestSplice(unittest.TestCase):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
if not splice.available:
|
if not splice.available:
|
||||||
raise nose.SkipTest('splice not available')
|
raise unittest.SkipTest('splice not available')
|
||||||
|
|
||||||
def test_flags(self):
|
def test_flags(self):
|
||||||
'''Test flag attribute availability'''
|
'''Test flag attribute availability'''
|
||||||
@ -228,7 +227,7 @@ class TestTee(unittest.TestCase):
|
|||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
if not tee.available:
|
if not tee.available:
|
||||||
raise nose.SkipTest('tee not available')
|
raise unittest.SkipTest('tee not available')
|
||||||
|
|
||||||
@mock.patch('swift.common.splice.tee._c_tee', None)
|
@mock.patch('swift.common.splice.tee._c_tee', None)
|
||||||
def test_available(self):
|
def test_available(self):
|
||||||
|
@ -57,7 +57,6 @@ from functools import partial
|
|||||||
from tempfile import TemporaryFile, NamedTemporaryFile, mkdtemp
|
from tempfile import TemporaryFile, NamedTemporaryFile, mkdtemp
|
||||||
from netifaces import AF_INET6
|
from netifaces import AF_INET6
|
||||||
from mock import MagicMock, patch
|
from mock import MagicMock, patch
|
||||||
from nose import SkipTest
|
|
||||||
from six.moves.configparser import NoSectionError, NoOptionError
|
from six.moves.configparser import NoSectionError, NoOptionError
|
||||||
from uuid import uuid4
|
from uuid import uuid4
|
||||||
|
|
||||||
@ -3697,7 +3696,7 @@ cluster_dfw1 = http://dfw1.host/v1/
|
|||||||
try:
|
try:
|
||||||
utils.NR_ioprio_set()
|
utils.NR_ioprio_set()
|
||||||
except OSError as e:
|
except OSError as e:
|
||||||
raise SkipTest(e)
|
raise unittest.SkipTest(e)
|
||||||
|
|
||||||
with patch('swift.common.utils._libc_setpriority',
|
with patch('swift.common.utils._libc_setpriority',
|
||||||
_fake_setpriority), \
|
_fake_setpriority), \
|
||||||
|
@ -31,7 +31,6 @@ if six.PY2:
|
|||||||
import mimetools
|
import mimetools
|
||||||
|
|
||||||
import mock
|
import mock
|
||||||
import nose
|
|
||||||
|
|
||||||
import swift.common.middleware.catch_errors
|
import swift.common.middleware.catch_errors
|
||||||
import swift.common.middleware.gatekeeper
|
import swift.common.middleware.gatekeeper
|
||||||
@ -75,10 +74,8 @@ class TestWSGI(unittest.TestCase):
|
|||||||
if six.PY2:
|
if six.PY2:
|
||||||
mimetools.Message.parsetype = self._orig_parsetype
|
mimetools.Message.parsetype = self._orig_parsetype
|
||||||
|
|
||||||
|
@unittest.skipIf(six.PY3, "test specific to Python 2")
|
||||||
def test_monkey_patch_mimetools(self):
|
def test_monkey_patch_mimetools(self):
|
||||||
if six.PY3:
|
|
||||||
raise nose.SkipTest('test specific to Python 2')
|
|
||||||
|
|
||||||
sio = StringIO('blah')
|
sio = StringIO('blah')
|
||||||
self.assertEqual(mimetools.Message(sio).type, 'text/plain')
|
self.assertEqual(mimetools.Message(sio).type, 'text/plain')
|
||||||
sio = StringIO('blah')
|
sio = StringIO('blah')
|
||||||
|
@ -46,7 +46,6 @@ from test.unit import (mock as unit_mock, temptree, mock_check_drive,
|
|||||||
make_timestamp_iter, DEFAULT_TEST_EC_TYPE,
|
make_timestamp_iter, DEFAULT_TEST_EC_TYPE,
|
||||||
requires_o_tmpfile_support, encode_frag_archive_bodies,
|
requires_o_tmpfile_support, encode_frag_archive_bodies,
|
||||||
skip_if_no_xattrs)
|
skip_if_no_xattrs)
|
||||||
from nose import SkipTest
|
|
||||||
from swift.obj import diskfile
|
from swift.obj import diskfile
|
||||||
from swift.common import utils
|
from swift.common import utils
|
||||||
from swift.common.utils import hash_path, mkdirs, Timestamp, \
|
from swift.common.utils import hash_path, mkdirs, Timestamp, \
|
||||||
@ -4746,8 +4745,7 @@ class DiskFileMixin(BaseDiskFileTestMixin):
|
|||||||
|
|
||||||
def test_zero_copy_cache_dropping(self):
|
def test_zero_copy_cache_dropping(self):
|
||||||
if not self._system_can_zero_copy():
|
if not self._system_can_zero_copy():
|
||||||
raise SkipTest("zero-copy support is missing")
|
raise unittest.SkipTest("zero-copy support is missing")
|
||||||
|
|
||||||
self.conf['splice'] = 'on'
|
self.conf['splice'] = 'on'
|
||||||
self.conf['keep_cache_size'] = 16384
|
self.conf['keep_cache_size'] = 16384
|
||||||
self.conf['disk_chunk_size'] = 4096
|
self.conf['disk_chunk_size'] = 4096
|
||||||
@ -4767,7 +4765,7 @@ class DiskFileMixin(BaseDiskFileTestMixin):
|
|||||||
|
|
||||||
def test_zero_copy_turns_off_when_md5_sockets_not_supported(self):
|
def test_zero_copy_turns_off_when_md5_sockets_not_supported(self):
|
||||||
if not self._system_can_zero_copy():
|
if not self._system_can_zero_copy():
|
||||||
raise SkipTest("zero-copy support is missing")
|
raise unittest.SkipTest("zero-copy support is missing")
|
||||||
df_mgr = self.df_router[POLICIES.default]
|
df_mgr = self.df_router[POLICIES.default]
|
||||||
self.conf['splice'] = 'on'
|
self.conf['splice'] = 'on'
|
||||||
with mock.patch('swift.obj.diskfile.get_md5_socket') as mock_md5sock:
|
with mock.patch('swift.obj.diskfile.get_md5_socket') as mock_md5sock:
|
||||||
@ -4782,8 +4780,7 @@ class DiskFileMixin(BaseDiskFileTestMixin):
|
|||||||
|
|
||||||
def test_tee_to_md5_pipe_length_mismatch(self):
|
def test_tee_to_md5_pipe_length_mismatch(self):
|
||||||
if not self._system_can_zero_copy():
|
if not self._system_can_zero_copy():
|
||||||
raise SkipTest("zero-copy support is missing")
|
raise unittest.SkipTest("zero-copy support is missing")
|
||||||
|
|
||||||
self.conf['splice'] = 'on'
|
self.conf['splice'] = 'on'
|
||||||
|
|
||||||
df = self._get_open_disk_file(fsize=16385)
|
df = self._get_open_disk_file(fsize=16385)
|
||||||
@ -4805,8 +4802,7 @@ class DiskFileMixin(BaseDiskFileTestMixin):
|
|||||||
|
|
||||||
def test_splice_to_wsockfd_blocks(self):
|
def test_splice_to_wsockfd_blocks(self):
|
||||||
if not self._system_can_zero_copy():
|
if not self._system_can_zero_copy():
|
||||||
raise SkipTest("zero-copy support is missing")
|
raise unittest.SkipTest("zero-copy support is missing")
|
||||||
|
|
||||||
self.conf['splice'] = 'on'
|
self.conf['splice'] = 'on'
|
||||||
|
|
||||||
df = self._get_open_disk_file(fsize=16385)
|
df = self._get_open_disk_file(fsize=16385)
|
||||||
|
@ -39,8 +39,6 @@ from textwrap import dedent
|
|||||||
from eventlet import sleep, spawn, wsgi, Timeout, tpool, greenthread
|
from eventlet import sleep, spawn, wsgi, Timeout, tpool, greenthread
|
||||||
from eventlet.green import httplib
|
from eventlet.green import httplib
|
||||||
|
|
||||||
from nose import SkipTest
|
|
||||||
|
|
||||||
from swift import __version__ as swift_version
|
from swift import __version__ as swift_version
|
||||||
from swift.common.http import is_success
|
from swift.common.http import is_success
|
||||||
from test import listen_zero
|
from test import listen_zero
|
||||||
@ -6408,7 +6406,7 @@ class TestObjectController(unittest.TestCase):
|
|||||||
except NotImplementedError:
|
except NotImplementedError:
|
||||||
# On some operating systems (at a minimum, OS X) it's not possible
|
# On some operating systems (at a minimum, OS X) it's not possible
|
||||||
# to introspect the value of a semaphore
|
# to introspect the value of a semaphore
|
||||||
raise SkipTest
|
raise unittest.SkipTest
|
||||||
else:
|
else:
|
||||||
self.assertEqual(value, 4)
|
self.assertEqual(value, 4)
|
||||||
|
|
||||||
@ -7636,7 +7634,7 @@ class TestZeroCopy(unittest.TestCase):
|
|||||||
def setUp(self):
|
def setUp(self):
|
||||||
skip_if_no_xattrs()
|
skip_if_no_xattrs()
|
||||||
if not self._system_can_zero_copy():
|
if not self._system_can_zero_copy():
|
||||||
raise SkipTest("zero-copy support is missing")
|
raise unittest.SkipTest("zero-copy support is missing")
|
||||||
|
|
||||||
self.testdir = mkdtemp(suffix="obj_server_zero_copy")
|
self.testdir = mkdtemp(suffix="obj_server_zero_copy")
|
||||||
mkdirs(os.path.join(self.testdir, 'sda1', 'tmp'))
|
mkdirs(os.path.join(self.testdir, 'sda1', 'tmp'))
|
||||||
|
Loading…
Reference in New Issue
Block a user