If you use the former, you get a pretty error message when there's a
failure. If you use the latter, you get an ugly traceback when used with
the '--debug' flag.
Without this change:
  $ openstack flavor create ... --property '' foo
  ...
  Traceback (most recent call last):
    File "/tmp/venv/lib/python3.11/site-packages/cliff/app.py", line 402, in run_subcommand
      parsed_args = cmd_parser.parse_args(sub_argv)
                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
    File "/usr/lib64/python3.11/argparse.py", line 1862, in parse_args
      args, argv = self.parse_known_args(args, namespace)
                   ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
    File "/usr/lib64/python3.11/argparse.py", line 1895, in parse_known_args
      namespace, args = self._parse_known_args(args, namespace)
                        ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
    File "/usr/lib64/python3.11/argparse.py", line 2107, in _parse_known_args
      start_index = consume_optional(start_index)
                    ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
    File "/usr/lib64/python3.11/argparse.py", line 2047, in consume_optional
      take_action(action, args, option_string)
    File "/usr/lib64/python3.11/argparse.py", line 1971, in take_action
      action(self, namespace, argument_values, option_string)
    File "/tmp/venv/lib/python3.11/site-packages/osc_lib/cli/parseractions.py", line 45, in __call__
      raise argparse.ArgumentTypeError(msg % str(values))
  argparse.ArgumentTypeError: Expected 'key=value' type, but got:
  clean_up CreateFlavor: Expected 'key=value' type, but got:
With this change:
  $ openstack flavor create ... --property '' foo
  ...
  usage: openstack flavor create [-h] [-f {json,shell,table,value,yaml}] [-c COLUMN]
                                 [--noindent] [--prefix PREFIX] [--max-width <integer>]
                                 [--fit-width] [--print-empty] [--id <id>]
                                 [--ram <size-mb>] [--disk <size-gb>]
                                 [--ephemeral <size-gb>] [--swap <size-mb>]
                                 [--vcpus <vcpus>] [--rxtx-factor <factor>]
                                 [--public | --private] [--property <key=value>]
                                 [--project <project>] [--description <description>]
                                 [--project-domain <project-domain>]
                                 <flavor-name>
  openstack flavor create: error: argument --property: Expected 'key=value' type, but got:
  clean_up CreateFlavor:
Change-Id: I9e78b35ad9d016d7a33655141ec579397c5344c0
Signed-off-by: Stephen Finucane <stephenfin@redhat.com>
		
	
		
			
				
	
	
		
			743 lines
		
	
	
		
			23 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			743 lines
		
	
	
		
			23 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
#
 | 
						|
#   Licensed under the Apache License, Version 2.0 (the "License"); you may
 | 
						|
#   not use this file except in compliance with the License. You may obtain
 | 
						|
#   a copy of the License at
 | 
						|
#
 | 
						|
#        http://www.apache.org/licenses/LICENSE-2.0
 | 
						|
#
 | 
						|
#   Unless required by applicable law or agreed to in writing, software
 | 
						|
#   distributed under the License is distributed on an "AS IS" BASIS, WITHOUT
 | 
						|
#   WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. See the
 | 
						|
#   License for the specific language governing permissions and limitations
 | 
						|
#   under the License.
 | 
						|
 | 
						|
from unittest import mock
 | 
						|
 | 
						|
from osc_lib.cli import format_columns
 | 
						|
from osc_lib import exceptions
 | 
						|
from osc_lib import utils
 | 
						|
 | 
						|
from openstackclient.tests.unit.identity.v3 import fakes as project_fakes
 | 
						|
from openstackclient.tests.unit import utils as test_utils
 | 
						|
from openstackclient.tests.unit.volume.v2 import fakes as volume_fakes
 | 
						|
from openstackclient.volume.v2 import volume_snapshot
 | 
						|
 | 
						|
 | 
						|
