Repair cinder integration tests

- Use image from nova scenario tests for cinder tests
- Correct environment status wait function
- Replace backup waiters with new tempest changes
- Use devstack trueorfalse common function to determine
boolean values

Closes-Bug: #1626872

Change-Id: Id2172d3d9b314eb8132d97ec8868028c714a35c3
This commit is contained in:
Victor Ryzhenkin 2016-08-08 02:31:23 +03:00
parent 51b1b710a3
commit f547dff5c4
8 changed files with 197 additions and 54 deletions

View File

@ -176,7 +176,7 @@ function configure_murano {
iniset $MURANO_CONF_FILE DEFAULT home_region $REGION_NAME iniset $MURANO_CONF_FILE DEFAULT home_region $REGION_NAME
# Murano Policy Enforcement Configuration # Murano Policy Enforcement Configuration
if [[ -n "$MURANO_ENABLE_MODEL_POLICY_ENFORCEMENT" ]]; then if [[ "$MURANO_ENABLE_MODEL_POLICY_ENFORCEMENT" == "True" ]]; then
iniset $MURANO_CONF_FILE engine enable_model_policy_enforcer $MURANO_ENABLE_MODEL_POLICY_ENFORCEMENT iniset $MURANO_CONF_FILE engine enable_model_policy_enforcer $MURANO_ENABLE_MODEL_POLICY_ENFORCEMENT
fi fi
@ -358,6 +358,7 @@ function setup_core_library() {
remove_core_apps_zip remove_core_apps_zip
} }
# install_murano() - Collect source and prepare # install_murano() - Collect source and prepare
function install_murano() { function install_murano() {
install_murano_pythonclient install_murano_pythonclient
@ -443,6 +444,15 @@ function configure_murano_tempest_plugin() {
if is_murano_backend_glare; then if is_murano_backend_glare; then
iniset $TEMPEST_CONFIG application_catalog glare_backend "True" iniset $TEMPEST_CONFIG application_catalog glare_backend "True"
fi fi
if [[ "$TEMPEST_MURANO_SCENARIO_TESTS_ENABLED" == "True" ]]; then
if is_service_enabled cinder; then
iniset $TEMPEST_CONFIG application_catalog cinder_volume_tests "True"
fi
if [[ "$TEMPEST_MURANO_DEPLOYMENT_TESTS_ENABLED" == "True" ]]; then
iniset $TEMPEST_CONFIG application_catalog deployment_tests "True"
iniset $TEMPEST_CONFIG application_catalog linux_image "$CLOUD_IMAGE_NAME"
fi
fi
fi fi
} }

View File

@ -17,8 +17,13 @@ MURANO_CONF_DIR=${MURANO_CONF_DIR:-/etc/murano}
MURANO_CONF_FILE=${MURANO_CONF_DIR}/murano.conf MURANO_CONF_FILE=${MURANO_CONF_DIR}/murano.conf
MURANO_CFAPI_CONF_FILE=${MURANO_CONF_DIR}/murano-cfapi.conf MURANO_CFAPI_CONF_FILE=${MURANO_CONF_DIR}/murano-cfapi.conf
MURANO_POLICY_FILE=${MURANO_CONF_DIR}/policy.json MURANO_POLICY_FILE=${MURANO_CONF_DIR}/policy.json
MURANO_DEBUG=${MURANO_DEBUG:-True} MURANO_DEBUG=$(trueorfalse True MURANO_DEBUG)
MURANO_ENABLE_MODEL_POLICY_ENFORCEMENT=${MURANO_ENABLE_MODEL_POLICY_ENFORCEMENT:-False} MURANO_ENABLE_MODEL_POLICY_ENFORCEMENT=$(trueorfalse False MURANO_ENABLE_MODEL_POLICY_ENFORCEMENT)
# Since Murano support raw cloud images, we can allow download any image with cloud init
UBUNTU_CLOUD_IMAGE_URL=${UBUNTU_CLOUD_IMAGE_URL:-'http://storage.apps.openstack.org/images/ubuntu-14.04-m-agent.qcow2'}
IMAGE_URLS+=",${UBUNTU_CLOUD_IMAGE_URL}"
CLOUD_IMAGE_NAME=$(basename "$UBUNTU_CLOUD_IMAGE_URL" ".qcow2")
# Set up murano service endpoint # Set up murano service endpoint
MURANO_SERVICE_HOST=${MURANO_SERVICE_HOST:-$SERVICE_HOST} MURANO_SERVICE_HOST=${MURANO_SERVICE_HOST:-$SERVICE_HOST}
@ -37,7 +42,7 @@ MURANO_KEYSTONE_SIGNING_DIR=${MURANO_KEYSTONE_SIGNING_DIR:-/tmp/keystone-signing
# Set up murano networking settings # Set up murano networking settings
MURANO_DEFAULT_ROUTER=${MURANO_DEFAULT_ROUTER:-''} MURANO_DEFAULT_ROUTER=${MURANO_DEFAULT_ROUTER:-''}
MURANO_EXTERNAL_NETWORK=${MURANO_EXTERNAL_NETWORK:-''} MURANO_EXTERNAL_NETWORK=${MURANO_EXTERNAL_NETWORK:-''}
MURANO_DEFAULT_DNS=${MURANO_DEFAULT_DNS:-''} MURANO_DEFAULT_DNS=${MURANO_DEFAULT_DNS:-'8.8.8.8'}
# Choose applications for installation # Choose applications for installation
MURANO_APPS=${MURANO_APPS:-''} MURANO_APPS=${MURANO_APPS:-''}
@ -58,6 +63,8 @@ MURANO_RABBIT_VHOST=${MURANO_RABBIT_VHOST:-''}
TEMPEST_DIR=$DEST/tempest TEMPEST_DIR=$DEST/tempest
TEMPEST_CONFIG_DIR=${TEMPEST_CONFIG_DIR:-$TEMPEST_DIR/etc} TEMPEST_CONFIG_DIR=${TEMPEST_CONFIG_DIR:-$TEMPEST_DIR/etc}
TEMPEST_CONFIG=$TEMPEST_CONFIG_DIR/tempest.conf TEMPEST_CONFIG=$TEMPEST_CONFIG_DIR/tempest.conf
TEMPEST_MURANO_SCENARIO_TESTS_ENABLED=$(trueorfalse True TEMPEST_MURANO_SCENARIO_TESTS_ENABLED)
TEMPEST_MURANO_DEPLOYMENT_TESTS_ENABLED=$(trueorfalse False TEMPEST_MURANO_DEPLOYMENT_TESTS_ENABLED)
# GlARe variables # GlARe variables
# Glance Artifact Repository endpoint type for Murano communications. # Glance Artifact Repository endpoint type for Murano communications.

View File

@ -0,0 +1,66 @@
# 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.
Namespaces:
=: io.murano.apps.test
std: io.murano
res: io.murano.resources
sys: io.murano.system
conf: io.murano.configuration
Name: VM
Extends: std:Application
Properties:
name:
Contract: $.string().notNull()
instance:
Contract: $.class(res:Instance).notNull()
userName:
Contract: $.string()
Methods:
initialize:
Body:
- $._environment: $.find(std:Environment).require()
deploy:
Body:
- If: not $.getAttr(deployed, false)
Then:
- $._environment.reporter.report($this, 'Creating VM')
- $securityGroupIngress:
- ToPort: 80
FromPort: 80
IpProtocol: tcp
External: true
- ToPort: 443
FromPort: 443
IpProtocol: tcp
External: true
- $._environment.securityGroupManager.addGroupIngress($securityGroupIngress)
- $.instance.deploy()
- $._environment.reporter.report($this, 'Instance is created.')
- $resources: new(sys:Resources)
- $linux: new(conf:Linux)
- If: $.instance.assignFloatingIp
Then:
- $host: $.instance.floatingIpAddress
Else:
- $host: $.instance.ipAddresses[0]
- $.setAttr(deployed, true)

View File

@ -0,0 +1,8 @@
<!DOCTYPE html>
<html>
<head>
<title> Hello World</title>
</head>
<body>Hello world. This is my first web page. My name is %USER_NAME%.
</body>
</html>

View File

@ -0,0 +1,22 @@
# 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.
Format: 1.0
Type: Application
FullName: io.murano.test.VM.VM
Name: VM
Description: |
application which simply boot a virtual machine
Author: 'Mirantis, Inc'
Tags: [Server]
Classes:
io.murano.apps.test.VM: VM.yaml

View File

@ -94,6 +94,7 @@ class BaseApplicationCatalogScenarioTest(base.BaseTestCase):
creds = cls.get_configured_isolated_creds(type_of_creds='primary') creds = cls.get_configured_isolated_creds(type_of_creds='primary')
cls.os = clients.Manager(credentials=creds) cls.os = clients.Manager(credentials=creds)
cls.services_manager = services_manager(creds) cls.services_manager = services_manager(creds)
cls.linux_image = CONF.application_catalog.linux_image cls.linux_image = CONF.application_catalog.linux_image
cls.application_catalog_client = cls.os.application_catalog_client cls.application_catalog_client = cls.os.application_catalog_client
cls.artifacts_client = cls.os.artifacts_client cls.artifacts_client = cls.os.artifacts_client
@ -102,6 +103,13 @@ class BaseApplicationCatalogScenarioTest(base.BaseTestCase):
cls.snapshots_client = cls.services_manager.snapshots_client cls.snapshots_client = cls.services_manager.snapshots_client
cls.volumes_client = cls.services_manager.volumes_client cls.volumes_client = cls.services_manager.volumes_client
cls.backups_client = cls.services_manager.backups_client cls.backups_client = cls.services_manager.backups_client
cls.images_client = cls.services_manager.image_client_v2
cls.cirros_image = cls.get_required_image_name()
@classmethod
def get_required_image_name(cls):
image = cls.images_client.show_image(CONF.compute.image_ref)
return image['name']
@classmethod @classmethod
def resource_cleanup(cls): def resource_cleanup(cls):
@ -152,8 +160,8 @@ class BaseApplicationCatalogScenarioTest(base.BaseTestCase):
if name in instance['name']: if name in instance['name']:
return instance['id'] return instance['id']
def apache_cinder( def apache(
self, attributes=None, userName=None, flavor='m1.medium'): self, attributes=None, userName=None, flavor='m1.small'):
post_body = { post_body = {
"instance": { "instance": {
"flavor": flavor, "flavor": flavor,
@ -179,7 +187,34 @@ class BaseApplicationCatalogScenarioTest(base.BaseTestCase):
} }
return post_body return post_body
def update_executor(self, flavor='m1.medium'): def vm_cinder(
self, attributes=None, userName=None, flavor='m1.small'):
post_body = {
"instance": {
"flavor": flavor,
"image": self.cirros_image,
"assignFloatingIp": True,
"availabilityZone": "nova",
"volumes": attributes,
"?": {
"type": "io.murano.resources.LinuxMuranoInstance",
"id": utils.generate_uuid()
},
"name": utils.generate_name("testMurano")
},
"name": utils.generate_name("VM"),
"userName": userName,
"?": {
"_{id}".format(id=utils.generate_uuid()): {
"name": "VM"
},
"type": "io.murano.apps.test.VM",
"id": utils.generate_uuid()
}
}
return post_body
def update_executor(self, flavor='m1.small'):
post_body = { post_body = {
"instance": { "instance": {
"flavor": flavor, "flavor": flavor,
@ -203,7 +238,8 @@ class BaseApplicationCatalogScenarioTest(base.BaseTestCase):
self.application_catalog_client.deploy_session(environment['id'], self.application_catalog_client.deploy_session(environment['id'],
session['id']) session['id'])
timeout = 1800 timeout = 1800
deployed_env = utils.wait_for_environment_deploy(environment, deployed_env = utils.wait_for_environment_deploy(
self.application_catalog_client, environment['id'],
timeout=timeout) timeout=timeout)
if deployed_env['status'] == 'ready': if deployed_env['status'] == 'ready':
return deployed_env return deployed_env
@ -257,8 +293,8 @@ class BaseApplicationCatalogScenarioTest(base.BaseTestCase):
self.assertEqual(0, result, '%s port is closed on instance' % port) self.assertEqual(0, result, '%s port is closed on instance' % port)
@classmethod @classmethod
def create_volume(cls): def create_volume(cls, **kwargs):
volume = cls.volumes_client.create_volume()['volume'] volume = cls.volumes_client.create_volume(**kwargs)['volume']
waiters.wait_for_volume_status(cls.volumes_client, waiters.wait_for_volume_status(cls.volumes_client,
volume['id'], 'available') volume['id'], 'available')
return volume['id'] return volume['id']
@ -291,12 +327,13 @@ class BaseApplicationCatalogScenarioTest(base.BaseTestCase):
backup = self.backups_client.create_backup( backup = self.backups_client.create_backup(
volume_id=volume_id, volume_id=volume_id,
force=True)['backup'] force=True)['backup']
self.backups_client.wait_for_backup_status(backup['id'], 'available') waiters.wait_for_backup_status(self.backups_client,
backup['id'], 'available')
return backup['id'] return backup['id']
def delete_backup(self, backup_id): def delete_backup(self, backup_id):
self.backups_client.delete_backup(backup_id) self.backups_client.delete_backup(backup_id)
return self.backups_client.wait_for_backup_deletion(backup_id) return self.backups_client.wait_for_resource_deletion(backup_id)
def get_volume(self, environment_id): def get_volume(self, environment_id):
stack = self.get_stack_id(environment_id) stack = self.get_stack_id(environment_id)

View File

@ -32,11 +32,11 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
raise cls.skipException(msg) raise cls.skipException(msg)
super(TestCinderVolumes, cls).resource_setup() super(TestCinderVolumes, cls).resource_setup()
cls.linux = CONF.application_catalog.linux_image cls.linux = CONF.application_catalog.linux_image
application_name = utils.generate_name('Apache_custom') application_name = utils.generate_name('VM')
cls.abs_archive_path, dir_with_archive, archive_name = \ cls.abs_archive_path, dir_with_archive, archive_name = \
utils.prepare_package( utils.prepare_package(
application_name, application_name,
app='io.murano.apps.test.ApacheHttpServerCustom', app='io.murano.apps.test.VM',
manifest_required=False) manifest_required=False)
if CONF.application_catalog.glare_backend: if CONF.application_catalog.glare_backend:
cls.client = cls.artifacts_client cls.client = cls.artifacts_client
@ -45,7 +45,7 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
cls.package = cls.client.upload_package( cls.package = cls.client.upload_package(
application_name, archive_name, dir_with_archive, application_name, archive_name, dir_with_archive,
{"categories": ["Web"], "tags": ["test"]}) {"categories": ["Web"], "tags": ["test"]})
cls.volume = cls.create_volume() cls.volume = cls.create_volume(size='1')
@classmethod @classmethod
def resource_cleanup(cls): def resource_cleanup(cls):
@ -62,7 +62,7 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
Scenario: Scenario:
1. Create environment 1. Create environment
2. Add ApacheHTTPServer application with ability to boot instance 2. Add VM application with ability to boot instance
from Cinder volume from Cinder volume
3. Deploy environment 3. Deploy environment
4. Make sure that deployment finished successfully 4. Make sure that deployment finished successfully
@ -79,14 +79,14 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
create_session(environment['id']) create_session(environment['id'])
post_body = { post_body = {
"instance": { "instance": {
"flavor": "m1.medium", "flavor": "m1.small",
"blockDevices": { "blockDevices": {
"volume": { "volume": {
"?": { "?": {
"type": "io.murano.resources.CinderVolume" "type": "io.murano.resources.CinderVolume"
}, },
"size": 4, "size": 4,
"sourceImage": self.linux "sourceImage": self.cirros_image
}, },
"bootIndex": 0, "bootIndex": 0,
"deviceName": "vda", "deviceName": "vda",
@ -100,12 +100,12 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
}, },
"name": utils.generate_name("testMurano") "name": utils.generate_name("testMurano")
}, },
"name": utils.generate_name("ApacheHTTPServer"), "name": utils.generate_name("VM"),
"?": { "?": {
"_{id}".format(id=utils.generate_uuid()): { "_{id}".format(id=utils.generate_uuid()): {
"name": "ApacheHTTPServer" "name": "VM"
}, },
"type": "io.murano.apps.test.ApacheHttpServerCustom", "type": "io.murano.apps.test.VM",
"id": utils.generate_uuid() "id": utils.generate_uuid()
} }
} }
@ -114,12 +114,11 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
post_body) post_body)
self.deploy_environment(environment, session) self.deploy_environment(environment, session)
self.status_check(environment['id'], [['testMurano', 22, 80]])
volume_data = self.get_volume(environment['id']) volume_data = self.get_volume(environment['id'])
self.check_volume_attached('testMurano', volume_data['id']) self.check_volume_attached('testMurano', volume_data['id'])
self.assertEqual(volume_data['size'], 4) self.assertEqual(volume_data['size'], 4)
self.assertEqual(volume_data['volume_image_metadata']['image_name'], self.assertEqual(volume_data['volume_image_metadata']['image_name'],
self.linux) self.cirros_image)
server = self.get_instance_id('testMurano') server = self.get_instance_id('testMurano')
self.assertFalse( self.assertFalse(
self.servers_client.show_server(server)['server']['image']) self.servers_client.show_server(server)['server']['image'])
@ -131,7 +130,7 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
Scenario: Scenario:
1. Create environment 1. Create environment
2. Add ApacheHTTPServer application with ability to attach existing 2. Add VM application with ability to attach existing
Cinder volume to the instance Cinder volume to the instance
3. Deploy environment 3. Deploy environment
4. Make sure that deployment finished successfully 4. Make sure that deployment finished successfully
@ -153,13 +152,12 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
"openstackId": self.volume "openstackId": self.volume
} }
} }
post_body = self.apache_cinder(attributes=volume_attributes) post_body = self.vm_cinder(attributes=volume_attributes)
self.application_catalog_client.\ self.application_catalog_client.\
create_service(environment['id'], session['id'], create_service(environment['id'], session['id'],
post_body) post_body)
self.deploy_environment(environment, session) self.deploy_environment(environment, session)
self.status_check(environment['id'], [['testMurano', 22, 80]])
self.check_volume_attached('testMurano', self.volume) self.check_volume_attached('testMurano', self.volume)
@testtools.testcase.attr('smoke') @testtools.testcase.attr('smoke')
@ -169,7 +167,7 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
Scenario: Scenario:
1. Create environment 1. Create environment
2. Add ApacheHTTPServer application with ability to create and 2. Add VM application with ability to create and
attach Cinder volume with size 1 GiB to the instance attach Cinder volume with size 1 GiB to the instance
3. Deploy environment 3. Deploy environment
4. Make sure that deployment finished successfully 4. Make sure that deployment finished successfully
@ -191,13 +189,12 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
"size": 1 "size": 1
} }
} }
post_body = self.apache_cinder(attributes=volume_attributes) post_body = self.vm_cinder(attributes=volume_attributes)
self.application_catalog_client.\ self.application_catalog_client.\
create_service(environment['id'], session['id'], create_service(environment['id'], session['id'],
post_body) post_body)
self.deploy_environment(environment, session) self.deploy_environment(environment, session)
self.status_check(environment['id'], [['testMurano', 22, 80]])
volume_data = self.get_volume(environment['id']) volume_data = self.get_volume(environment['id'])
self.check_volume_attached('testMurano', volume_data['id']) self.check_volume_attached('testMurano', volume_data['id'])
self.assertEqual(volume_data['size'], 1) self.assertEqual(volume_data['size'], 1)
@ -209,7 +206,7 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
Scenario: Scenario:
1. Create environment 1. Create environment
2. Add ApacheHTTPServer application with ability to create Cinder 2. Add VM application with ability to create Cinder
volume with size 2 GiB from image and attach it to the instance volume with size 2 GiB from image and attach it to the instance
3. Deploy environment 3. Deploy environment
4. Make sure that deployment finished successfully 4. Make sure that deployment finished successfully
@ -230,21 +227,20 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
"type": "io.murano.resources.CinderVolume" "type": "io.murano.resources.CinderVolume"
}, },
"size": 4, "size": 4,
"sourceImage": self.linux "sourceImage": self.cirros_image
} }
} }
post_body = self.apache_cinder(volume_attributes) post_body = self.vm_cinder(volume_attributes)
self.application_catalog_client.\ self.application_catalog_client.\
create_service(environment['id'], session['id'], create_service(environment['id'], session['id'],
post_body) post_body)
self.deploy_environment(environment, session) self.deploy_environment(environment, session)
self.status_check(environment['id'], [['testMurano', 22, 80]])
volume_data = self.get_volume(environment['id']) volume_data = self.get_volume(environment['id'])
self.check_volume_attached('testMurano', volume_data['id']) self.check_volume_attached('testMurano', volume_data['id'])
self.assertEqual(volume_data['size'], 4) self.assertEqual(volume_data['size'], 4)
self.assertEqual(volume_data['volume_image_metadata']['image_name'], self.assertEqual(volume_data['volume_image_metadata']['image_name'],
self.linux) self.cirros_image)
@testtools.testcase.attr('smoke') @testtools.testcase.attr('smoke')
@testtools.testcase.attr('scenario') @testtools.testcase.attr('scenario')
@ -253,7 +249,7 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
Scenario: Scenario:
1. Create environment 1. Create environment
2. Add ApacheHTTPServer application with ability to create Cinder 2. Add VM application with ability to create Cinder
volume with size 1 GiB from existing volume and attach it to the volume with size 1 GiB from existing volume and attach it to the
instance instance
3. Deploy environment 3. Deploy environment
@ -283,13 +279,12 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
} }
} }
} }
post_body = self.apache_cinder(volume_attributes) post_body = self.vm_cinder(volume_attributes)
self.application_catalog_client.\ self.application_catalog_client.\
create_service(environment['id'], session['id'], create_service(environment['id'], session['id'],
post_body) post_body)
self.deploy_environment(environment, session) self.deploy_environment(environment, session)
self.status_check(environment['id'], [['testMurano', 22, 80]])
volume_data = self.get_volume(environment['id']) volume_data = self.get_volume(environment['id'])
self.check_volume_attached('testMurano', volume_data['id']) self.check_volume_attached('testMurano', volume_data['id'])
self.assertEqual(volume_data['size'], 1) self.assertEqual(volume_data['size'], 1)
@ -303,7 +298,7 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
Scenario: Scenario:
1. Make snapshot from volume 1. Make snapshot from volume
2. Create environment 2. Create environment
3. Add ApacheHTTPServer application with ability to create 3. Add VM application with ability to create
Cinder volume with size 1 GiB from existing volume snapshot and Cinder volume with size 1 GiB from existing volume snapshot and
attach it to the instance attach it to the instance
4. Deploy environment 4. Deploy environment
@ -335,13 +330,12 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
} }
} }
} }
post_body = self.apache_cinder(volume_attributes) post_body = self.vm_cinder(volume_attributes)
self.application_catalog_client.\ self.application_catalog_client.\
create_service(environment['id'], session['id'], create_service(environment['id'], session['id'],
post_body) post_body)
self.deploy_environment(environment, session) self.deploy_environment(environment, session)
self.status_check(environment['id'], [['testMurano', 22, 80]])
volume_data = self.get_volume(environment['id']) volume_data = self.get_volume(environment['id'])
self.check_volume_attached('testMurano', volume_data['id']) self.check_volume_attached('testMurano', volume_data['id'])
self.assertEqual(volume_data['size'], 1) self.assertEqual(volume_data['size'], 1)
@ -355,7 +349,7 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
Scenario: Scenario:
1. Make backup from volume 1. Make backup from volume
2. Create environment 2. Create environment
3. Add ApacheHTTPServer application with ability to create Cinder 3. Add VM application with ability to create Cinder
volume with size 1 GiB from existing volume backup and attach it to volume with size 1 GiB from existing volume backup and attach it to
the instance the instance
4. Deploy environment 4. Deploy environment
@ -395,13 +389,12 @@ class TestCinderVolumes(base.BaseApplicationCatalogScenarioTest):
} }
} }
} }
post_body = self.apache_cinder(volume_attributes) post_body = self.vm_cinder(volume_attributes)
self.application_catalog_client.\ self.application_catalog_client.\
create_service(environment['id'], session['id'], create_service(environment['id'], session['id'],
post_body) post_body)
self.deploy_environment(environment, session) self.deploy_environment(environment, session)
self.status_check(environment['id'], [['testMurano', 22, 80]])
volume_data = self.get_volume(environment['id']) volume_data = self.get_volume(environment['id'])
self.check_volume_attached('testMurano', volume_data['id']) self.check_volume_attached('testMurano', volume_data['id'])
self.assertEqual(volume_data['size'], 1) self.assertEqual(volume_data['size'], 1)
@ -417,11 +410,11 @@ class TestCinderVolumeIsolatedAdmin(
msg = "Cinder volumes attachment tests will be skipped." msg = "Cinder volumes attachment tests will be skipped."
raise cls.skipException(msg) raise cls.skipException(msg)
super(TestCinderVolumeIsolatedAdmin, cls).resource_setup() super(TestCinderVolumeIsolatedAdmin, cls).resource_setup()
application_name = utils.generate_name('Apache_custom') application_name = utils.generate_name('VM')
cls.abs_archive_path, dir_with_archive, archive_name = \ cls.abs_archive_path, dir_with_archive, archive_name = \
utils.prepare_package( utils.prepare_package(
application_name, application_name,
app='io.murano.apps.test.ApacheHttpServerCustom', app='io.murano.apps.test.VM',
manifest_required=False) manifest_required=False)
if CONF.application_catalog.glare_backend: if CONF.application_catalog.glare_backend:
cls.client = cls.artifacts_client cls.client = cls.artifacts_client
@ -445,7 +438,7 @@ class TestCinderVolumeIsolatedAdmin(
Scenario: Scenario:
1. Create environment 1. Create environment
2. Add ApacheHTTPServer application with ability to create and 2. Add VM application with ability to create and
attach Cinder volume with size 1 GiB, multiattach and readonly attach Cinder volume with size 1 GiB, multiattach and readonly
properties to the instance properties to the instance
3. Deploy environment 3. Deploy environment
@ -471,13 +464,12 @@ class TestCinderVolumeIsolatedAdmin(
"multiattach": True "multiattach": True
} }
} }
post_body = self.apache_cinder(attributes=volume_attributes) post_body = self.vm_cinder(attributes=volume_attributes)
self.application_catalog_client.\ self.application_catalog_client.\
create_service(environment['id'], session['id'], create_service(environment['id'], session['id'],
post_body) post_body)
self.deploy_environment(environment, session) self.deploy_environment(environment, session)
self.status_check(environment['id'], [['testMurano', 22, 80]])
volume_data = self.get_volume(environment['id']) volume_data = self.get_volume(environment['id'])
self.check_volume_attached('testMurano', volume_data['id']) self.check_volume_attached('testMurano', volume_data['id'])
self.assertEqual(volume_data['size'], 1) self.assertEqual(volume_data['size'], 1)

