Freezer command line tool add argument: "--os-backup-api-version"

1. You can select an API version to use by ``--os-backup-api-version`` option or by
   setting corresponding environment variable:

       export OS_BACKUP_API_VERSION=1

   Default Freezer API used is v2.
2. Add freezerclient.shell unit test cases.

Change-Id: I2946c7397834046fca3f1155588cd04083e07302
This commit is contained in:
Cai Hui 2018-10-08 03:22:17 -04:00
parent 57f3fa1c96
commit 234d57331c
3 changed files with 156 additions and 8 deletions

View File

@ -98,6 +98,13 @@ class FreezerShell(app.App):
help='Specify identity endpoint', help='Specify identity endpoint',
) )
parser.add_argument(
'--os-backup-api-version',
dest='os_backup_api_version',
default=os.environ.get('OS_BACKUP_API_VERSION', '2'),
help='Backup API version: 1 or 2'
)
parser.add_argument( parser.add_argument(
'--os-backup-url', '--os-backup-url',
dest='os_backup_url', dest='os_backup_url',
@ -250,7 +257,8 @@ class FreezerShell(app.App):
'cacert': self.options.os_cacert, 'cacert': self.options.os_cacert,
'insecure': self.options.insecure 'insecure': self.options.insecure
} }
return utils.get_client_instance(opts) return utils.get_client_instance(
opts, api_version=self.options.os_backup_api_version)
def main(argv=sys.argv[1:]): def main(argv=sys.argv[1:]):

View File

@ -0,0 +1,137 @@
# (c) Copyright 2018 ZTE Corporation.
#
# 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 os
import re
import sys
import fixtures
import six
import testtools
from testtools import matchers
from freezerclient import shell as openstack_shell
DEFAULT_USERNAME = 'username'
DEFAULT_PASSWORD = 'password'
DEFAULT_PROJECT_ID = 'tenant_id'
DEFAULT_PROJECT_NAME = 'tenant_name'
DEFAULT_AUTH_URL = 'http://127.0.0.1:5000/v2.0/'
class ShellTest(testtools.TestCase):
FAKE_ENV = {
'OS_USERNAME': DEFAULT_USERNAME,
'OS_PASSWORD': DEFAULT_PASSWORD,
'OS_TENANT_ID': DEFAULT_PROJECT_ID,
'OS_TENANT_NAME': DEFAULT_PROJECT_NAME,
'OS_PROJECT_ID': DEFAULT_PROJECT_ID,
'OS_PROJECT_NAME': DEFAULT_PROJECT_NAME,
'OS_AUTH_URL': DEFAULT_AUTH_URL,
}
# 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, check=False, expected_val=0):
# expected_val is the expected return value after executing
# the command in FreezerShell
orig = (sys.stdout, sys.stderr)
clean_env = {}
_old_env, os.environ = os.environ, clean_env.copy()
try:
sys.stdout = six.moves.cStringIO()
sys.stderr = six.moves.cStringIO()
_shell = openstack_shell.FreezerShell()
_shell.run(argstr.split())
except SystemExit:
exc_type, exc_value, exc_traceback = sys.exc_info()
self.assertEqual(expected_val, exc_value.code)
finally:
stdout = sys.stdout.getvalue()
stderr = sys.stderr.getvalue()
sys.stdout.close()
sys.stderr.close()
sys.stdout, sys.stderr = orig
os.environ = _old_env
return stdout, stderr, _shell.options
def test_help(self):
required = 'usage:'
help_text, stderr, _ = self.shell('help')
self.assertThat(
help_text,
matchers.MatchesRegex(required))
def test_help_on_subcommand(self):
required = [
'.*?^usage: .* job-list']
stdout, stderr, _ = self.shell('help job-list')
for r in required:
self.assertThat(
stdout,
matchers.MatchesRegex(r, re.DOTALL | re.MULTILINE))
def test_help_command(self):
required = 'usage:'
help_text, stderr, _ = self.shell('help action-create')
self.assertThat(
help_text,
matchers.MatchesRegex(required))
def test_run_incomplete_command(self):
cmd = 'job-create'
stdout, stderr, _ = self.shell(cmd, check=True, expected_val=2)
search_str = "run job-create: error"
self.assertTrue(any(search_str in string for string
in stderr.split('\n')))
def test_set_os_backup_api_version(self):
cmd = (
'--os-backup-api-version 1 job-list')
stdout, stderr, options = self.shell(cmd)
self.assertEqual("1", options.os_backup_api_version)
def test_default_os_backup_api_version(self):
cmd = 'help job-list'
stdout, stderr, options = self.shell(cmd)
self.assertEqual("2", options.os_backup_api_version)
def test_set_os_username_password(self):
cmd = (
'--os-username caihui --os-password stack job-list')
stdout, stderr, options = self.shell(cmd)
self.assertEqual("caihui", options.os_username)
self.assertEqual("stack", options.os_password)
def test_set_os_project_name_id(self):
cmd = (
'--os-project-id tecs0000000001 \
--os-project-name tecs job-list')
stdout, stderr, options = self.shell(cmd)
self.assertEqual("tecs0000000001", options.os_project_id)
self.assertEqual("tecs", options.os_project_name)
def test_set_os_auth_url(self):
cmd = (
'--os-auth-url http://127.0.0.1:5001 job-list')
stdout, stderr, options = self.shell(cmd)
self.assertEqual("http://127.0.0.1:5001", options.os_auth_url)

View File

@ -143,13 +143,17 @@ def prepare_search(search_term):
return {} return {}
def check_api_version(): def check_api_version(api_version=None):
"""Check freezer version API to use """Check freezer version API to use
1: not multi-tenant, useful for infrastructure 1: not multi-tenant, useful for infrastructure
2: multi-tenant, useful for backup as a service 2: multi-tenant, useful for backup as a service
:return: str :return: str
""" """
freezer_api_version = os.environ.get('OS_BACKUP_API_VERSION', '2') if not api_version:
freezer_api_version = os.environ.get('OS_BACKUP_API_VERSION', '2')
else:
freezer_api_version = api_version
if freezer_api_version == '1': if freezer_api_version == '1':
return '1' return '1'
elif freezer_api_version == '2': elif freezer_api_version == '2':
@ -165,16 +169,15 @@ def get_client_class(api_version=None):
Returns freezerclient.v{x}.client.Client Returns freezerclient.v{x}.client.Client
:return: class :return: class
""" """
if not api_version: freezer_api_version = check_api_version(api_version)
api_version = check_api_version() api_string = 'freezerclient.v{0}.client.Client'.format(freezer_api_version)
api_string = 'freezerclient.v{0}.client.Client'.format(api_version)
return importutils.import_class(api_string) return importutils.import_class(api_string)
def get_client_instance(kwargs={}, opts=None): def get_client_instance(kwargs={}, opts=None, api_version=None):
"""Get Freezerclient Instance. """Get Freezerclient Instance.
We will the provided auth dict to instantiate a client instance We will the provided auth dict to instantiate a client instance
Returns freezerclient.v{x}.client.Client Object Returns freezerclient.v{x}.client.Client Object
:return: Object :return: Object
""" """
return get_client_class()(opts=opts, **kwargs) return get_client_class(api_version)(opts=opts, **kwargs)