Add a simple smoke test to be run in the grenade gate

This test only runs introspection on one node, nothing else.

Also make sure tempest gets our and ironic plugin.

Depends-On: Ia2a5b9cc535c7c46728eee6284a36340745e9043
Change-Id: Id12b6cc75977c32f0a9e1ada8ff954b8f4bc2e41
This commit is contained in:
Dmitry Tantsur 2016-07-01 14:22:51 +02:00 committed by dparalen
parent d970bf56da
commit 823f6d26a2
3 changed files with 81 additions and 49 deletions

View File

@ -1,3 +1,6 @@
# Enable our tests; also enable ironic tempest plugin as we depend on it.
export TEMPEST_PLUGINS="/opt/stack/new/ironic /opt/stack/new/ironic-inspector"
# Enabling Inspector grenade plug-in # Enabling Inspector grenade plug-in
# Based on Ironic/devstack/grenade/settings # Based on Ironic/devstack/grenade/settings
register_project_for_upgrade ironic-inspector register_project_for_upgrade ironic-inspector

View File

@ -14,11 +14,17 @@
import os import os
import time import time
import tempest
from tempest import config from tempest import config
from tempest.lib.common.api_version_utils import LATEST_MICROVERSION
from ironic_inspector.test.inspector_tempest_plugin import exceptions from ironic_inspector.test.inspector_tempest_plugin import exceptions
from ironic_inspector.test.inspector_tempest_plugin.services import \ from ironic_inspector.test.inspector_tempest_plugin.services import \
introspection_client introspection_client
from ironic_tempest_plugin.tests.api.admin.api_microversion_fixture import \
APIMicroversionFixture as IronicMicroversionFixture
from ironic_tempest_plugin.tests.scenario.baremetal_manager import \
BaremetalProvisionStates
from ironic_tempest_plugin.tests.scenario.baremetal_manager import \ from ironic_tempest_plugin.tests.scenario.baremetal_manager import \
BaremetalScenarioTest BaremetalScenarioTest
@ -29,8 +35,12 @@ CONF = config.CONF
class InspectorScenarioTest(BaremetalScenarioTest): class InspectorScenarioTest(BaremetalScenarioTest):
"""Provide harness to do Inspector scenario tests.""" """Provide harness to do Inspector scenario tests."""
wait_provisioning_state_interval = 15
credentials = ['primary', 'admin'] credentials = ['primary', 'admin']
ironic_api_version = LATEST_MICROVERSION
@classmethod @classmethod
def setup_clients(cls): def setup_clients(cls):
super(InspectorScenarioTest, cls).setup_clients() super(InspectorScenarioTest, cls).setup_clients()
@ -39,7 +49,15 @@ class InspectorScenarioTest(BaremetalScenarioTest):
def setUp(self): def setUp(self):
super(InspectorScenarioTest, self).setUp() super(InspectorScenarioTest, self).setUp()
# we rely on the 'available' provision_state; using latest
# microversion
self.useFixture(IronicMicroversionFixture(self.ironic_api_version))
self.flavor = self.baremetal_flavor() self.flavor = self.baremetal_flavor()
self.node_ids = {node['uuid'] for node in
self.node_filter(filter=lambda node:
node['provision_state'] ==
BaremetalProvisionStates.AVAILABLE)}
self.rule_purge()
def item_filter(self, list_method, show_method, def item_filter(self, list_method, show_method,
filter=lambda item: True, items=None): filter=lambda item: True, items=None):
@ -144,3 +162,31 @@ class InspectorScenarioTest(BaremetalScenarioTest):
{'stats': stats, {'stats': stats,
'timeout': timeout}) 'timeout': timeout})
raise exceptions.HypervisorUpdateTimeout(message) raise exceptions.HypervisorUpdateTimeout(message)
def node_cleanup(self, node_id):
if (self.node_show(node_id)['provision_state'] ==
BaremetalProvisionStates.AVAILABLE):
return
try:
self.baremetal_client.set_node_provision_state(node_id, 'provide')
except tempest.lib.exceptions.RestClientException:
# maybe node already cleaning or available
pass
self.wait_provisioning_state(
node_id, [BaremetalProvisionStates.AVAILABLE,
BaremetalProvisionStates.NOSTATE],
timeout=CONF.baremetal.unprovision_timeout,
interval=self.wait_provisioning_state_interval)
def introspect_node(self, node_id):
# in case there are properties remove those
patch = {('properties/%s' % key): None for key in
self.node_show(node_id)['properties']}
# reset any previous rule result
patch['extra/rule_success'] = None
self.node_update(node_id, patch)
self.baremetal_client.set_node_provision_state(node_id, 'manage')
self.baremetal_client.set_node_provision_state(node_id, 'inspect')
self.addCleanup(self.node_cleanup, node_id)