View File

@ -27,7 +27,8 @@ class TestMuranoDeployment(base.BaseApplicationCatalogScenarioTest):
@classmethod @classmethod
def resource_setup(cls): def resource_setup(cls):
if not CONF.application_catalog.deployment_tests: if not CONF.application_catalog.deployment_tests or \
not CONF.application_catalog.linux_image:
msg = "Application Catalog Scenario Deployment Tests will be " \ msg = "Application Catalog Scenario Deployment Tests will be " \
"skipped." "skipped."
raise cls.skipException(msg) raise cls.skipException(msg)
@ -97,7 +98,7 @@ class TestMuranoDeployment(base.BaseApplicationCatalogScenarioTest):
6. Delete environment 6. Delete environment
""" """
post_body = self.apache_cinder() post_body = self.apache()
environment_name = utils.generate_name('Test_Murano') environment_name = utils.generate_name('Test_Murano')
environment = self.application_catalog_client.create_environment( environment = self.application_catalog_client.create_environment(
name=environment_name) name=environment_name)
@ -130,8 +131,8 @@ class TestMuranoDeployment(base.BaseApplicationCatalogScenarioTest):
10. Delete environment 10. Delete environment
""" """
app_1_post_body = self.apache_cinder() app_1_post_body = self.apache()
app_2_post_body = self.apache_cinder() app_2_post_body = self.apache()
environment_name = utils.generate_name('Test_Murano') environment_name = utils.generate_name('Test_Murano')
environment = self.application_catalog_client.create_environment( environment = self.application_catalog_client.create_environment(
@ -231,7 +232,7 @@ class TestMuranoDeployment(base.BaseApplicationCatalogScenarioTest):
7. Delete environment 7. Delete environment
""" """
post_body = self.apache_cinder(userName=utils.generate_name('user')) post_body = self.apache(userName=utils.generate_name('user'))
username = post_body["userName"] username = post_body["userName"]
environment_name = utils.generate_name('SSC-murano') environment_name = utils.generate_name('SSC-murano')
environment = self.application_catalog_client.create_environment( environment = self.application_catalog_client.create_environment(