Add negative tests for baremetal node commands
Change-Id: I56e64cc37ffbce448dfef3c9dc34c909c308c7b2
This commit is contained in:
committed by
Kyrylo Romanenko
parent
ea433420d9
commit
540c59bf9c
@@ -0,0 +1,89 @@
|
||||
# Copyright (c) 2017 Mirantis, Inc.
|
||||
#
|
||||
# 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
|
||||
import six
|
||||
from tempest.lib import exceptions
|
||||
|
||||
from ironicclient.tests.functional.osc.v1 import base
|
||||
|
||||
|
||||
@ddt.ddt
|
||||
class BaremetalNodeNegativeTests(base.TestCase):
|
||||
"""Negative tests for baremetal node commands."""
|
||||
|
||||
def setUp(self):
|
||||
super(BaremetalNodeNegativeTests, self).setUp()
|
||||
self.node = self.node_create()
|
||||
|
||||
@staticmethod
|
||||
def constuct_cmd(base_cmd, argument, value):
|
||||
cmd = base_cmd
|
||||
if argument:
|
||||
cmd = '{} {} {}'.format(cmd, argument, value)
|
||||
return cmd
|
||||
|
||||
@ddt.data(
|
||||
('', '', 'error: argument --driver is required'),
|
||||
('--driver', 'wrongdriver',
|
||||
'No valid host was found. Reason: No conductor service '
|
||||
'registered which supports driver wrongdriver.')
|
||||
)
|
||||
@ddt.unpack
|
||||
def test_create_driver(self, argument, value, ex_text):
|
||||
"""Negative test for baremetal node driver options."""
|
||||
base_cmd = 'baremetal node create'
|
||||
command = self.constuct_cmd(base_cmd, argument, value)
|
||||
six.assertRaisesRegex(self, exceptions.CommandFailed, ex_text,
|
||||
self.openstack, command)
|
||||
|
||||
def test_delete_no_node(self):
|
||||
"""Test for baremetal node delete without node specified."""
|
||||
command = 'baremetal node delete'
|
||||
ex_text = 'error: too few arguments'
|
||||
six.assertRaisesRegex(self, exceptions.CommandFailed, ex_text,
|
||||
self.openstack, command)
|
||||
|
||||
def test_list_wrong_argument(self):
|
||||
"""Test for baremetal node list with wrong argument."""
|
||||
command = 'baremetal node list --wrong_arg'
|
||||
ex_text = 'error: unrecognized arguments: --wrong_arg'
|
||||
six.assertRaisesRegex(self, exceptions.CommandFailed, ex_text,
|
||||
self.openstack, command)
|
||||
|
||||
@ddt.data(
|
||||
('--property', '', 'error: too few arguments'),
|
||||
('--property', 'prop', 'Attributes must be a list of PATH=VALUE')
|
||||
)
|
||||
@ddt.unpack
|
||||
def test_set_property(self, argument, value, ex_text):
|
||||
"""Negative test for baremetal node set command options."""
|
||||
base_cmd = 'baremetal node set'
|
||||
command = '{} {}'.format(
|
||||
self.constuct_cmd(base_cmd, argument, value), self.node['uuid'])
|
||||
six.assertRaisesRegex(self, exceptions.CommandFailed, ex_text,
|
||||
self.openstack, command)
|
||||
|
||||
@ddt.data(
|
||||
('--property', '', 'error: too few arguments'),
|
||||
('--property', 'prop', "Reason: can't remove non-existent object")
|
||||
)
|
||||
@ddt.unpack
|
||||
def test_unset_property(self, argument, value, ex_text):
|
||||
"""Negative test for baremetal node unset command options."""
|
||||
base_cmd = 'baremetal node unset'
|
||||
command = '{} {}'.format(
|
||||
self.constuct_cmd(base_cmd, argument, value), self.node['uuid'])
|
||||
six.assertRaisesRegex(self, exceptions.CommandFailed, ex_text,
|
||||
self.openstack, command)
|
||||
Reference in New Issue
Block a user