class TestVolumeSnapshot(volume_fakes.TestVolume):
 | 
						|
    def setUp(self):
 | 
						|
        super().setUp()
 | 
						|
 | 
						|
        self.snapshots_mock = self.volume_client.volume_snapshots
 | 
						|
        self.snapshots_mock.reset_mock()
 | 
						|
        self.volumes_mock = self.volume_client.volumes
 | 
						|
        self.volumes_mock.reset_mock()
 | 
						|
        self.project_mock = self.app.client_manager.identity.projects
 | 
						|
        self.project_mock.reset_mock()
 | 
						|
 | 
						|
 | 
						|
class TestVolumeSnapshotCreate(TestVolumeSnapshot):
 | 
						|
    columns = (
 | 
						|
        'created_at',
 | 
						|
        'description',
 | 
						|
        'id',
 | 
						|
        'name',
 | 
						|
        'properties',
 | 
						|
        'size',
 | 
						|
        'status',
 | 
						|
        'volume_id',
 | 
						|
    )
 | 
						|
 | 
						|
    def setUp(self):
 | 
						|
        super().setUp()
 | 
						|
 | 
						|
        self.volume = volume_fakes.create_one_volume()
 | 
						|
        self.new_snapshot = volume_fakes.create_one_snapshot(
 | 
						|
            attrs={'volume_id': self.volume.id}
 | 
						|
        )
 | 
						|
 | 
						|
        self.data = (
 | 
						|
            self.new_snapshot.created_at,
 | 
						|
            self.new_snapshot.description,
 | 
						|
            self.new_snapshot.id,
 | 
						|
            self.new_snapshot.name,
 | 
						|
            format_columns.DictColumn(self.new_snapshot.metadata),
 | 
						|
            self.new_snapshot.size,
 | 
						|
            self.new_snapshot.status,
 | 
						|
            self.new_snapshot.volume_id,
 | 
						|
        )
 | 
						|
 | 
						|
        self.volumes_mock.get.return_value = self.volume
 | 
						|
        self.snapshots_mock.create.return_value = self.new_snapshot
 | 
						|
        self.snapshots_mock.manage.return_value = self.new_snapshot
 | 
						|
        # Get the command object to test
 | 
						|
        self.cmd = volume_snapshot.CreateVolumeSnapshot(self.app, None)
 | 
						|
 | 
						|
    def test_snapshot_create(self):
 | 
						|
        arglist = [
 | 
						|
            "--volume",
 | 
						|
            self.new_snapshot.volume_id,
 | 
						|
            "--description",
 | 
						|
            self.new_snapshot.description,
 | 
						|
            "--force",
 | 
						|
            '--property',
 | 
						|
            'Alpha=a',
 | 
						|
            '--property',
 | 
						|
            'Beta=b',
 | 
						|
            self.new_snapshot.name,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ("volume", self.new_snapshot.volume_id),
 | 
						|
            ("description", self.new_snapshot.description),
 | 
						|
            ("force", True),
 | 
						|
            ('property', {'Alpha': 'a', 'Beta': 'b'}),
 | 
						|
            ("snapshot_name", self.new_snapshot.name),
 | 
						|
        ]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        columns, data = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.create.assert_called_with(
 | 
						|
            self.new_snapshot.volume_id,
 | 
						|
            force=True,
 | 
						|
            name=self.new_snapshot.name,
 | 
						|
            description=self.new_snapshot.description,
 | 
						|
            metadata={'Alpha': 'a', 'Beta': 'b'},
 | 
						|
        )
 | 
						|
        self.assertEqual(self.columns, columns)
 | 
						|
        self.assertEqual(self.data, data)
 | 
						|
 | 
						|
    def test_snapshot_create_without_name(self):
 | 
						|
        arglist = [
 | 
						|
            "--volume",
 | 
						|
            self.new_snapshot.volume_id,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ("volume", self.new_snapshot.volume_id),
 | 
						|
        ]
 | 
						|
        self.assertRaises(
 | 
						|
            test_utils.ParserException,
 | 
						|
            self.check_parser,
 | 
						|
            self.cmd,
 | 
						|
            arglist,
 | 
						|
            verifylist,
 | 
						|
        )
 | 
						|
 | 
						|
    def test_snapshot_create_without_volume(self):
 | 
						|
        arglist = [
 | 
						|
            "--description",
 | 
						|
            self.new_snapshot.description,
 | 
						|
            "--force",
 | 
						|
            self.new_snapshot.name,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ("description", self.new_snapshot.description),
 | 
						|
            ("force", True),
 | 
						|
            ("snapshot_name", self.new_snapshot.name),
 | 
						|
        ]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        columns, data = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.volumes_mock.get.assert_called_once_with(self.new_snapshot.name)
 | 
						|
        self.snapshots_mock.create.assert_called_once_with(
 | 
						|
            self.new_snapshot.volume_id,
 | 
						|
            force=True,
 | 
						|
            name=self.new_snapshot.name,
 | 
						|
            description=self.new_snapshot.description,
 | 
						|
            metadata=None,
 | 
						|
        )
 | 
						|
        self.assertEqual(self.columns, columns)
 | 
						|
        self.assertEqual(self.data, data)
 | 
						|
 | 
						|
    def test_snapshot_create_with_remote_source(self):
 | 
						|
        arglist = [
 | 
						|
            '--remote-source',
 | 
						|
            'source-name=test_source_name',
 | 
						|
            '--remote-source',
 | 
						|
            'source-id=test_source_id',
 | 
						|
            '--volume',
 | 
						|
            self.new_snapshot.volume_id,
 | 
						|
            self.new_snapshot.name,
 | 
						|
        ]
 | 
						|
        ref_dict = {
 | 
						|
            'source-name': 'test_source_name',
 | 
						|
            'source-id': 'test_source_id',
 | 
						|
        }
 | 
						|
        verifylist = [
 | 
						|
            ('remote_source', ref_dict),
 | 
						|
            ('volume', self.new_snapshot.volume_id),
 | 
						|
            ("snapshot_name", self.new_snapshot.name),
 | 
						|
        ]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        columns, data = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.manage.assert_called_with(
 | 
						|
            volume_id=self.new_snapshot.volume_id,
 | 
						|
            ref=ref_dict,
 | 
						|
            name=self.new_snapshot.name,
 | 
						|
            description=None,
 | 
						|
            metadata=None,
 | 
						|
        )
 | 
						|
        self.snapshots_mock.create.assert_not_called()
 | 
						|
        self.assertEqual(self.columns, columns)
 | 
						|
        self.assertEqual(self.data, data)
 | 
						|
 | 
						|
 | 
						|
