Add --project and --project-domain option to "volume snapshot list"

Add "--project" and "--project-domain" option to volume v2's
"volume snapshot list" command, it will filter list result by different project.

Change-Id: I7dccd6d8d9f1889fa9cb0c2d04a42d77975c645b
This commit is contained in:
jiahui.qiang 2017-01-06 22:49:41 +08:00
parent 221cb5318e
commit 27e0be0517
4 changed files with 56 additions and 2 deletions

View File

@ -82,6 +82,7 @@ List volume snapshots
openstack volume snapshot list openstack volume snapshot list
[--all-projects] [--all-projects]
[--project <project> [--project-domain <project-domain>]]
[--long] [--long]
[--limit <limit>] [--limit <limit>]
[--marker <marker>] [--marker <marker>]
@ -93,6 +94,20 @@ List volume snapshots
Include all projects (admin only) Include all projects (admin only)
.. option:: --project <project>
Filter results by project (name or ID) (admin only)
*Volume version 2 only*
.. option:: --project-domain <project-domain>
Domain the project belongs to (name or ID).
This can be used in case collisions between project names exist.
*Volume version 2 only*
.. option:: --long .. option:: --long
List additional fields in output List additional fields in output

View File

@ -19,6 +19,7 @@ from mock import call
from osc_lib import exceptions from osc_lib import exceptions
from osc_lib import utils from osc_lib import utils
from openstackclient.tests.unit.identity.v3 import fakes as project_fakes
from openstackclient.tests.unit.volume.v2 import fakes as volume_fakes from openstackclient.tests.unit.volume.v2 import fakes as volume_fakes
from openstackclient.volume.v2 import volume_snapshot from openstackclient.volume.v2 import volume_snapshot
@ -32,6 +33,8 @@ class TestSnapshot(volume_fakes.TestVolume):
self.snapshots_mock.reset_mock() self.snapshots_mock.reset_mock()
self.volumes_mock = self.app.client_manager.volume.volumes self.volumes_mock = self.app.client_manager.volume.volumes
self.volumes_mock.reset_mock() self.volumes_mock.reset_mock()
self.project_mock = self.app.client_manager.identity.projects
self.project_mock.reset_mock()
class TestSnapshotCreate(TestSnapshot): class TestSnapshotCreate(TestSnapshot):
@ -278,6 +281,7 @@ class TestSnapshotDelete(TestSnapshot):
class TestSnapshotList(TestSnapshot): class TestSnapshotList(TestSnapshot):
volume = volume_fakes.FakeVolume.create_one_volume() volume = volume_fakes.FakeVolume.create_one_volume()
project = project_fakes.FakeProject.create_one_project()
snapshots = volume_fakes.FakeSnapshot.create_snapshots( snapshots = volume_fakes.FakeSnapshot.create_snapshots(
attrs={'volume_id': volume.name}, count=3) attrs={'volume_id': volume.name}, count=3)
@ -321,6 +325,7 @@ class TestSnapshotList(TestSnapshot):
self.volumes_mock.list.return_value = [self.volume] self.volumes_mock.list.return_value = [self.volume]
self.volumes_mock.get.return_value = self.volume self.volumes_mock.get.return_value = self.volume
self.project_mock.get.return_value = self.project
self.snapshots_mock.list.return_value = self.snapshots self.snapshots_mock.list.return_value = self.snapshots
# Get the command to test # Get the command to test
self.cmd = volume_snapshot.ListVolumeSnapshot(self.app, None) self.cmd = volume_snapshot.ListVolumeSnapshot(self.app, None)
@ -341,6 +346,7 @@ class TestSnapshotList(TestSnapshot):
'all_tenants': False, 'all_tenants': False,
'name': None, 'name': None,
'status': None, 'status': None,
'project_id': None,
'volume_id': None 'volume_id': None
} }
) )
@ -351,11 +357,13 @@ class TestSnapshotList(TestSnapshot):
arglist = [ arglist = [
"--long", "--long",
"--limit", "2", "--limit", "2",
"--project", self.project.id,
"--marker", self.snapshots[0].id, "--marker", self.snapshots[0].id,
] ]
verifylist = [ verifylist = [
("long", True), ("long", True),
("limit", 2), ("limit", 2),
("project", self.project.id),
("marker", self.snapshots[0].id), ("marker", self.snapshots[0].id),
('all_projects', False), ('all_projects', False),
] ]
@ -367,7 +375,8 @@ class TestSnapshotList(TestSnapshot):
limit=2, limit=2,
marker=self.snapshots[0].id, marker=self.snapshots[0].id,
search_opts={ search_opts={
'all_tenants': False, 'all_tenants': True,
'project_id': self.project.id,
'name': None, 'name': None,
'status': None, 'status': None,
'volume_id': None 'volume_id': None
@ -394,6 +403,7 @@ class TestSnapshotList(TestSnapshot):
'all_tenants': True, 'all_tenants': True,
'name': None, 'name': None,
'status': None, 'status': None,
'project_id': None,
'volume_id': None 'volume_id': None
} }
) )
@ -419,6 +429,7 @@ class TestSnapshotList(TestSnapshot):
'all_tenants': False, 'all_tenants': False,
'name': self.snapshots[0].name, 'name': self.snapshots[0].name,
'status': None, 'status': None,
'project_id': None,
'volume_id': None 'volume_id': None
} }
) )
@ -444,6 +455,7 @@ class TestSnapshotList(TestSnapshot):
'all_tenants': False, 'all_tenants': False,
'name': None, 'name': None,
'status': self.snapshots[0].status, 'status': self.snapshots[0].status,
'project_id': None,
'volume_id': None 'volume_id': None
} }
) )
@ -469,6 +481,7 @@ class TestSnapshotList(TestSnapshot):
'all_tenants': False, 'all_tenants': False,
'name': None, 'name': None,
'status': None, 'status': None,
'project_id': None,
'volume_id': self.volume.id 'volume_id': self.volume.id
} }
) )

