124 lines
		
	
	
		
			4.3 KiB
		
	
	
	
		
			Python
		
	
	
	
	
	
			
		
		
	
	
			124 lines
		
	
	
		
			4.3 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.
 | 
						|
 | 
						|
import argparse
 | 
						|
import re
 | 
						|
import sys
 | 
						|
 | 
						|
import fixtures
 | 
						|
from six import moves
 | 
						|
from testtools import matchers
 | 
						|
 | 
						|
from cinderclient import exceptions
 | 
						|
from cinderclient import shell
 | 
						|
from cinderclient.tests import utils
 | 
						|
 | 
						|
 | 
						|
class ShellTest(utils.TestCase):
 | 
						|
 | 
						|
    FAKE_ENV = {
 | 
						|
        'OS_USERNAME': 'username',
 | 
						|
        'OS_PASSWORD': 'password',
 | 
						|
        'OS_TENANT_NAME': 'tenant_name',
 | 
						|
        'OS_AUTH_URL': 'http://no.where',
 | 
						|
    }
 | 
						|
 | 
						|
    # Patch os.environ to avoid required auth info.
 | 
						|
    def setUp(self):
 | 
						|
        super(ShellTest, self).setUp()
 | 
						|
        for var in self.FAKE_ENV:
 | 
						|
            self.useFixture(fixtures.EnvironmentVariable(var,
 | 
						|
                                                         self.FAKE_ENV[var]))
 | 
						|
 | 
						|
    def shell(self, argstr):
 | 
						|
        orig = sys.stdout
 | 
						|
        try:
 | 
						|
            sys.stdout = moves.StringIO()
 | 
						|
            _shell = shell.OpenStackCinderShell()
 | 
						|
            _shell.main(argstr.split())
 | 
						|
        except SystemExit:
 | 
						|
            exc_type, exc_value, exc_traceback = sys.exc_info()
 | 
						|
            self.assertEqual(exc_value.code, 0)
 | 
						|
        finally:
 | 
						|
            out = sys.stdout.getvalue()
 | 
						|
            sys.stdout.close()
 | 
						|
            sys.stdout = orig
 | 
						|
 | 
						|
        return out
 | 
						|
 | 
						|
    def test_help_unknown_command(self):
 | 
						|
        self.assertRaises(exceptions.CommandError, self.shell, 'help foofoo')
 | 
						|
 | 
						|
    def test_help(self):
 | 
						|
        required = [
 | 
						|
            '.*?^usage: ',
 | 
						|
            '.*?(?m)^\s+create\s+Creates a volume.',
 | 
						|
            '.*?(?m)^Run "cinder help SUBCOMMAND" for help on a subcommand.',
 | 
						|
        ]
 | 
						|
        help_text = self.shell('help')
 | 
						|
        for r in required:
 | 
						|
            self.assertThat(help_text,
 | 
						|
                            matchers.MatchesRegex(r, re.DOTALL | re.MULTILINE))
 | 
						|
 | 
						|
    def test_help_on_subcommand(self):
 | 
						|
        required = [
 | 
						|
            '.*?^usage: cinder list',
 | 
						|
            '.*?(?m)^Lists all volumes.',
 | 
						|
        ]
 | 
						|
        help_text = self.shell('help list')
 | 
						|
        for r in required:
 | 
						|
            self.assertThat(help_text,
 | 
						|
                            matchers.MatchesRegex(r, re.DOTALL | re.MULTILINE))
 | 
						|
 | 
						|
 | 
						|
class CinderClientArgumentParserTest(utils.TestCase):
 | 
						|
    def test_ambiguity_solved_for_one_visible_argument(self):
 | 
						|
        parser = shell.CinderClientArgumentParser(add_help=False)
 | 
						|
        parser.add_argument('--test-parameter',
 | 
						|
                            dest='visible_param',
 | 
						|
                            action='store_true')
 | 
						|
        parser.add_argument('--test_parameter',
 | 
						|
                            dest='hidden_param',
 | 
						|
                            action='store_true',
 | 
						|
                            help=argparse.SUPPRESS)
 | 
						|
 | 
						|
        opts = parser.parse_args(['--test'])
 | 
						|
 | 
						|
        #visible argument must be set
 | 
						|
        self.assertTrue(opts.visible_param)
 | 
						|
        self.assertFalse(opts.hidden_param)
 | 
						|
 | 
						|
    def test_raise_ambiguity_error_two_visible_argument(self):
 | 
						|
        parser = shell.CinderClientArgumentParser(add_help=False)
 | 
						|
        parser.add_argument('--test-parameter',
 | 
						|
                            dest="visible_param1",
 | 
						|
                            action='store_true')
 | 
						|
        parser.add_argument('--test_parameter',
 | 
						|
                            dest="visible_param2",
 | 
						|
                            action='store_true')
 | 
						|
 | 
						|
        self.assertRaises(SystemExit, parser.parse_args, ['--test'])
 | 
						|
 | 
						|
    def test_raise_ambiguity_error_two_hidden_argument(self):
 | 
						|
        parser = shell.CinderClientArgumentParser(add_help=False)
 | 
						|
        parser.add_argument('--test-parameter',
 | 
						|
                            dest="hidden_param1",
 | 
						|
                            action='store_true',
 | 
						|
                            help=argparse.SUPPRESS)
 | 
						|
        parser.add_argument('--test_parameter',
 | 
						|
                            dest="hidden_param2",
 | 
						|
                            action='store_true',
 | 
						|
                            help=argparse.SUPPRESS)
 | 
						|
 | 
						|
        self.assertRaises(SystemExit, parser.parse_args, ['--test'])
 |