class TestVolumeSnapshotDelete(TestVolumeSnapshot):
 | 
						|
    snapshots = volume_fakes.create_snapshots(count=2)
 | 
						|
 | 
						|
    def setUp(self):
 | 
						|
        super().setUp()
 | 
						|
 | 
						|
        self.snapshots_mock.get = volume_fakes.get_snapshots(self.snapshots)
 | 
						|
        self.snapshots_mock.delete.return_value = None
 | 
						|
 | 
						|
        # Get the command object to mock
 | 
						|
        self.cmd = volume_snapshot.DeleteVolumeSnapshot(self.app, None)
 | 
						|
 | 
						|
    def test_snapshot_delete(self):
 | 
						|
        arglist = [self.snapshots[0].id]
 | 
						|
        verifylist = [("snapshots", [self.snapshots[0].id])]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        result = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.delete.assert_called_with(
 | 
						|
            self.snapshots[0].id, False
 | 
						|
        )
 | 
						|
        self.assertIsNone(result)
 | 
						|
 | 
						|
    def test_snapshot_delete_with_force(self):
 | 
						|
        arglist = ['--force', self.snapshots[0].id]
 | 
						|
        verifylist = [('force', True), ("snapshots", [self.snapshots[0].id])]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        result = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.delete.assert_called_with(
 | 
						|
            self.snapshots[0].id, True
 | 
						|
        )
 | 
						|
        self.assertIsNone(result)
 | 
						|
 | 
						|
    def test_delete_multiple_snapshots(self):
 | 
						|
        arglist = []
 | 
						|
        for s in self.snapshots:
 | 
						|
            arglist.append(s.id)
 | 
						|
        verifylist = [
 | 
						|
            ('snapshots', arglist),
 | 
						|
        ]
 | 
						|
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
        result = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        calls = []
 | 
						|
        for s in self.snapshots:
 | 
						|
            calls.append(mock.call(s.id, False))
 | 
						|
        self.snapshots_mock.delete.assert_has_calls(calls)
 | 
						|
        self.assertIsNone(result)
 | 
						|
 | 
						|
    def test_delete_multiple_snapshots_with_exception(self):
 | 
						|
        arglist = [
 | 
						|
            self.snapshots[0].id,
 | 
						|
            'unexist_snapshot',
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ('snapshots', arglist),
 | 
						|
        ]
 | 
						|
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        find_mock_result = [self.snapshots[0], exceptions.CommandError]
 | 
						|
        with mock.patch.object(
 | 
						|
            utils, 'find_resource', side_effect=find_mock_result
 | 
						|
        ) as find_mock:
 | 
						|
            try:
 | 
						|
                self.cmd.take_action(parsed_args)
 | 
						|
                self.fail('CommandError should be raised.')
 | 
						|
            except exceptions.CommandError as e:
 | 
						|
                self.assertEqual('1 of 2 snapshots failed to delete.', str(e))
 | 
						|
 | 
						|
            find_mock.assert_any_call(
 | 
						|
                self.snapshots_mock, self.snapshots[0].id
 | 
						|
            )
 | 
						|
            find_mock.assert_any_call(self.snapshots_mock, 'unexist_snapshot')
 | 
						|
 | 
						|
            self.assertEqual(2, find_mock.call_count)
 | 
						|
            self.snapshots_mock.delete.assert_called_once_with(
 | 
						|
                self.snapshots[0].id, False
 | 
						|
            )
 | 
						|
 | 
						|
 | 
						|