View File

@ -10,63 +10,15 @@
# License for the specific language governing permissions and limitations # License for the specific language governing permissions and limitations
# under the License. # under the License.
import tempest
from tempest.config import CONF from tempest.config import CONF
from tempest import test # noqa from tempest import test # noqa
from ironic_inspector.test.inspector_tempest_plugin.tests import manager from ironic_inspector.test.inspector_tempest_plugin.tests import manager
from ironic_tempest_plugin.tests.api.admin.api_microversion_fixture import \
APIMicroversionFixture as IronicMicroversionFixture
from ironic_tempest_plugin.tests.scenario.baremetal_manager import \ from ironic_tempest_plugin.tests.scenario.baremetal_manager import \
BaremetalProvisionStates BaremetalProvisionStates
from tempest.lib.common.api_version_utils import LATEST_MICROVERSION
class InspectorBasicTest(manager.InspectorScenarioTest): class InspectorBasicTest(manager.InspectorScenarioTest):
wait_provisioning_state_interval = 15
def node_cleanup(self, node_id):
if (self.node_show(node_id)['provision_state'] ==
BaremetalProvisionStates.AVAILABLE):
return
try:
self.baremetal_client.set_node_provision_state(node_id, 'provide')
except tempest.lib.exceptions.RestClientException:
# maybe node already cleaning or available
pass
self.wait_provisioning_state(
node_id, [BaremetalProvisionStates.AVAILABLE,
BaremetalProvisionStates.NOSTATE],
timeout=CONF.baremetal.unprovision_timeout,
interval=self.wait_provisioning_state_interval)
def introspect_node(self, node_id):
# in case there are properties remove those
patch = {('properties/%s' % key): None for key in
self.node_show(node_id)['properties']}
# reset any previous rule result
patch['extra/rule_success'] = None
self.node_update(node_id, patch)
self.baremetal_client.set_node_provision_state(node_id, 'manage')
self.baremetal_client.set_node_provision_state(node_id, 'inspect')
self.addCleanup(self.node_cleanup, node_id)
def setUp(self):
super(InspectorBasicTest, self).setUp()
# we rely on the 'available' provision_state; using latest
# microversion
self.useFixture(IronicMicroversionFixture(LATEST_MICROVERSION))
# avoid testing nodes that aren't available
self.node_ids = {node['uuid'] for node in
self.node_filter(filter=lambda node:
node['provision_state'] ==
BaremetalProvisionStates.AVAILABLE)}
if not self.node_ids:
self.skipTest('no available nodes detected')
self.rule_purge()
def verify_node_introspection_data(self, node): def verify_node_introspection_data(self, node):
self.assertEqual('yes', node['extra']['rule_success']) self.assertEqual('yes', node['extra']['rule_success'])
@ -98,7 +50,7 @@ class InspectorBasicTest(manager.InspectorScenarioTest):
@test.services('baremetal', 'compute', 'image', @test.services('baremetal', 'compute', 'image',
'network', 'object_storage') 'network', 'object_storage')
def test_baremetal_introspection(self): def test_baremetal_introspection(self):
"""This smoke test case follows this basic set of operations: """This smoke test case follows this set of operations:
* Fetches expected properties from baremetal flavor * Fetches expected properties from baremetal flavor
* Removes all properties from nodes * Removes all properties from nodes
@ -147,3 +99,34 @@ class InspectorBasicTest(manager.InspectorScenarioTest):
self.add_keypair() self.add_keypair()
ins, _node = self.boot_instance() ins, _node = self.boot_instance()
self.terminate_instance(ins) self.terminate_instance(ins)
class InspectorSmokeTest(manager.InspectorScenarioTest):
@test.idempotent_id('a702d1f1-88e4-42ce-88ef-cba2d9e3312e')
@test.attr(type='smoke')
@test.services('baremetal', 'compute', 'image',
'network', 'object_storage')
def test_baremetal_introspection(self):
"""This smoke test case follows this very basic set of operations:
* Fetches expected properties from baremetal flavor
* Removes all properties from one node
* Sets the node to manageable state
* Inspects the node
* Sets the node to available state
"""
# NOTE(dtantsur): we can't silently skip this test because it runs in
# grenade with several other tests, and we won't have any indication
# that it was not run.
assert self.node_ids, "No available nodes"
node_id = next(iter(self.node_ids))
self.introspect_node(node_id)
# settle down introspection
self.wait_for_introspection_finished([node_id])
self.wait_provisioning_state(
node_id, 'manageable',
timeout=CONF.baremetal_introspection.ironic_sync_timeout,
interval=self.wait_provisioning_state_interval)