Fix region support in mistralclient
Although mistral client already supports '--os-region-name', but it's not passed to mistral service properly. Even user has specified region when using CLI, mistral will still ignore the region when initialize other openstack service client Change-Id: Ia06779e7a5b657d044066ea4df6e4a18d035d27f
This commit is contained in:
parent
63f1fd5ab5
commit
6ae1bad9a0
@ -30,6 +30,7 @@ CERT_KEY = 'key'
|
|||||||
INSECURE = 'insecure'
|
INSECURE = 'insecure'
|
||||||
PROJECT_ID = 'project_id'
|
PROJECT_ID = 'project_id'
|
||||||
USER_ID = 'user_id'
|
USER_ID = 'user_id'
|
||||||
|
REGION_NAME = 'region_name'
|
||||||
|
|
||||||
TARGET_AUTH_TOKEN = 'target_auth_token'
|
TARGET_AUTH_TOKEN = 'target_auth_token'
|
||||||
TARGET_AUTH_URI = 'target_auth_url'
|
TARGET_AUTH_URI = 'target_auth_url'
|
||||||
@ -64,6 +65,7 @@ class HTTPClient(object):
|
|||||||
self.user_id = kwargs.get(USER_ID)
|
self.user_id = kwargs.get(USER_ID)
|
||||||
self.cacert = kwargs.get(CACERT)
|
self.cacert = kwargs.get(CACERT)
|
||||||
self.insecure = kwargs.get(INSECURE, False)
|
self.insecure = kwargs.get(INSECURE, False)
|
||||||
|
self.region_name = kwargs.get(REGION_NAME)
|
||||||
self.ssl_options = {}
|
self.ssl_options = {}
|
||||||
|
|
||||||
self.target_auth_token = kwargs.get(TARGET_AUTH_TOKEN)
|
self.target_auth_token = kwargs.get(TARGET_AUTH_TOKEN)
|
||||||
@ -160,6 +162,9 @@ class HTTPClient(object):
|
|||||||
if self.user_id:
|
if self.user_id:
|
||||||
headers['X-User-Id'] = self.user_id
|
headers['X-User-Id'] = self.user_id
|
||||||
|
|
||||||
|
if self.region_name:
|
||||||
|
headers['X-Region-Name'] = self.region_name
|
||||||
|
|
||||||
if self.target_auth_token:
|
if self.target_auth_token:
|
||||||
headers['X-Target-Auth-Token'] = self.target_auth_token
|
headers['X-Target-Auth-Token'] = self.target_auth_token
|
||||||
|
|
||||||
|
@ -564,6 +564,7 @@ class MistralShell(app.App):
|
|||||||
project_id=self.options.tenant_id or self.options.project_id,
|
project_id=self.options.tenant_id or self.options.project_id,
|
||||||
endpoint_type=self.options.endpoint_type,
|
endpoint_type=self.options.endpoint_type,
|
||||||
service_type=self.options.service_type,
|
service_type=self.options.service_type,
|
||||||
|
region_name=self.options.region_name,
|
||||||
auth_token=self.options.token,
|
auth_token=self.options.token,
|
||||||
cacert=self.options.os_cacert,
|
cacert=self.options.os_cacert,
|
||||||
insecure=self.options.insecure,
|
insecure=self.options.insecure,
|
||||||
|
@ -33,13 +33,15 @@ EXPECTED_URL = API_BASE_URL + API_URL
|
|||||||
AUTH_TOKEN = uuidutils.generate_uuid()
|
AUTH_TOKEN = uuidutils.generate_uuid()
|
||||||
PROJECT_ID = uuidutils.generate_uuid()
|
PROJECT_ID = uuidutils.generate_uuid()
|
||||||
USER_ID = uuidutils.generate_uuid()
|
USER_ID = uuidutils.generate_uuid()
|
||||||
|
REGION_NAME = 'fake_region'
|
||||||
PROFILER_HMAC_KEY = 'SECRET_HMAC_KEY'
|
PROFILER_HMAC_KEY = 'SECRET_HMAC_KEY'
|
||||||
PROFILER_TRACE_ID = uuidutils.generate_uuid()
|
PROFILER_TRACE_ID = uuidutils.generate_uuid()
|
||||||
|
|
||||||
EXPECTED_AUTH_HEADERS = {
|
EXPECTED_AUTH_HEADERS = {
|
||||||
'x-auth-token': AUTH_TOKEN,
|
'x-auth-token': AUTH_TOKEN,
|
||||||
'X-Project-Id': PROJECT_ID,
|
'X-Project-Id': PROJECT_ID,
|
||||||
'X-User-Id': USER_ID
|
'X-User-Id': USER_ID,
|
||||||
|
'X-Region-Name': REGION_NAME
|
||||||
}
|
}
|
||||||
|
|
||||||
EXPECTED_REQ_OPTIONS = {
|
EXPECTED_REQ_OPTIONS = {
|
||||||
@ -76,7 +78,8 @@ class HTTPClientTest(base.BaseTestCase):
|
|||||||
API_BASE_URL,
|
API_BASE_URL,
|
||||||
auth_token=AUTH_TOKEN,
|
auth_token=AUTH_TOKEN,
|
||||||
project_id=PROJECT_ID,
|
project_id=PROJECT_ID,
|
||||||
user_id=USER_ID
|
user_id=USER_ID,
|
||||||
|
region_name=REGION_NAME
|
||||||
)
|
)
|
||||||
|
|
||||||
@mock.patch.object(
|
@mock.patch.object(
|
||||||
@ -149,6 +152,7 @@ class HTTPClientTest(base.BaseTestCase):
|
|||||||
auth_token=AUTH_TOKEN,
|
auth_token=AUTH_TOKEN,
|
||||||
project_id=PROJECT_ID,
|
project_id=PROJECT_ID,
|
||||||
user_id=USER_ID,
|
user_id=USER_ID,
|
||||||
|
region_name=REGION_NAME,
|
||||||
target_auth_url=target_auth_url,
|
target_auth_url=target_auth_url,
|
||||||
target_auth_token=target_auth_token,
|
target_auth_token=target_auth_token,
|
||||||
target_project_id=target_project_id,
|
target_project_id=target_project_id,
|
||||||
|
@ -20,107 +20,117 @@ import mistralclient.tests.unit.base_shell_test as base
|
|||||||
class TestShell(base.BaseShellTests):
|
class TestShell(base.BaseShellTests):
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.client')
|
@mock.patch('mistralclient.api.client.client')
|
||||||
def test_command_no_mistral_url(self, mock):
|
def test_command_no_mistral_url(self, client_mock):
|
||||||
self.shell(
|
self.shell(
|
||||||
'workbook-list'
|
'workbook-list'
|
||||||
)
|
)
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
params = mock.call_args
|
params = client_mock.call_args
|
||||||
self.assertEqual('', params[1]['mistral_url'])
|
self.assertEqual('', params[1]['mistral_url'])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.client')
|
@mock.patch('mistralclient.api.client.client')
|
||||||
def test_command_with_mistral_url(self, mock):
|
def test_command_with_mistral_url(self, client_mock):
|
||||||
self.shell(
|
self.shell(
|
||||||
'--os-mistral-url=http://localhost:8989/v2 workbook-list'
|
'--os-mistral-url=http://localhost:8989/v2 workbook-list'
|
||||||
)
|
)
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
params = mock.call_args
|
params = client_mock.call_args
|
||||||
self.assertEqual('http://localhost:8989/v2',
|
self.assertEqual('http://localhost:8989/v2',
|
||||||
params[1]['mistral_url'])
|
params[1]['mistral_url'])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.determine_client_version')
|
@mock.patch('mistralclient.api.client.determine_client_version')
|
||||||
def test_mistral_version(self, mock):
|
def test_mistral_version(self, client_mock):
|
||||||
self.shell(
|
self.shell(
|
||||||
'--os-mistral-version=v1 workbook-list'
|
'--os-mistral-version=v1 workbook-list'
|
||||||
)
|
)
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
mistral_version = mock.call_args
|
mistral_version = client_mock.call_args
|
||||||
self.assertEqual('v1', mistral_version[0][0])
|
self.assertEqual('v1', mistral_version[0][0])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.determine_client_version')
|
@mock.patch('mistralclient.api.client.determine_client_version')
|
||||||
def test_no_mistral_version(self, mock):
|
def test_no_mistral_version(self, client_mock):
|
||||||
self.shell('workbook-list')
|
self.shell('workbook-list')
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
mistral_version = mock.call_args
|
mistral_version = client_mock.call_args
|
||||||
self.assertEqual('v2', mistral_version[0][0])
|
self.assertEqual('v2', mistral_version[0][0])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.client')
|
@mock.patch('mistralclient.api.client.client')
|
||||||
def test_service_type(self, mock):
|
def test_service_type(self, client_mock):
|
||||||
self.shell('--os-mistral-service-type=test workbook-list')
|
self.shell('--os-mistral-service-type=test workbook-list')
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
parmters = mock.call_args
|
parmters = client_mock.call_args
|
||||||
self.assertEqual('test', parmters[1]['service_type'])
|
self.assertEqual('test', parmters[1]['service_type'])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.client')
|
@mock.patch('mistralclient.api.client.client')
|
||||||
def test_no_service_type(self, mock):
|
def test_no_service_type(self, client_mock):
|
||||||
self.shell('workbook-list')
|
self.shell('workbook-list')
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
params = mock.call_args
|
params = client_mock.call_args
|
||||||
self.assertEqual('workflowv2', params[1]['service_type'])
|
self.assertEqual('workflowv2', params[1]['service_type'])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.client')
|
@mock.patch('mistralclient.api.client.client')
|
||||||
def test_endpoint_type(self, mock):
|
def test_endpoint_type(self, client_mock):
|
||||||
self.shell('--os-mistral-endpoint-type=adminURL workbook-list')
|
self.shell('--os-mistral-endpoint-type=adminURL workbook-list')
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
params = mock.call_args
|
params = client_mock.call_args
|
||||||
self.assertEqual('adminURL', params[1]['endpoint_type'])
|
self.assertEqual('adminURL', params[1]['endpoint_type'])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.client')
|
@mock.patch('mistralclient.api.client.client')
|
||||||
def test_no_endpoint_type(self, mock):
|
def test_no_endpoint_type(self, client_mock):
|
||||||
self.shell('workbook-list')
|
self.shell('workbook-list')
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
params = mock.call_args
|
params = client_mock.call_args
|
||||||
self.assertEqual('publicURL', params[1]['endpoint_type'])
|
self.assertEqual('publicURL', params[1]['endpoint_type'])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.client')
|
@mock.patch('mistralclient.api.client.client')
|
||||||
def test_auth_url(self, mock):
|
def test_auth_url(self, client_mock):
|
||||||
self.shell(
|
self.shell(
|
||||||
'--os-auth-url=https://127.0.0.1:35357/v3 '
|
'--os-auth-url=https://127.0.0.1:35357/v3 '
|
||||||
'--os-username=admin '
|
'--os-username=admin '
|
||||||
'--os-password=1234 '
|
'--os-password=1234 '
|
||||||
'workbook-list'
|
'workbook-list'
|
||||||
)
|
)
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
params = mock.call_args
|
params = client_mock.call_args
|
||||||
self.assertEqual('https://127.0.0.1:35357/v3', params[1]['auth_url'])
|
self.assertEqual('https://127.0.0.1:35357/v3', params[1]['auth_url'])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.client')
|
@mock.patch('mistralclient.api.client.client')
|
||||||
def test_no_auth_url(self, mock):
|
def test_no_auth_url(self, client_mock):
|
||||||
self.shell('workbook-list')
|
self.shell('workbook-list')
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
params = mock.call_args
|
params = client_mock.call_args
|
||||||
self.assertEqual('', params[1]['auth_url'])
|
self.assertEqual('', params[1]['auth_url'])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.client')
|
@mock.patch('mistralclient.api.client.client')
|
||||||
def test_default_auth_url_with_os_password(self, mock):
|
def test_default_auth_url_with_os_password(self, client_mock):
|
||||||
self.shell('--os-username=admin --os-password=1234 workbook-list')
|
self.shell('--os-username=admin --os-password=1234 workbook-list')
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
params = mock.call_args
|
params = client_mock.call_args
|
||||||
self.assertEqual('http://localhost:35357/v3', params[1]['auth_url'])
|
self.assertEqual('http://localhost:35357/v3', params[1]['auth_url'])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.client')
|
@mock.patch('mistralclient.api.client.client')
|
||||||
def test_default_auth_url_with_os_auth_token(self, mock):
|
def test_default_auth_url_with_os_auth_token(self, client_mock):
|
||||||
self.shell(
|
self.shell(
|
||||||
'--os-auth-token=abcd1234 '
|
'--os-auth-token=abcd1234 '
|
||||||
'workbook-list'
|
'workbook-list'
|
||||||
)
|
)
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
params = mock.call_args
|
params = client_mock.call_args
|
||||||
self.assertEqual('http://localhost:35357/v3', params[1]['auth_url'])
|
self.assertEqual('http://localhost:35357/v3', params[1]['auth_url'])
|
||||||
|
|
||||||
@mock.patch('mistralclient.api.client.client')
|
@mock.patch('mistralclient.api.client.client')
|
||||||
def test_profile(self, mock):
|
def test_profile(self, client_mock):
|
||||||
self.shell('--profile=SECRET_HMAC_KEY workbook-list')
|
self.shell('--profile=SECRET_HMAC_KEY workbook-list')
|
||||||
self.assertTrue(mock.called)
|
self.assertTrue(client_mock.called)
|
||||||
params = mock.call_args
|
params = client_mock.call_args
|
||||||
self.assertEqual('SECRET_HMAC_KEY', params[1]['profile'])
|
self.assertEqual('SECRET_HMAC_KEY', params[1]['profile'])
|
||||||
|
|
||||||
|
@mock.patch('mistralclient.api.client.client')
|
||||||
|
def test_region_name(self, client_mock):
|
||||||
|
self.shell('--os-region-name=RegionOne workbook-list')
|
||||||
|
|
||||||
|
self.assertTrue(client_mock.called)
|
||||||
|
|
||||||
|
params = client_mock.call_args
|
||||||
|
|
||||||
|
self.assertEqual('RegionOne', params[1]['region_name'])
|
||||||
|
Loading…
Reference in New Issue
Block a user