class TestVolumeSnapshotList(TestVolumeSnapshot):
 | 
						|
    volume = volume_fakes.create_one_volume()
 | 
						|
    project = project_fakes.FakeProject.create_one_project()
 | 
						|
    snapshots = volume_fakes.create_snapshots(
 | 
						|
        attrs={'volume_id': volume.name}, count=3
 | 
						|
    )
 | 
						|
 | 
						|
    columns = ["ID", "Name", "Description", "Status", "Size"]
 | 
						|
    columns_long = columns + ["Created At", "Volume", "Properties"]
 | 
						|
 | 
						|
    data = []
 | 
						|
    for s in snapshots:
 | 
						|
        data.append(
 | 
						|
            (
 | 
						|
                s.id,
 | 
						|
                s.name,
 | 
						|
                s.description,
 | 
						|
                s.status,
 | 
						|
                s.size,
 | 
						|
            )
 | 
						|
        )
 | 
						|
    data_long = []
 | 
						|
    for s in snapshots:
 | 
						|
        data_long.append(
 | 
						|
            (
 | 
						|
                s.id,
 | 
						|
                s.name,
 | 
						|
                s.description,
 | 
						|
                s.status,
 | 
						|
                s.size,
 | 
						|
                s.created_at,
 | 
						|
                volume_snapshot.VolumeIdColumn(
 | 
						|
                    s.volume_id, volume_cache={volume.id: volume}
 | 
						|
                ),
 | 
						|
                format_columns.DictColumn(s.metadata),
 | 
						|
            )
 | 
						|
        )
 | 
						|
 | 
						|
    def setUp(self):
 | 
						|
        super().setUp()
 | 
						|
 | 
						|
        self.volumes_mock.list.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
 | 
						|
        # Get the command to test
 | 
						|
        self.cmd = volume_snapshot.ListVolumeSnapshot(self.app, None)
 | 
						|
 | 
						|
    def test_snapshot_list_without_options(self):
 | 
						|
        arglist = []
 | 
						|
        verifylist = [('all_projects', False), ('long', False)]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        columns, data = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.list.assert_called_once_with(
 | 
						|
            limit=None,
 | 
						|
            marker=None,
 | 
						|
            search_opts={
 | 
						|
                'all_tenants': False,
 | 
						|
                'name': None,
 | 
						|
                'status': None,
 | 
						|
                'project_id': None,
 | 
						|
                'volume_id': None,
 | 
						|
            },
 | 
						|
        )
 | 
						|
        self.assertEqual(self.columns, columns)
 | 
						|
        self.assertEqual(self.data, list(data))
 | 
						|
 | 
						|
    def test_snapshot_list_with_options(self):
 | 
						|
        arglist = [
 | 
						|
            "--long",
 | 
						|
            "--limit",
 | 
						|
            "2",
 | 
						|
            "--project",
 | 
						|
            self.project.id,
 | 
						|
            "--marker",
 | 
						|
            self.snapshots[0].id,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ("long", True),
 | 
						|
            ("limit", 2),
 | 
						|
            ("project", self.project.id),
 | 
						|
            ("marker", self.snapshots[0].id),
 | 
						|
            ('all_projects', False),
 | 
						|
        ]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        columns, data = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.list.assert_called_once_with(
 | 
						|
            limit=2,
 | 
						|
            marker=self.snapshots[0].id,
 | 
						|
            search_opts={
 | 
						|
                'all_tenants': True,
 | 
						|
                'project_id': self.project.id,
 | 
						|
                'name': None,
 | 
						|
                'status': None,
 | 
						|
                'volume_id': None,
 | 
						|
            },
 | 
						|
        )
 | 
						|
        self.assertEqual(self.columns_long, columns)
 | 
						|
        self.assertEqual(self.data_long, list(data))
 | 
						|
 | 
						|
    def test_snapshot_list_all_projects(self):
 | 
						|
        arglist = [
 | 
						|
            '--all-projects',
 | 
						|
        ]
 | 
						|
        verifylist = [('long', False), ('all_projects', True)]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        columns, data = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.list.assert_called_once_with(
 | 
						|
            limit=None,
 | 
						|
            marker=None,
 | 
						|
            search_opts={
 | 
						|
                'all_tenants': True,
 | 
						|
                'name': None,
 | 
						|
                'status': None,
 | 
						|
                'project_id': None,
 | 
						|
                'volume_id': None,
 | 
						|
            },
 | 
						|
        )
 | 
						|
        self.assertEqual(self.columns, columns)
 | 
						|
        self.assertEqual(self.data, list(data))
 | 
						|
 | 
						|
    def test_snapshot_list_name_option(self):
 | 
						|
        arglist = [
 | 
						|
            '--name',
 | 
						|
            self.snapshots[0].name,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ('all_projects', False),
 | 
						|
            ('long', False),
 | 
						|
            ('name', self.snapshots[0].name),
 | 
						|
        ]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        columns, data = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.list.assert_called_once_with(
 | 
						|
            limit=None,
 | 
						|
            marker=None,
 | 
						|
            search_opts={
 | 
						|
                'all_tenants': False,
 | 
						|
                'name': self.snapshots[0].name,
 | 
						|
                'status': None,
 | 
						|
                'project_id': None,
 | 
						|
                'volume_id': None,
 | 
						|
            },
 | 
						|
        )
 | 
						|
        self.assertEqual(self.columns, columns)
 | 
						|
        self.assertEqual(self.data, list(data))
 | 
						|
 | 
						|
    def test_snapshot_list_status_option(self):
 | 
						|
        arglist = [
 | 
						|
            '--status',
 | 
						|
            self.snapshots[0].status,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ('all_projects', False),
 | 
						|
            ('long', False),
 | 
						|
            ('status', self.snapshots[0].status),
 | 
						|
        ]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        columns, data = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.list.assert_called_once_with(
 | 
						|
            limit=None,
 | 
						|
            marker=None,
 | 
						|
            search_opts={
 | 
						|
                'all_tenants': False,
 | 
						|
                'name': None,
 | 
						|
                'status': self.snapshots[0].status,
 | 
						|
                'project_id': None,
 | 
						|
                'volume_id': None,
 | 
						|
            },
 | 
						|
        )
 | 
						|
        self.assertEqual(self.columns, columns)
 | 
						|
        self.assertEqual(self.data, list(data))
 | 
						|
 | 
						|
    def test_snapshot_list_volumeid_option(self):
 | 
						|
        arglist = [
 | 
						|
            '--volume',
 | 
						|
            self.volume.id,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ('all_projects', False),
 | 
						|
            ('long', False),
 | 
						|
            ('volume', self.volume.id),
 | 
						|
        ]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        columns, data = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.list.assert_called_once_with(
 | 
						|
            limit=None,
 | 
						|
            marker=None,
 | 
						|
            search_opts={
 | 
						|
                'all_tenants': False,
 | 
						|
                'name': None,
 | 
						|
                'status': None,
 | 
						|
                'project_id': None,
 | 
						|
                'volume_id': self.volume.id,
 | 
						|
            },
 | 
						|
        )
 | 
						|
        self.assertEqual(self.columns, columns)
 | 
						|
        self.assertEqual(self.data, list(data))
 | 
						|
 | 
						|
    def test_snapshot_list_negative_limit(self):
 | 
						|
        arglist = [
 | 
						|
            "--limit",
 | 
						|
            "-2",
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ("limit", -2),
 | 
						|
        ]
 | 
						|
        self.assertRaises(
 | 
						|
            test_utils.ParserException,
 | 
						|
            self.check_parser,
 | 
						|
            self.cmd,
 | 
						|
            arglist,
 | 
						|
            verifylist,
 | 
						|
        )
 | 
						|
 | 
						|
 | 
						|
