Use utils.ismount in place of os.path.ismount
See comments from: https://review.openstack.org/55991 Change-Id: Ibb4153702b3dc4c60f66abb11cd3fa1953449827 Signed-off-by: Peter Portante <peter.portante@redhat.com>
This commit is contained in:
parent
8255810e7d
commit
b1f51d00cd
@ -28,7 +28,8 @@ from swift.account.backend import AccountBroker
|
|||||||
from swift.common.direct_client import ClientException, \
|
from swift.common.direct_client import ClientException, \
|
||||||
direct_delete_container, direct_delete_object, direct_get_container
|
direct_delete_container, direct_delete_object, direct_get_container
|
||||||
from swift.common.ring import Ring
|
from swift.common.ring import Ring
|
||||||
from swift.common.utils import get_logger, whataremyips, config_true_value
|
from swift.common.utils import get_logger, whataremyips, ismount, \
|
||||||
|
config_true_value
|
||||||
from swift.common.daemon import Daemon
|
from swift.common.daemon import Daemon
|
||||||
|
|
||||||
|
|
||||||
@ -120,7 +121,7 @@ class AccountReaper(Daemon):
|
|||||||
begin = time()
|
begin = time()
|
||||||
try:
|
try:
|
||||||
for device in os.listdir(self.devices):
|
for device in os.listdir(self.devices):
|
||||||
if self.mount_check and not os.path.ismount(
|
if self.mount_check and not ismount(
|
||||||
os.path.join(self.devices, device)):
|
os.path.join(self.devices, device)):
|
||||||
self.logger.increment('errors')
|
self.logger.increment('errors')
|
||||||
self.logger.debug(
|
self.logger.debug(
|
||||||
|
@ -32,7 +32,7 @@ import swift.common.db
|
|||||||
from swift.common.direct_client import quote
|
from swift.common.direct_client import quote
|
||||||
from swift.common.utils import get_logger, whataremyips, storage_directory, \
|
from swift.common.utils import get_logger, whataremyips, storage_directory, \
|
||||||
renamer, mkdirs, lock_parent_directory, config_true_value, \
|
renamer, mkdirs, lock_parent_directory, config_true_value, \
|
||||||
unlink_older_than, dump_recon_cache, rsync_ip
|
unlink_older_than, dump_recon_cache, rsync_ip, ismount
|
||||||
from swift.common import ring
|
from swift.common import ring
|
||||||
from swift.common.http import HTTP_NOT_FOUND, HTTP_INSUFFICIENT_STORAGE
|
from swift.common.http import HTTP_NOT_FOUND, HTTP_INSUFFICIENT_STORAGE
|
||||||
from swift.common.bufferedhttp import BufferedHTTPConnection
|
from swift.common.bufferedhttp import BufferedHTTPConnection
|
||||||
@ -529,7 +529,7 @@ class Replicator(Daemon):
|
|||||||
for node in self.ring.devs:
|
for node in self.ring.devs:
|
||||||
if (node and node['replication_ip'] in ips and
|
if (node and node['replication_ip'] in ips and
|
||||||
node['replication_port'] == self.port):
|
node['replication_port'] == self.port):
|
||||||
if self.mount_check and not os.path.ismount(
|
if self.mount_check and not ismount(
|
||||||
os.path.join(self.root, node['device'])):
|
os.path.join(self.root, node['device'])):
|
||||||
self.logger.warn(
|
self.logger.warn(
|
||||||
_('Skipping %(device)s as it is not mounted') % node)
|
_('Skipping %(device)s as it is not mounted') % node)
|
||||||
@ -580,8 +580,7 @@ class ReplicatorRpc(object):
|
|||||||
return HTTPBadRequest(body='Invalid object type')
|
return HTTPBadRequest(body='Invalid object type')
|
||||||
op = args.pop(0)
|
op = args.pop(0)
|
||||||
drive, partition, hsh = replicate_args
|
drive, partition, hsh = replicate_args
|
||||||
if self.mount_check and \
|
if self.mount_check and not ismount(os.path.join(self.root, drive)):
|
||||||
not os.path.ismount(os.path.join(self.root, drive)):
|
|
||||||
return Response(status='507 %s is not mounted' % drive)
|
return Response(status='507 %s is not mounted' % drive)
|
||||||
db_file = os.path.join(self.root, drive,
|
db_file = os.path.join(self.root, drive,
|
||||||
storage_directory(self.datadir, partition, hsh),
|
storage_directory(self.datadir, partition, hsh),
|
||||||
|
@ -1511,8 +1511,7 @@ def audit_location_generator(devices, datadir, suffix='',
|
|||||||
# randomize devices in case of process restart before sweep completed
|
# randomize devices in case of process restart before sweep completed
|
||||||
shuffle(device_dir)
|
shuffle(device_dir)
|
||||||
for device in device_dir:
|
for device in device_dir:
|
||||||
if mount_check and not \
|
if mount_check and not ismount(os.path.join(devices, device)):
|
||||||
os.path.ismount(os.path.join(devices, device)):
|
|
||||||
if logger:
|
if logger:
|
||||||
logger.debug(
|
logger.debug(
|
||||||
_('Skipping %s as it is not mounted'), device)
|
_('Skipping %s as it is not mounted'), device)
|
||||||
|
@ -30,7 +30,8 @@ from swift.container.server import DATADIR
|
|||||||
from swift.common.bufferedhttp import http_connect
|
from swift.common.bufferedhttp import http_connect
|
||||||
from swift.common.exceptions import ConnectionTimeout
|
from swift.common.exceptions import ConnectionTimeout
|
||||||
from swift.common.ring import Ring
|
from swift.common.ring import Ring
|
||||||
from swift.common.utils import get_logger, config_true_value, dump_recon_cache
|
from swift.common.utils import get_logger, config_true_value, ismount, \
|
||||||
|
dump_recon_cache
|
||||||
from swift.common.daemon import Daemon
|
from swift.common.daemon import Daemon
|
||||||
from swift.common.http import is_success, HTTP_INTERNAL_SERVER_ERROR
|
from swift.common.http import is_success, HTTP_INTERNAL_SERVER_ERROR
|
||||||
|
|
||||||
@ -79,7 +80,7 @@ class ContainerUpdater(Daemon):
|
|||||||
paths = []
|
paths = []
|
||||||
for device in os.listdir(self.devices):
|
for device in os.listdir(self.devices):
|
||||||
dev_path = os.path.join(self.devices, device)
|
dev_path = os.path.join(self.devices, device)
|
||||||
if self.mount_check and not os.path.ismount(dev_path):
|
if self.mount_check and not ismount(dev_path):
|
||||||
self.logger.warn(_('%s is not mounted'), device)
|
self.logger.warn(_('%s is not mounted'), device)
|
||||||
continue
|
continue
|
||||||
con_path = os.path.join(dev_path, DATADIR)
|
con_path = os.path.join(dev_path, DATADIR)
|
||||||
|
@ -53,7 +53,7 @@ from swift.common.constraints import check_mount
|
|||||||
from swift.common.utils import mkdirs, normalize_timestamp, \
|
from swift.common.utils import mkdirs, normalize_timestamp, \
|
||||||
storage_directory, hash_path, renamer, fallocate, fsync, \
|
storage_directory, hash_path, renamer, fallocate, fsync, \
|
||||||
fdatasync, drop_buffer_cache, ThreadPool, lock_path, write_pickle, \
|
fdatasync, drop_buffer_cache, ThreadPool, lock_path, write_pickle, \
|
||||||
config_true_value, listdir, split_path
|
config_true_value, listdir, split_path, ismount
|
||||||
from swift.common.exceptions import DiskFileQuarantined, DiskFileNotExist, \
|
from swift.common.exceptions import DiskFileQuarantined, DiskFileNotExist, \
|
||||||
DiskFileCollision, DiskFileNoSpace, DiskFileDeviceUnavailable, \
|
DiskFileCollision, DiskFileNoSpace, DiskFileDeviceUnavailable, \
|
||||||
DiskFileDeleted, DiskFileError, DiskFileNotOpen, PathNotDir
|
DiskFileDeleted, DiskFileError, DiskFileNotOpen, PathNotDir
|
||||||
@ -324,7 +324,7 @@ def object_audit_location_generator(devices, mount_check=True, logger=None):
|
|||||||
shuffle(device_dirs)
|
shuffle(device_dirs)
|
||||||
for device in device_dirs:
|
for device in device_dirs:
|
||||||
if mount_check and not \
|
if mount_check and not \
|
||||||
os.path.ismount(os.path.join(devices, device)):
|
ismount(os.path.join(devices, device)):
|
||||||
if logger:
|
if logger:
|
||||||
logger.debug(
|
logger.debug(
|
||||||
_('Skipping %s as it is not mounted'), device)
|
_('Skipping %s as it is not mounted'), device)
|
||||||
|
@ -29,7 +29,7 @@ from eventlet.support.greenlets import GreenletExit
|
|||||||
|
|
||||||
from swift.common.ring import Ring
|
from swift.common.ring import Ring
|
||||||
from swift.common.utils import whataremyips, unlink_older_than, \
|
from swift.common.utils import whataremyips, unlink_older_than, \
|
||||||
compute_eta, get_logger, dump_recon_cache, \
|
compute_eta, get_logger, dump_recon_cache, ismount, \
|
||||||
rsync_ip, mkdirs, config_true_value, list_from_csv, get_hub, \
|
rsync_ip, mkdirs, config_true_value, list_from_csv, get_hub, \
|
||||||
tpool_reraise, config_auto_int_value
|
tpool_reraise, config_auto_int_value
|
||||||
from swift.common.bufferedhttp import http_connect
|
from swift.common.bufferedhttp import http_connect
|
||||||
@ -407,7 +407,7 @@ class ObjectReplicator(Daemon):
|
|||||||
dev_path = join(self.devices_dir, local_dev['device'])
|
dev_path = join(self.devices_dir, local_dev['device'])
|
||||||
obj_path = join(dev_path, 'objects')
|
obj_path = join(dev_path, 'objects')
|
||||||
tmp_path = join(dev_path, 'tmp')
|
tmp_path = join(dev_path, 'tmp')
|
||||||
if self.mount_check and not os.path.ismount(dev_path):
|
if self.mount_check and not ismount(dev_path):
|
||||||
self.logger.warn(_('%s is not mounted'), local_dev['device'])
|
self.logger.warn(_('%s is not mounted'), local_dev['device'])
|
||||||
continue
|
continue
|
||||||
unlink_older_than(tmp_path, time.time() - self.reclaim_age)
|
unlink_older_than(tmp_path, time.time() - self.reclaim_age)
|
||||||
@ -475,7 +475,7 @@ class ObjectReplicator(Daemon):
|
|||||||
job['partition'] not in override_partitions:
|
job['partition'] not in override_partitions:
|
||||||
continue
|
continue
|
||||||
dev_path = join(self.devices_dir, job['device'])
|
dev_path = join(self.devices_dir, job['device'])
|
||||||
if self.mount_check and not os.path.ismount(dev_path):
|
if self.mount_check and not ismount(dev_path):
|
||||||
self.logger.warn(_('%s is not mounted'), job['device'])
|
self.logger.warn(_('%s is not mounted'), job['device'])
|
||||||
continue
|
continue
|
||||||
if not self.check_ring():
|
if not self.check_ring():
|
||||||
|
@ -27,7 +27,7 @@ from swift.common.bufferedhttp import http_connect
|
|||||||
from swift.common.exceptions import ConnectionTimeout
|
from swift.common.exceptions import ConnectionTimeout
|
||||||
from swift.common.ring import Ring
|
from swift.common.ring import Ring
|
||||||
from swift.common.utils import get_logger, renamer, write_pickle, \
|
from swift.common.utils import get_logger, renamer, write_pickle, \
|
||||||
dump_recon_cache, config_true_value
|
dump_recon_cache, config_true_value, ismount
|
||||||
from swift.common.daemon import Daemon
|
from swift.common.daemon import Daemon
|
||||||
from swift.obj.diskfile import ASYNCDIR
|
from swift.obj.diskfile import ASYNCDIR
|
||||||
from swift.common.http import is_success, HTTP_NOT_FOUND, \
|
from swift.common.http import is_success, HTTP_NOT_FOUND, \
|
||||||
@ -72,7 +72,7 @@ class ObjectUpdater(Daemon):
|
|||||||
self.get_container_ring().get_nodes('')
|
self.get_container_ring().get_nodes('')
|
||||||
for device in os.listdir(self.devices):
|
for device in os.listdir(self.devices):
|
||||||
if self.mount_check and not \
|
if self.mount_check and not \
|
||||||
os.path.ismount(os.path.join(self.devices, device)):
|
ismount(os.path.join(self.devices, device)):
|
||||||
self.logger.increment('errors')
|
self.logger.increment('errors')
|
||||||
self.logger.warn(
|
self.logger.warn(
|
||||||
_('Skipping %s as it is not mounted'), device)
|
_('Skipping %s as it is not mounted'), device)
|
||||||
@ -115,7 +115,7 @@ class ObjectUpdater(Daemon):
|
|||||||
self.failures = 0
|
self.failures = 0
|
||||||
for device in os.listdir(self.devices):
|
for device in os.listdir(self.devices):
|
||||||
if self.mount_check and \
|
if self.mount_check and \
|
||||||
not os.path.ismount(os.path.join(self.devices, device)):
|
ismount(os.path.join(self.devices, device)):
|
||||||
self.logger.increment('errors')
|
self.logger.increment('errors')
|
||||||
self.logger.warn(
|
self.logger.warn(
|
||||||
_('Skipping %s as it is not mounted'), device)
|
_('Skipping %s as it is not mounted'), device)
|
||||||
|
@ -24,7 +24,7 @@ from time import sleep, time
|
|||||||
from swiftclient import get_auth, head_account
|
from swiftclient import get_auth, head_account
|
||||||
|
|
||||||
from swift.common.ring import Ring
|
from swift.common.ring import Ring
|
||||||
from swift.common.utils import readconf
|
from swift.common.utils import readconf, ismount
|
||||||
|
|
||||||
from test.probe import CHECK_SERVER_TIMEOUT, VALIDATE_RSYNC
|
from test.probe import CHECK_SERVER_TIMEOUT, VALIDATE_RSYNC
|
||||||
|
|
||||||
@ -154,7 +154,7 @@ def get_ring(server, force_validate=None):
|
|||||||
for device in os.listdir(conf['devices']):
|
for device in os.listdir(conf['devices']):
|
||||||
if device == dev['device']:
|
if device == dev['device']:
|
||||||
full_path = path.realpath(path.join(conf['devices'], device))
|
full_path = path.realpath(path.join(conf['devices'], device))
|
||||||
assert path.ismount(full_path), \
|
assert ismount(full_path), \
|
||||||
'device %s in %s was not mounted (%s)' % (
|
'device %s in %s was not mounted (%s)' % (
|
||||||
device, conf['devices'], full_path)
|
device, conf['devices'], full_path)
|
||||||
break
|
break
|
||||||
|
@ -448,13 +448,13 @@ class TestReaper(unittest.TestCase):
|
|||||||
devices = prepare_data_dir()
|
devices = prepare_data_dir()
|
||||||
r = init_reaper(devices)
|
r = init_reaper(devices)
|
||||||
|
|
||||||
with patch('swift.account.reaper.os.path.ismount', lambda x: True):
|
with patch('swift.account.reaper.ismount', lambda x: True):
|
||||||
with patch(
|
with patch(
|
||||||
'swift.account.reaper.AccountReaper.reap_device') as foo:
|
'swift.account.reaper.AccountReaper.reap_device') as foo:
|
||||||
r.run_once()
|
r.run_once()
|
||||||
self.assertEqual(foo.called, 1)
|
self.assertEqual(foo.called, 1)
|
||||||
|
|
||||||
with patch('swift.account.reaper.os.path.ismount', lambda x: False):
|
with patch('swift.account.reaper.ismount', lambda x: False):
|
||||||
with patch(
|
with patch(
|
||||||
'swift.account.reaper.AccountReaper.reap_device') as foo:
|
'swift.account.reaper.AccountReaper.reap_device') as foo:
|
||||||
r.run_once()
|
r.run_once()
|
||||||
|
@ -166,15 +166,10 @@ class TestDatabaseBroker(unittest.TestCase):
|
|||||||
with broker.get() as conn:
|
with broker.get() as conn:
|
||||||
conn.execute('SELECT * FROM outgoing_sync')
|
conn.execute('SELECT * FROM outgoing_sync')
|
||||||
conn.execute('SELECT * FROM incoming_sync')
|
conn.execute('SELECT * FROM incoming_sync')
|
||||||
|
broker = DatabaseBroker(os.path.join(self.testdir, '1.db'))
|
||||||
def my_ismount(*a, **kw):
|
broker._initialize = stub
|
||||||
return True
|
self.assertRaises(DatabaseAlreadyExists,
|
||||||
|
broker.initialize, normalize_timestamp('1'))
|
||||||
with patch('os.path.ismount', my_ismount):
|
|
||||||
broker = DatabaseBroker(os.path.join(self.testdir, '1.db'))
|
|
||||||
broker._initialize = stub
|
|
||||||
self.assertRaises(DatabaseAlreadyExists,
|
|
||||||
broker.initialize, normalize_timestamp('1'))
|
|
||||||
|
|
||||||
def test_delete_db(self):
|
def test_delete_db(self):
|
||||||
def init_stub(conn, put_timestamp):
|
def init_stub(conn, put_timestamp):
|
||||||
|
@ -414,7 +414,7 @@ class TestObjectAuditLocationGenerator(unittest.TestCase):
|
|||||||
def mock_ismount(path):
|
def mock_ismount(path):
|
||||||
return path.endswith('sdp')
|
return path.endswith('sdp')
|
||||||
|
|
||||||
with mock.patch('os.path.ismount', mock_ismount):
|
with mock.patch('swift.obj.diskfile.ismount', mock_ismount):
|
||||||
with temptree([]) as tmpdir:
|
with temptree([]) as tmpdir:
|
||||||
os.makedirs(os.path.join(tmpdir, "sdp", "objects",
|
os.makedirs(os.path.join(tmpdir, "sdp", "objects",
|
||||||
"2607", "df3",
|
"2607", "df3",
|
||||||
|
Loading…
x
Reference in New Issue
Block a user