82a571c486
Currently, Manila CI Tempest jobs use deprecated options of Tempest. Recently, latest version of Tempest dropped them [1]. Manila CI jobs work ok, because they check out specific version of Tempest. But it will work until first Devstack update for some one more Tempest feature and then we will be forced to use latest Tempest again. Switch to supported approach of setting up users in Tempest, to avoid such sudden blockers. [1] I8c24cd17f643083dde71ab2bd2a38417c54aeccb Change-Id: I5b3ebab52ea1401f6f7a116d1260268eb10ebe0c Closes-Bug: #1586129
101 lines
3.9 KiB
Python
101 lines
3.9 KiB
Python
# Copyright 2014 Mirantis Inc.
|
|
# All Rights Reserved.
|
|
#
|
|
# 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 ddt
|
|
from tempest.lib import exceptions as lib_exc
|
|
from tempest import test
|
|
|
|
from manila_tempest_tests.tests.api import base
|
|
|
|
|
|
@ddt.ddt
|
|
class ServicesAdminNegativeTest(base.BaseSharesMixedTest):
|
|
|
|
@classmethod
|
|
def resource_setup(cls):
|
|
super(ServicesAdminNegativeTest, cls).resource_setup()
|
|
cls.admin_client = cls.admin_shares_v2_client
|
|
cls.member_client = cls.shares_v2_client
|
|
|
|
@test.attr(type=[base.TAG_NEGATIVE, base.TAG_API])
|
|
def test_list_services_with_non_admin_user(self):
|
|
self.assertRaises(lib_exc.Forbidden,
|
|
self.member_client.list_services)
|
|
|
|
@test.attr(type=[base.TAG_NEGATIVE, base.TAG_API])
|
|
def test_get_service_by_invalid_params(self):
|
|
# All services are expected if send the request with invalid parameter
|
|
services = self.admin_client.list_services()
|
|
params = {'fake_param': 'fake_param_value'}
|
|
services_fake = self.admin_client.list_services(params)
|
|
self.assertEqual(len(services), len(services_fake))
|
|
|
|
# "update_at" field could be updated before second request,
|
|
# so do not take it in account.
|
|
for service in services + services_fake:
|
|
service["updated_at"] = "removed_possible_difference"
|
|
|
|
msg = ('Unexpected service list. Expected %s, got %s.' %
|
|
(services, services_fake))
|
|
self.assertEqual(sorted(services, key=lambda service: service['id']),
|
|
sorted(services_fake,
|
|
key=lambda service: service['id']),
|
|
msg)
|
|
|
|
@test.attr(type=[base.TAG_NEGATIVE, base.TAG_API])
|
|
def test_get_service_by_invalid_host(self):
|
|
params = {'host': 'fake_host'}
|
|
services_fake = self.admin_client.list_services(params)
|
|
self.assertEqual(0, len(services_fake))
|
|
|
|
@test.attr(type=[base.TAG_NEGATIVE, base.TAG_API])
|
|
def test_get_service_by_invalid_binary(self):
|
|
params = {'binary': 'fake_binary'}
|
|
services_fake = self.admin_client.list_services(params)
|
|
self.assertEqual(0, len(services_fake))
|
|
|
|
@test.attr(type=[base.TAG_NEGATIVE, base.TAG_API])
|
|
def test_get_service_by_invalid_zone(self):
|
|
params = {'zone': 'fake_zone'}
|
|
services_fake = self.admin_client.list_services(params)
|
|
self.assertEqual(0, len(services_fake))
|
|
|
|
@test.attr(type=[base.TAG_NEGATIVE, base.TAG_API])
|
|
def test_get_service_by_invalid_status(self):
|
|
params = {'status': 'fake_status'}
|
|
services_fake = self.admin_client.list_services(params)
|
|
self.assertEqual(0, len(services_fake))
|
|
|
|
@test.attr(type=[base.TAG_NEGATIVE, base.TAG_API])
|
|
def test_get_service_by_invalid_state(self):
|
|
params = {'state': 'fake_state'}
|
|
services_fake = self.admin_client.list_services(params)
|
|
self.assertEqual(0, len(services_fake))
|
|
|
|
@test.attr(type=[base.TAG_NEGATIVE, base.TAG_API])
|
|
@ddt.data(
|
|
('os-services', '2.7'),
|
|
('services', '2.6'),
|
|
('services', '2.0'),
|
|
)
|
|
@ddt.unpack
|
|
@base.skip_if_microversion_not_supported("2.7")
|
|
def test_list_services_with_wrong_versions(self, url, version):
|
|
self.assertRaises(
|
|
lib_exc.NotFound,
|
|
self.admin_client.list_services,
|
|
version=version, url=url,
|
|
)
|