class TestVolumeSnapshotSet(TestVolumeSnapshot):
 | 
						|
    snapshot = volume_fakes.create_one_snapshot()
 | 
						|
 | 
						|
    def setUp(self):
 | 
						|
        super().setUp()
 | 
						|
 | 
						|
        self.snapshots_mock.get.return_value = self.snapshot
 | 
						|
        self.snapshots_mock.set_metadata.return_value = None
 | 
						|
        self.snapshots_mock.update.return_value = None
 | 
						|
        # Get the command object to mock
 | 
						|
        self.cmd = volume_snapshot.SetVolumeSnapshot(self.app, None)
 | 
						|
 | 
						|
    def test_snapshot_set_no_option(self):
 | 
						|
        arglist = [
 | 
						|
            self.snapshot.id,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ("snapshot", self.snapshot.id),
 | 
						|
        ]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        result = self.cmd.take_action(parsed_args)
 | 
						|
        self.snapshots_mock.get.assert_called_once_with(parsed_args.snapshot)
 | 
						|
        self.assertNotCalled(self.snapshots_mock.reset_state)
 | 
						|
        self.assertNotCalled(self.snapshots_mock.update)
 | 
						|
        self.assertNotCalled(self.snapshots_mock.set_metadata)
 | 
						|
        self.assertIsNone(result)
 | 
						|
 | 
						|
    def test_snapshot_set_name_and_property(self):
 | 
						|
        arglist = [
 | 
						|
            "--name",
 | 
						|
            "new_snapshot",
 | 
						|
            "--property",
 | 
						|
            "x=y",
 | 
						|
            "--property",
 | 
						|
            "foo=foo",
 | 
						|
            self.snapshot.id,
 | 
						|
        ]
 | 
						|
        new_property = {"x": "y", "foo": "foo"}
 | 
						|
        verifylist = [
 | 
						|
            ("name", "new_snapshot"),
 | 
						|
            ("property", new_property),
 | 
						|
            ("snapshot", self.snapshot.id),
 | 
						|
        ]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        result = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        kwargs = {
 | 
						|
            "name": "new_snapshot",
 | 
						|
        }
 | 
						|
        self.snapshots_mock.update.assert_called_with(
 | 
						|
            self.snapshot.id, **kwargs
 | 
						|
        )
 | 
						|
        self.snapshots_mock.set_metadata.assert_called_with(
 | 
						|
            self.snapshot.id, new_property
 | 
						|
        )
 | 
						|
        self.assertIsNone(result)
 | 
						|
 | 
						|
    def test_snapshot_set_with_no_property(self):
 | 
						|
        arglist = [
 | 
						|
            "--no-property",
 | 
						|
            self.snapshot.id,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ("no_property", True),
 | 
						|
            ("snapshot", self.snapshot.id),
 | 
						|
        ]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        result = self.cmd.take_action(parsed_args)
 | 
						|
        self.snapshots_mock.get.assert_called_once_with(parsed_args.snapshot)
 | 
						|
        self.assertNotCalled(self.snapshots_mock.reset_state)
 | 
						|
        self.assertNotCalled(self.snapshots_mock.update)
 | 
						|
        self.assertNotCalled(self.snapshots_mock.set_metadata)
 | 
						|
        self.snapshots_mock.delete_metadata.assert_called_with(
 | 
						|
            self.snapshot.id, ["foo"]
 | 
						|
        )
 | 
						|
        self.assertIsNone(result)
 | 
						|
 | 
						|
    def test_snapshot_set_with_no_property_and_property(self):
 | 
						|
        arglist = [
 | 
						|
            "--no-property",
 | 
						|
            "--property",
 | 
						|
            "foo_1=bar_1",
 | 
						|
            self.snapshot.id,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ("no_property", True),
 | 
						|
            ("property", {"foo_1": "bar_1"}),
 | 
						|
            ("snapshot", self.snapshot.id),
 | 
						|
        ]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        result = self.cmd.take_action(parsed_args)
 | 
						|
        self.snapshots_mock.get.assert_called_once_with(parsed_args.snapshot)
 | 
						|
        self.assertNotCalled(self.snapshots_mock.reset_state)
 | 
						|
        self.assertNotCalled(self.snapshots_mock.update)
 | 
						|
        self.snapshots_mock.delete_metadata.assert_called_with(
 | 
						|
            self.snapshot.id, ["foo"]
 | 
						|
        )
 | 
						|
        self.snapshots_mock.set_metadata.assert_called_once_with(
 | 
						|
            self.snapshot.id, {"foo_1": "bar_1"}
 | 
						|
        )
 | 
						|
        self.assertIsNone(result)
 | 
						|
 | 
						|
    def test_snapshot_set_state_to_error(self):
 | 
						|
        arglist = ["--state", "error", self.snapshot.id]
 | 
						|
        verifylist = [("state", "error"), ("snapshot", self.snapshot.id)]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        result = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.reset_state.assert_called_with(
 | 
						|
            self.snapshot.id, "error"
 | 
						|
        )
 | 
						|
        self.assertIsNone(result)
 | 
						|
 | 
						|
    def test_volume_set_state_failed(self):
 | 
						|
        self.snapshots_mock.reset_state.side_effect = exceptions.CommandError()
 | 
						|
        arglist = ['--state', 'error', self.snapshot.id]
 | 
						|
        verifylist = [('state', 'error'), ('snapshot', self.snapshot.id)]
 | 
						|
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
        try:
 | 
						|
            self.cmd.take_action(parsed_args)
 | 
						|
            self.fail('CommandError should be raised.')
 | 
						|
        except exceptions.CommandError as e:
 | 
						|
            self.assertEqual(
 | 
						|
                'One or more of the set operations failed', str(e)
 | 
						|
            )
 | 
						|
        self.snapshots_mock.reset_state.assert_called_once_with(
 | 
						|
            self.snapshot.id, 'error'
 | 
						|
        )
 | 
						|
 | 
						|
    def test_volume_set_name_and_state_failed(self):
 | 
						|
        self.snapshots_mock.reset_state.side_effect = exceptions.CommandError()
 | 
						|
        arglist = [
 | 
						|
            '--state',
 | 
						|
            'error',
 | 
						|
            "--name",
 | 
						|
            "new_snapshot",
 | 
						|
            self.snapshot.id,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ('state', 'error'),
 | 
						|
            ("name", "new_snapshot"),
 | 
						|
            ('snapshot', self.snapshot.id),
 | 
						|
        ]
 | 
						|
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
        try:
 | 
						|
            self.cmd.take_action(parsed_args)
 | 
						|
            self.fail('CommandError should be raised.')
 | 
						|
        except exceptions.CommandError as e:
 | 
						|
            self.assertEqual(
 | 
						|
                'One or more of the set operations failed', str(e)
 | 
						|
            )
 | 
						|
        kwargs = {
 | 
						|
            "name": "new_snapshot",
 | 
						|
        }
 | 
						|
        self.snapshots_mock.update.assert_called_once_with(
 | 
						|
            self.snapshot.id, **kwargs
 | 
						|
        )
 | 
						|
        self.snapshots_mock.reset_state.assert_called_once_with(
 | 
						|
            self.snapshot.id, 'error'
 | 
						|
        )
 | 
						|
 | 
						|
 | 
						|
