Merge "Add Cinder create_and_list_volume_backups scenario"

This commit is contained in:
Jenkins 2015-08-01 16:19:07 +00:00 committed by Gerrit Code Review
commit 067e711bd1
8 changed files with 175 additions and 3 deletions

View File

@ -410,3 +410,41 @@
sla: sla:
failure_rate: failure_rate:
max: 0 max: 0
CinderVolumes.create_and_list_volume_backups:
-
args:
size: 1
detailed: True
do_delete: True
runner:
type: "constant"
times: 2
concurrency: 2
context:
users:
tenants: 1
users_per_tenant: 1
roles:
- "Member"
sla:
failure_rate:
max: 0
-
args:
size: 1
detailed: True
do_delete: False
runner:
type: "constant"
times: 2
concurrency: 2
context:
users:
tenants: 1
users_per_tenant: 1
roles:
- "Member"
sla:
failure_rate:
max: 0

View File

@ -308,3 +308,21 @@
sla: sla:
failure_rate: failure_rate:
max: 0 max: 0
CinderVolumes.create_and_list_volume_backups:
-
args:
size: 1
detailed: True
do_delete: True
runner:
type: "constant"
times: 2
concurrency: 1
context:
users:
tenants: 1
users_per_tenant: 1
sla:
failure_rate:
max: 0

View File

@ -323,6 +323,15 @@ class CinderScenario(scenario.OpenStackScenario):
check_interval=CONF.benchmark.cinder_volume_create_poll_interval check_interval=CONF.benchmark.cinder_volume_create_poll_interval
) )
@base.atomic_action_timer("cinder.list_backups")
def _list_backups(self, detailed=True):
"""Return user volume backups list.
:param detailed: True if detailed information about backup
should be listed
"""
return self.clients("cinder").backups.list(detailed)
def get_random_server(self): def get_random_server(self):
server_id = random.choice(self.context["tenant"]["servers"]) server_id = random.choice(self.context["tenant"]["servers"])
return self.clients("nova").servers.get(server_id) return self.clients("nova").servers.get(server_id)

View File

