Merge "Add FakeBackup class and updata backup unittest in volumeV2"
This commit is contained in:
commit
dcc8256982
openstackclient/tests/volume/v2
@ -498,3 +498,57 @@ class FakeAvailabilityZone(object):
|
|||||||
availability_zones.append(availability_zone)
|
availability_zones.append(availability_zone)
|
||||||
|
|
||||||
return availability_zones
|
return availability_zones
|
||||||
|
|
||||||
|
|
||||||
|
class FakeBackup(object):
|
||||||
|
"""Fake one or more backup."""
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def create_one_backup(attrs=None):
|
||||||
|
"""Create a fake backup.
|
||||||
|
|
||||||
|
:param Dictionary attrs:
|
||||||
|
A dictionary with all attributes
|
||||||
|
:return:
|
||||||
|
A FakeResource object with id, name, volume_id, etc.
|
||||||
|
"""
|
||||||
|
attrs = attrs or {}
|
||||||
|
|
||||||
|
# Set default attributes.
|
||||||
|
backup_info = {
|
||||||
|
"id": 'backup-id-' + uuid.uuid4().hex,
|
||||||
|
"name": 'backup-name-' + uuid.uuid4().hex,
|
||||||
|
"volume_id": 'volume-id-' + uuid.uuid4().hex,
|
||||||
|
"description": 'description-' + uuid.uuid4().hex,
|
||||||
|
"object_count": None,
|
||||||
|
"container": 'container-' + uuid.uuid4().hex,
|
||||||
|
"size": random.randint(1, 20),
|
||||||
|
"status": "error",
|
||||||
|
"availability_zone": 'zone' + uuid.uuid4().hex,
|
||||||
|
}
|
||||||
|
|
||||||
|
# Overwrite default attributes.
|
||||||
|
backup_info.update(attrs)
|
||||||
|
|
||||||
|
backup = fakes.FakeResource(
|
||||||
|
info=copy.deepcopy(backup_info),
|
||||||
|
loaded=True)
|
||||||
|
return backup
|
||||||
|
|
||||||
|
@staticmethod
|
||||||
|
def create_backups(attrs=None, count=2):
|
||||||
|
"""Create multiple fake backups.
|
||||||
|
|
||||||
|
:param Dictionary attrs:
|
||||||
|
A dictionary with all attributes
|
||||||
|
:param int count:
|
||||||
|
The number of backups to fake
|
||||||
|
:return:
|
||||||
|
A list of FakeResource objects faking the backups
|
||||||
|
"""
|
||||||
|
backups = []
|
||||||
|
for i in range(0, count):
|
||||||
|
backup = FakeBackup.create_one_backup(attrs)
|
||||||
|
backups.append(backup)
|
||||||
|
|
||||||
|
return backups
|
||||||
|
@ -12,9 +12,6 @@
|
|||||||
# under the License.
|
# under the License.
|
||||||
#
|
#
|
||||||
|
|
||||||
import copy
|
|
||||||
|
|
||||||
from openstackclient.tests import fakes
|
|
||||||
from openstackclient.tests.volume.v2 import fakes as volume_fakes
|
from openstackclient.tests.volume.v2 import fakes as volume_fakes
|
||||||
from openstackclient.volume.v2 import backup
|
from openstackclient.volume.v2 import backup
|
||||||
|
|
||||||
@ -34,83 +31,101 @@ class TestBackup(volume_fakes.TestVolume):
|
|||||||
|
|
||||||
class TestBackupCreate(TestBackup):
|
class TestBackupCreate(TestBackup):
|
||||||
|
|
||||||
|
volume = volume_fakes.FakeVolume.create_one_volume()
|
||||||
|
new_backup = volume_fakes.FakeBackup.create_one_backup(
|
||||||
|
attrs={'volume_id': volume.id})
|
||||||
|
|
||||||
|
columns = (
|
||||||
|
'availability_zone',
|
||||||
|
'container',
|
||||||
|
'description',
|
||||||
|
'id',
|
||||||
|
'name',
|
||||||
|
'object_count',
|
||||||
|
'size',
|
||||||
|
'status',
|
||||||
|
'volume_id',
|
||||||
|
)
|
||||||
|
data = (
|
||||||
|
new_backup.availability_zone,
|
||||||
|
new_backup.container,
|
||||||
|
new_backup.description,
|
||||||
|
new_backup.id,
|
||||||
|
new_backup.name,
|
||||||
|
new_backup.object_count,
|
||||||
|
new_backup.size,
|
||||||
|
new_backup.status,
|
||||||
|
new_backup.volume_id,
|
||||||
|
)
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestBackupCreate, self).setUp()
|
super(TestBackupCreate, self).setUp()
|
||||||
|
|
||||||
self.volumes_mock.get.return_value = fakes.FakeResource(
|
self.volumes_mock.get.return_value = self.volume
|
||||||
None,
|
self.backups_mock.create.return_value = self.new_backup
|
||||||
copy.deepcopy(volume_fakes.VOLUME),
|
|
||||||
loaded=True
|
|
||||||
)
|
|
||||||
|
|
||||||
self.backups_mock.create.return_value = fakes.FakeResource(
|
|
||||||
None,
|
|
||||||
copy.deepcopy(volume_fakes.BACKUP),
|
|
||||||
loaded=True
|
|
||||||
)
|
|
||||||
# Get the command object to test
|
# Get the command object to test
|
||||||
self.cmd = backup.CreateBackup(self.app, None)
|
self.cmd = backup.CreateBackup(self.app, None)
|
||||||
|
|
||||||
def test_backup_create(self):
|
def test_backup_create(self):
|
||||||
arglist = [
|
arglist = [
|
||||||
volume_fakes.volume_id,
|
"--name", self.new_backup.name,
|
||||||
"--name", volume_fakes.backup_name,
|
"--description", self.new_backup.description,
|
||||||
"--description", volume_fakes.backup_description,
|
"--container", self.new_backup.container,
|
||||||
"--container", volume_fakes.backup_name
|
self.new_backup.volume_id,
|
||||||
]
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
("volume", volume_fakes.volume_id),
|
("name", self.new_backup.name),
|
||||||
("name", volume_fakes.backup_name),
|
("description", self.new_backup.description),
|
||||||
("description", volume_fakes.backup_description),
|
("container", self.new_backup.container),
|
||||||
("container", volume_fakes.backup_name)
|
("volume", self.new_backup.volume_id),
|
||||||
]
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
columns, data = self.cmd.take_action(parsed_args)
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
self.backups_mock.create.assert_called_with(
|
self.backups_mock.create.assert_called_with(
|
||||||
volume_fakes.volume_id,
|
self.new_backup.volume_id,
|
||||||
container=volume_fakes.backup_name,
|
container=self.new_backup.container,
|
||||||
name=volume_fakes.backup_name,
|
name=self.new_backup.name,
|
||||||
description=volume_fakes.backup_description
|
description=self.new_backup.description
|
||||||
)
|
)
|
||||||
self.assertEqual(columns, volume_fakes.BACKUP_columns)
|
self.assertEqual(self.columns, columns)
|
||||||
self.assertEqual(data, volume_fakes.BACKUP_data)
|
self.assertEqual(self.data, data)
|
||||||
|
|
||||||
def test_backup_create_without_name(self):
|
def test_backup_create_without_name(self):
|
||||||
arglist = [
|
arglist = [
|
||||||
volume_fakes.volume_id,
|
"--description", self.new_backup.description,
|
||||||
"--description", volume_fakes.backup_description,
|
"--container", self.new_backup.container,
|
||||||
"--container", volume_fakes.backup_name
|
self.new_backup.volume_id,
|
||||||
]
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
("volume", volume_fakes.volume_id),
|
("description", self.new_backup.description),
|
||||||
("description", volume_fakes.backup_description),
|
("container", self.new_backup.container),
|
||||||
("container", volume_fakes.backup_name)
|
("volume", self.new_backup.volume_id),
|
||||||
]
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
columns, data = self.cmd.take_action(parsed_args)
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
self.backups_mock.create.assert_called_with(
|
self.backups_mock.create.assert_called_with(
|
||||||
volume_fakes.volume_id,
|
self.new_backup.volume_id,
|
||||||
container=volume_fakes.backup_name,
|
container=self.new_backup.container,
|
||||||
name=None,
|
name=None,
|
||||||
description=volume_fakes.backup_description
|
description=self.new_backup.description
|
||||||
)
|
)
|
||||||
self.assertEqual(columns, volume_fakes.BACKUP_columns)
|
self.assertEqual(self.columns, columns)
|
||||||
self.assertEqual(data, volume_fakes.BACKUP_data)
|
self.assertEqual(self.data, data)
|
||||||
|
|
||||||
|
|
||||||
class TestBackupDelete(TestBackup):
|
class TestBackupDelete(TestBackup):
|
||||||
|
|
||||||
|
backup = volume_fakes.FakeBackup.create_one_backup()
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestBackupDelete, self).setUp()
|
super(TestBackupDelete, self).setUp()
|
||||||
|
|
||||||
self.backups_mock.get.return_value = fakes.FakeResource(
|
self.backups_mock.get.return_value = self.backup
|
||||||
None,
|
|
||||||
copy.deepcopy(volume_fakes.BACKUP),
|
|
||||||
loaded=True)
|
|
||||||
self.backups_mock.delete.return_value = None
|
self.backups_mock.delete.return_value = None
|
||||||
|
|
||||||
# Get the command object to mock
|
# Get the command object to mock
|
||||||
@ -118,21 +133,25 @@ class TestBackupDelete(TestBackup):
|
|||||||
|
|
||||||
def test_backup_delete(self):
|
def test_backup_delete(self):
|
||||||
arglist = [
|
arglist = [
|
||||||
volume_fakes.backup_id
|
self.backup.id
|
||||||
]
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
("backups", [volume_fakes.backup_id])
|
("backups", [self.backup.id])
|
||||||
]
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
result = self.cmd.take_action(parsed_args)
|
result = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
self.backups_mock.delete.assert_called_with(volume_fakes.backup_id)
|
self.backups_mock.delete.assert_called_with(self.backup.id)
|
||||||
self.assertIsNone(result)
|
self.assertIsNone(result)
|
||||||
|
|
||||||
|
|
||||||
class TestBackupList(TestBackup):
|
class TestBackupList(TestBackup):
|
||||||
|
|
||||||
|
volume = volume_fakes.FakeVolume.create_one_volume()
|
||||||
|
backups = volume_fakes.FakeBackup.create_backups(
|
||||||
|
attrs={'volume_id': volume.name}, count=3)
|
||||||
|
|
||||||
columns = [
|
columns = [
|
||||||
'ID',
|
'ID',
|
||||||
'Name',
|
'Name',
|
||||||
@ -140,33 +159,39 @@ class TestBackupList(TestBackup):
|
|||||||
'Status',
|
'Status',
|
||||||
'Size',
|
'Size',
|
||||||
]
|
]
|
||||||
datalist = (
|
columns_long = columns + [
|
||||||
(
|
'Availability Zone',
|
||||||
volume_fakes.backup_id,
|
'Volume',
|
||||||
volume_fakes.backup_name,
|
'Container',
|
||||||
volume_fakes.backup_description,
|
]
|
||||||
volume_fakes.backup_status,
|
|
||||||
volume_fakes.backup_size
|
data = []
|
||||||
),
|
for b in backups:
|
||||||
)
|
data.append((
|
||||||
|
b.id,
|
||||||
|
b.name,
|
||||||
|
b.description,
|
||||||
|
b.status,
|
||||||
|
b.size,
|
||||||
|
))
|
||||||
|
data_long = []
|
||||||
|
for b in backups:
|
||||||
|
data_long.append((
|
||||||
|
b.id,
|
||||||
|
b.name,
|
||||||
|
b.description,
|
||||||
|
b.status,
|
||||||
|
b.size,
|
||||||
|
b.availability_zone,
|
||||||
|
b.volume_id,
|
||||||
|
b.container,
|
||||||
|
))
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestBackupList, self).setUp()
|
super(TestBackupList, self).setUp()
|
||||||
|
|
||||||
self.volumes_mock.list.return_value = [
|
self.volumes_mock.list.return_value = [self.volume]
|
||||||
fakes.FakeResource(
|
self.backups_mock.list.return_value = self.backups
|
||||||
None,
|
|
||||||
copy.deepcopy(volume_fakes.VOLUME),
|
|
||||||
loaded=True
|
|
||||||
)
|
|
||||||
]
|
|
||||||
self.backups_mock.list.return_value = [
|
|
||||||
fakes.FakeResource(
|
|
||||||
None,
|
|
||||||
copy.deepcopy(volume_fakes.BACKUP),
|
|
||||||
loaded=True
|
|
||||||
)
|
|
||||||
]
|
|
||||||
# Get the command to test
|
# Get the command to test
|
||||||
self.cmd = backup.ListBackup(self.app, None)
|
self.cmd = backup.ListBackup(self.app, None)
|
||||||
|
|
||||||
@ -178,7 +203,7 @@ class TestBackupList(TestBackup):
|
|||||||
columns, data = self.cmd.take_action(parsed_args)
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
self.assertEqual(self.columns, columns)
|
self.assertEqual(self.columns, columns)
|
||||||
self.assertEqual(self.datalist, tuple(data))
|
self.assertEqual(self.data, list(data))
|
||||||
|
|
||||||
def test_backup_list_with_options(self):
|
def test_backup_list_with_options(self):
|
||||||
arglist = ["--long"]
|
arglist = ["--long"]
|
||||||
@ -187,86 +212,87 @@ class TestBackupList(TestBackup):
|
|||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
columns, data = self.cmd.take_action(parsed_args)
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
|
|
||||||
columns = self.columns + [
|
self.assertEqual(self.columns_long, columns)
|
||||||
'Availability Zone',
|
self.assertEqual(self.data_long, list(data))
|
||||||
'Volume',
|
|
||||||
'Container',
|
|
||||||
]
|
|
||||||
|
|
||||||
self.assertEqual(columns, columns)
|
|
||||||
|
|
||||||
datalist = ((
|
|
||||||
volume_fakes.backup_id,
|
|
||||||
volume_fakes.backup_name,
|
|
||||||
volume_fakes.backup_description,
|
|
||||||
volume_fakes.backup_status,
|
|
||||||
volume_fakes.backup_size,
|
|
||||||
volume_fakes.volume_availability_zone,
|
|
||||||
volume_fakes.backup_volume_id,
|
|
||||||
volume_fakes.backup_container
|
|
||||||
),)
|
|
||||||
self.assertEqual(datalist, tuple(data))
|
|
||||||
|
|
||||||
|
|
||||||
class TestBackupRestore(TestBackup):
|
class TestBackupRestore(TestBackup):
|
||||||
|
|
||||||
|
volume = volume_fakes.FakeVolume.create_one_volume()
|
||||||
|
backup = volume_fakes.FakeBackup.create_one_backup(
|
||||||
|
attrs={'volume_id': volume.id})
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestBackupRestore, self).setUp()
|
super(TestBackupRestore, self).setUp()
|
||||||
|
|
||||||
self.backups_mock.get.return_value = fakes.FakeResource(
|
self.backups_mock.get.return_value = self.backup
|
||||||
None,
|
self.volumes_mock.get.return_value = self.volume
|
||||||
copy.deepcopy(volume_fakes.BACKUP),
|
|
||||||
loaded=True
|
|
||||||
)
|
|
||||||
self.volumes_mock.get.return_value = fakes.FakeResource(
|
|
||||||
None,
|
|
||||||
copy.deepcopy(volume_fakes.VOLUME),
|
|
||||||
loaded=True
|
|
||||||
)
|
|
||||||
self.restores_mock.restore.return_value = None
|
self.restores_mock.restore.return_value = None
|
||||||
# Get the command object to mock
|
# Get the command object to mock
|
||||||
self.cmd = backup.RestoreBackup(self.app, None)
|
self.cmd = backup.RestoreBackup(self.app, None)
|
||||||
|
|
||||||
def test_backup_restore(self):
|
def test_backup_restore(self):
|
||||||
arglist = [
|
arglist = [
|
||||||
volume_fakes.backup_id,
|
self.backup.id,
|
||||||
volume_fakes.volume_id
|
self.backup.volume_id
|
||||||
]
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
("backup", volume_fakes.backup_id),
|
("backup", self.backup.id),
|
||||||
("volume", volume_fakes.volume_id)
|
("volume", self.backup.volume_id)
|
||||||
]
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
result = self.cmd.take_action(parsed_args)
|
result = self.cmd.take_action(parsed_args)
|
||||||
self.restores_mock.restore.assert_called_with(volume_fakes.backup_id,
|
self.restores_mock.restore.assert_called_with(self.backup.id,
|
||||||
volume_fakes.volume_id)
|
self.backup.volume_id)
|
||||||
self.assertIsNone(result)
|
self.assertIsNone(result)
|
||||||
|
|
||||||
|
|
||||||
class TestBackupShow(TestBackup):
|
class TestBackupShow(TestBackup):
|
||||||
|
|
||||||
|
backup = volume_fakes.FakeBackup.create_one_backup()
|
||||||
|
|
||||||
|
columns = (
|
||||||
|
'availability_zone',
|
||||||
|
'container',
|
||||||
|
'description',
|
||||||
|
'id',
|
||||||
|
'name',
|
||||||
|
'object_count',
|
||||||
|
'size',
|
||||||
|
'status',
|
||||||
|
'volume_id',
|
||||||
|
)
|
||||||
|
data = (
|
||||||
|
backup.availability_zone,
|
||||||
|
backup.container,
|
||||||
|
backup.description,
|
||||||
|
backup.id,
|
||||||
|
backup.name,
|
||||||
|
backup.object_count,
|
||||||
|
backup.size,
|
||||||
|
backup.status,
|
||||||
|
backup.volume_id,
|
||||||
|
)
|
||||||
|
|
||||||
def setUp(self):
|
def setUp(self):
|
||||||
super(TestBackupShow, self).setUp()
|
super(TestBackupShow, self).setUp()
|
||||||
|
|
||||||
self.backups_mock.get.return_value = fakes.FakeResource(
|
self.backups_mock.get.return_value = self.backup
|
||||||
None,
|
|
||||||
copy.deepcopy(volume_fakes.BACKUP),
|
|
||||||
loaded=True)
|
|
||||||
# Get the command object to test
|
# Get the command object to test
|
||||||
self.cmd = backup.ShowBackup(self.app, None)
|
self.cmd = backup.ShowBackup(self.app, None)
|
||||||
|
|
||||||
def test_backup_show(self):
|
def test_backup_show(self):
|
||||||
arglist = [
|
arglist = [
|
||||||
volume_fakes.backup_id
|
self.backup.id
|
||||||
]
|
]
|
||||||
verifylist = [
|
verifylist = [
|
||||||
("backup", volume_fakes.backup_id)
|
("backup", self.backup.id)
|
||||||
]
|
]
|
||||||
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
parsed_args = self.check_parser(self.cmd, arglist, verifylist)
|
||||||
|
|
||||||
columns, data = self.cmd.take_action(parsed_args)
|
columns, data = self.cmd.take_action(parsed_args)
|
||||||
self.backups_mock.get.assert_called_with(volume_fakes.backup_id)
|
self.backups_mock.get.assert_called_with(self.backup.id)
|
||||||
|
|
||||||
self.assertEqual(volume_fakes.BACKUP_columns, columns)
|
self.assertEqual(self.columns, columns)
|
||||||
self.assertEqual(volume_fakes.BACKUP_data, data)
|
self.assertEqual(self.data, data)
|
||||||
|
Loading…
x
Reference in New Issue
Block a user