class TestVolumeSnapshotShow(TestVolumeSnapshot):
 | 
						|
    columns = (
 | 
						|
        'created_at',
 | 
						|
        'description',
 | 
						|
        'id',
 | 
						|
        'name',
 | 
						|
        'properties',
 | 
						|
        'size',
 | 
						|
        'status',
 | 
						|
        'volume_id',
 | 
						|
    )
 | 
						|
 | 
						|
    def setUp(self):
 | 
						|
        super().setUp()
 | 
						|
 | 
						|
        self.snapshot = volume_fakes.create_one_snapshot()
 | 
						|
 | 
						|
        self.data = (
 | 
						|
            self.snapshot.created_at,
 | 
						|
            self.snapshot.description,
 | 
						|
            self.snapshot.id,
 | 
						|
            self.snapshot.name,
 | 
						|
            format_columns.DictColumn(self.snapshot.metadata),
 | 
						|
            self.snapshot.size,
 | 
						|
            self.snapshot.status,
 | 
						|
            self.snapshot.volume_id,
 | 
						|
        )
 | 
						|
 | 
						|
        self.snapshots_mock.get.return_value = self.snapshot
 | 
						|
        # Get the command object to test
 | 
						|
        self.cmd = volume_snapshot.ShowVolumeSnapshot(self.app, None)
 | 
						|
 | 
						|
    def test_snapshot_show(self):
 | 
						|
        arglist = [self.snapshot.id]
 | 
						|
        verifylist = [("snapshot", self.snapshot.id)]
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        columns, data = self.cmd.take_action(parsed_args)
 | 
						|
        self.snapshots_mock.get.assert_called_with(self.snapshot.id)
 | 
						|
 | 
						|
        self.assertEqual(self.columns, columns)
 | 
						|
        self.assertCountEqual(self.data, data)
 | 
						|
 | 
						|
 | 
						|