View File

@ -24,6 +24,7 @@ from osc_lib import utils
import six import six
from openstackclient.i18n import _ from openstackclient.i18n import _
from openstackclient.identity import common as identity_common
LOG = logging.getLogger(__name__) LOG = logging.getLogger(__name__)
@ -165,6 +166,12 @@ class ListVolumeSnapshot(command.Lister):
default=False, default=False,
help=_('Include all projects (admin only)'), help=_('Include all projects (admin only)'),
) )
parser.add_argument(
'--project',
metavar='<project>',
help=_('Filter results by project (name or ID) (admin only)')
)
identity_common.add_project_domain_option_to_parser(parser)
parser.add_argument( parser.add_argument(
'--long', '--long',
action='store_true', action='store_true',
@ -208,6 +215,7 @@ class ListVolumeSnapshot(command.Lister):
def take_action(self, parsed_args): def take_action(self, parsed_args):
volume_client = self.app.client_manager.volume volume_client = self.app.client_manager.volume
identity_client = self.app.client_manager.identity
def _format_volume_id(volume_id): def _format_volume_id(volume_id):
"""Return a volume name if available """Return a volume name if available
@ -245,8 +253,20 @@ class ListVolumeSnapshot(command.Lister):
volume_id = utils.find_resource( volume_id = utils.find_resource(
volume_client.volumes, parsed_args.volume).id volume_client.volumes, parsed_args.volume).id
project_id = None
if parsed_args.project:
project_id = identity_common.find_project(
identity_client,
parsed_args.project,
parsed_args.project_domain).id
# set value of 'all_tenants' when using project option
all_projects = True if parsed_args.project else \
parsed_args.all_projects
search_opts = { search_opts = {
'all_tenants': parsed_args.all_projects, 'all_tenants': all_projects,
'project_id': project_id,
'name': parsed_args.name, 'name': parsed_args.name,
'status': parsed_args.status, 'status': parsed_args.status,
'volume_id': volume_id, 'volume_id': volume_id,

View File

@ -0,0 +1,6 @@
---
features:
- |
Add ``--project`` and ``--project-domain`` option to
``volume snapshot list`` command, in order to filter list result
by different project.