1bd2bf67da
openstackclient fails to get image list when the image api endpoint has 'v2' substring in the URL. Instead of checking whether the api endpoint URL terminates with '/v2', the current logic is checking whether 'v2' appears anywhere in the endpoint string. This issue was discovered on a production setup where certain server names had 'v2' in their names. For example, when a hostname is gopher.dev20.com, the image list APIs fail. This commit updates the unit test to reflect this scenario. Without the change in openstackclient/api/image_v2.py, all the unit tests fail. Co-Authored-By: sergio.carvalho@workday.com Change-Id: I26b85afd646938272dbabe8e045b337b7df58c7d Closes-Bug: 1652827
99 lines
2.7 KiB
Python
99 lines
2.7 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.
|
|
#
|
|
|
|
"""Image v2 API Library Tests"""
|
|
|
|
from keystoneauth1 import session
|
|
from requests_mock.contrib import fixture
|
|
|
|
from openstackclient.api import image_v2
|
|
from openstackclient.tests.unit import utils
|
|
|
|
|
|
FAKE_PROJECT = 'xyzpdq'
|
|
FAKE_URL = 'http://gopher.dev20.com'
|
|
|
|
|
|
class TestImageAPIv2(utils.TestCase):
|
|
|
|
def setUp(self):
|
|
super(TestImageAPIv2, self).setUp()
|
|
|
|
sess = session.Session()
|
|
self.api = image_v2.APIv2(session=sess, endpoint=FAKE_URL)
|
|
self.requests_mock = self.useFixture(fixture.Fixture())
|
|
|
|
|
|
class TestImage(TestImageAPIv2):
|
|
|
|
PUB_PROT = {
|
|
'id': '1',
|
|
'name': 'pub1',
|
|
'visibility': 'public',
|
|
'protected': True,
|
|
}
|
|
PUB_NOPROT = {
|
|
'id': '2',
|
|
'name': 'pub2-noprot',
|
|
'visibility': 'public',
|
|
'protected': False,
|
|
}
|
|
NOPUB_PROT = {
|
|
'id': '3',
|
|
'name': 'priv3',
|
|
'visibility': 'private',
|
|
'protected': True,
|
|
}
|
|
NOPUB_NOPROT = {
|
|
'id': '4',
|
|
'name': 'priv4-noprot',
|
|
'visibility': 'private',
|
|
'protected': False,
|
|
}
|
|
LIST_IMAGE_RESP = [
|
|
PUB_PROT,
|
|
PUB_NOPROT,
|
|
NOPUB_PROT,
|
|
NOPUB_NOPROT,
|
|
]
|
|
|
|
def test_image_list_no_options(self):
|
|
self.requests_mock.register_uri(
|
|
'GET',
|
|
FAKE_URL + '/v2/images',
|
|
json={'images': self.LIST_IMAGE_RESP},
|
|
status_code=200,
|
|
)
|
|
ret = self.api.image_list()
|
|
self.assertEqual(self.LIST_IMAGE_RESP, ret)
|
|
|
|
def test_image_list_public(self):
|
|
self.requests_mock.register_uri(
|
|
'GET',
|
|
FAKE_URL + '/v2/images',
|
|
json={'images': [self.PUB_PROT, self.PUB_NOPROT]},
|
|
status_code=200,
|
|
)
|
|
ret = self.api.image_list(public=True)
|
|
self.assertEqual([self.PUB_PROT, self.PUB_NOPROT], ret)
|
|
|
|
def test_image_list_private(self):
|
|
self.requests_mock.register_uri(
|
|
'GET',
|
|
FAKE_URL + '/v2/images',
|
|
json={'images': [self.NOPUB_PROT, self.NOPUB_NOPROT]},
|
|
status_code=200,
|
|
)
|
|
ret = self.api.image_list(public=True)
|
|
self.assertEqual([self.NOPUB_PROT, self.NOPUB_NOPROT], ret)
|