class TestVolumeSnapshotUnset(TestVolumeSnapshot):
 | 
						|
    snapshot = volume_fakes.create_one_snapshot()
 | 
						|
 | 
						|
    def setUp(self):
 | 
						|
        super().setUp()
 | 
						|
 | 
						|
        self.snapshots_mock.get.return_value = self.snapshot
 | 
						|
        self.snapshots_mock.delete_metadata.return_value = None
 | 
						|
        # Get the command object to mock
 | 
						|
        self.cmd = volume_snapshot.UnsetVolumeSnapshot(self.app, None)
 | 
						|
 | 
						|
    def test_snapshot_unset(self):
 | 
						|
        arglist = [
 | 
						|
            "--property",
 | 
						|
            "foo",
 | 
						|
            self.snapshot.id,
 | 
						|
        ]
 | 
						|
        verifylist = [
 | 
						|
            ("property", ["foo"]),
 | 
						|
            ("snapshot", self.snapshot.id),
 | 
						|
        ]
 | 
						|
 | 
						|
        parsed_args = self.check_parser(self.cmd, arglist, verifylist)
 | 
						|
 | 
						|
        result = self.cmd.take_action(parsed_args)
 | 
						|
 | 
						|
        self.snapshots_mock.delete_metadata.assert_called_with(
 | 
						|
            self.snapshot.id, ["foo"]
 | 
						|
        )
 | 
						|
        self.assertIsNone(result)
 |