@ -479,3 +479,32 @@ class CinderVolumes(utils.CinderScenario,
if do_delete: if do_delete:
self._delete_volume(volume) self._delete_volume(volume)
self._delete_backup(backup) self._delete_backup(backup)
@validation.required_cinder_services("cinder-backup")
@validation.required_services(consts.Service.CINDER)
@validation.required_openstack(users=True)
@base.scenario(context={"cleanup": ["cinder"]})
def create_and_list_volume_backups(self, size, detailed=True,
do_delete=True,
create_volume_kwargs=None,
create_backup_kwargs=None):
"""Create and then list a volume backup.
:param size: volume size in GB
:param detailed: True if detailed information about backup
should be listed
:param do_delete: if True, a volume backup will be deleted
:param create_volume_kwargs: optional args to create a volume
:param create_backup_kwargs: optional args to create a volume backup
"""
create_volume_kwargs = create_volume_kwargs or {}
create_backup_kwargs = create_backup_kwargs or {}
volume = self._create_volume(size, **create_volume_kwargs)
backup = self._create_backup(volume.id, **create_backup_kwargs)
self._list_backups(detailed)
if do_delete:
self._delete_volume(volume)
self._delete_backup(backup)

View File

@ -0,0 +1,23 @@
{
"CinderVolumes.create_and_list_volume_backups": [
{
"args": {
"size": 1,
"detailed": true,
"do_delete": true
},
"runner": {
"type": "constant",
"times": 2,
"concurrency": 2
},
"context": {
"users": {
"tenants": 1,
"users_per_tenant": 1
},
"roles": ["Member"]
}
}
]
}

View File

@ -0,0 +1,17 @@
---
CinderVolumes.create_and_list_volume_backups:
-
args:
size: 1
detailed: True
do_delete: True
runner:
type: "constant"
times: 2
concurrency: 2
context:
users:
tenants: 1
users_per_tenant: 1
roles:
- "Member"

View File

@ -294,6 +294,14 @@ class CinderScenarioTestCase(test.ScenarioTestCase):
self._test_atomic_action_timer(self.scenario.atomic_actions(), self._test_atomic_action_timer(self.scenario.atomic_actions(),
"cinder.restore_backup") "cinder.restore_backup")
def test__list_backups(self):
return_backups_list = self.scenario._list_backups()
self.assertEqual(
self.clients("cinder").backups.list.return_value,
return_backups_list)
self._test_atomic_action_timer(self.scenario.atomic_actions(),
"cinder.list_backups")
def test__get_random_server(self): def test__get_random_server(self):
servers = [1, 2, 3] servers = [1, 2, 3]
context = {"user": {"tenant_id": "fake"}, context = {"user": {"tenant_id": "fake"},

View File

@ -408,15 +408,15 @@ class CinderServersTestCase(test.ScenarioTestCase):
self.assertFalse(scenario._delete_volume.called) self.assertFalse(scenario._delete_volume.called)
self.assertFalse(scenario._delete_backup.called) self.assertFalse(scenario._delete_backup.called)
def _get_scenario(self, fake_volume, fake_backup, fake_restore): def _get_scenario(self, fake_volume, fake_backup, fake_restore=None):
scenario = volumes.CinderVolumes() scenario = volumes.CinderVolumes()
scenario._create_volume = mock.MagicMock(return_value=fake_volume) scenario._create_volume = mock.MagicMock(return_value=fake_volume)
scenario._create_backup = mock.MagicMock(return_value=fake_backup) scenario._create_backup = mock.MagicMock(return_value=fake_backup)
scenario._restore_backup = mock.MagicMock(return_value=fake_restore) scenario._restore_backup = mock.MagicMock(return_value=fake_restore)
scenario._list_backups = mock.MagicMock()
scenario._delete_volume = mock.MagicMock() scenario._delete_volume = mock.MagicMock()
scenario._delete_backup = mock.MagicMock() scenario._delete_backup = mock.MagicMock()
return scenario return scenario
def test_create_and_restore_volume_backup(self): def test_create_and_restore_volume_backup(self):
@ -448,3 +448,33 @@ class CinderServersTestCase(test.ScenarioTestCase):
scenario._restore_backup.assert_called_once_with(fake_backup.id) scenario._restore_backup.assert_called_once_with(fake_backup.id)
self.assertFalse(scenario._delete_volume.called) self.assertFalse(scenario._delete_volume.called)
self.assertFalse(scenario._delete_backup.called) self.assertFalse(scenario._delete_backup.called)
def test_create_and_list_volume_backups(self):
fake_volume = mock.MagicMock()
fake_backup = mock.MagicMock()
scenario = self._get_scenario(fake_volume, fake_backup)
volume_kwargs = {"some_var": "zaq"}
scenario.create_and_list_volume_backups(
1, detailed=True, do_delete=True,
create_volume_kwargs=volume_kwargs)
scenario._create_volume.assert_called_once_with(1, **volume_kwargs)
scenario._create_backup.assert_called_once_with(fake_volume.id)
scenario._list_backups.assert_called_once_with(True)
scenario._delete_volume.assert_called_once_with(fake_volume)
scenario._delete_backup.assert_called_once_with(fake_backup)
def test_create_and_list_volume_backups_no_delete(self):
fake_volume = mock.MagicMock()
fake_backup = mock.MagicMock()
scenario = self._get_scenario(fake_volume, fake_backup)
volume_kwargs = {"some_var": "zaq"}
scenario.create_and_list_volume_backups(
1, detailed=True, do_delete=False,
create_volume_kwargs=volume_kwargs)
scenario._create_volume.assert_called_once_with(1, **volume_kwargs)
scenario._create_backup.assert_called_once_with(fake_volume.id)
scenario._list_backups.assert_called_once_with(True)
self.assertFalse(scenario._delete_volume.called)
self.assertFalse(scenario._delete_backup.called)