diff options
Diffstat (limited to 'tosca2heat/heat-translator-0.3.0/translator/tests/test_tosca_hot_translation.py')
-rw-r--r-- | tosca2heat/heat-translator-0.3.0/translator/tests/test_tosca_hot_translation.py | 503 |
1 files changed, 0 insertions, 503 deletions
diff --git a/tosca2heat/heat-translator-0.3.0/translator/tests/test_tosca_hot_translation.py b/tosca2heat/heat-translator-0.3.0/translator/tests/test_tosca_hot_translation.py deleted file mode 100644 index 534f8ed..0000000 --- a/tosca2heat/heat-translator-0.3.0/translator/tests/test_tosca_hot_translation.py +++ /dev/null @@ -1,503 +0,0 @@ -# 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 json -import os - -from toscaparser.common.exception import ExceptionCollector -from toscaparser.common.exception import URLException -from toscaparser.common.exception import ValidationError -from toscaparser.utils.gettextutils import _ -from translator.common.utils import TranslationUtils -from translator.tests.base import TestCase - - -class ToscaHotTranslationTest(TestCase): - - def test_hot_translate_single_server(self): - tosca_file = '../tests/data/tosca_single_server.yaml' - hot_file = '../tests/data/hot_output/hot_single_server.yaml' - params = {'cpus': 1} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_single_server_with_defaults(self): - tosca_file = \ - '../tests/data/tosca_single_server_with_defaults.yaml' - hot_file_with_input = '../tests/data/hot_output/' \ - 'hot_single_server_with_defaults_with_input.yaml' - hot_file_without_input = '../tests/data/hot_output/' \ - 'hot_single_server_with_defaults_without_input.yaml' - - params1 = {'cpus': '1'} - diff1 = TranslationUtils.compare_tosca_translation_with_hot( - tosca_file, hot_file_with_input, params1) - self.assertEqual({}, diff1, '<difference> : ' + - json.dumps(diff1, indent=4, separators=(', ', ': '))) - - params2 = {} - diff2 = TranslationUtils.compare_tosca_translation_with_hot( - tosca_file, hot_file_without_input, params2) - self.assertEqual({}, diff2, '<difference> : ' + - json.dumps(diff2, indent=4, separators=(', ', ': '))) - - def test_hot_translate_wordpress_single_instance(self): - tosca_file = '../tests/data/tosca_single_instance_wordpress.yaml' - hot_file = '../tests/data/hot_output/' \ - 'hot_single_instance_wordpress.yaml' - params = {'db_name': 'wordpress', - 'db_user': 'wp_user', - 'db_pwd': 'wp_pass', - 'db_root_pwd': 'passw0rd', - 'db_port': 3366, - 'cpus': 8} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_helloworld(self): - tosca_file = '../tests/data/tosca_helloworld.yaml' - hot_file = '../tests/data/hot_output/hot_hello_world.yaml' - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - {}) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_host_assignment(self): - tosca_file = '../tests/data/test_host_assignment.yaml' - hot_file = '../tests/data/hot_output/hot_host_assignment.yaml' - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - {}) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_elk(self): - tosca_file = '../tests/data/tosca_elk.yaml' - hot_file = '../tests/data/hot_output/hot_elk.yaml' - params = {'github_url': - 'http://github.com/paypal/rest-api-sample-app-nodejs.git', - 'my_cpus': 4} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_nodejs_mongodb_two_instances(self): - tosca_file = '../tests/data/tosca_nodejs_mongodb_two_instances.yaml' - hot_file = '../tests/data/hot_output/' \ - 'hot_nodejs_mongodb_two_instances.yaml' - params = {'github_url': - 'http://github.com/paypal/rest-api-sample-app-nodejs.git', - 'my_cpus': 4} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_blockstorage_with_attachment(self): - tosca_file = '../tests/data/storage/' \ - 'tosca_blockstorage_with_attachment.yaml' - hot_file = '../tests/data/hot_output/storage/' \ - 'hot_blockstorage_with_attachment.yaml' - params = {'cpus': 1, - 'storage_location': '/dev/vdc', - 'storage_size': '2000 MB', - 'storage_snapshot_id': 'ssid'} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_blockstorage_with_custom_relationship_type(self): - tosca_file = '../tests/data/storage/' \ - 'tosca_blockstorage_with_custom_relationship_type.yaml' - hot_file = '../tests/data/hot_output/storage/' \ - 'hot_blockstorage_with_custom_relationship_type.yaml' - params = {'cpus': 1, - 'storage_location': '/dev/vdc', - 'storage_size': '1 GB', - 'storage_snapshot_id': 'ssid'} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_blockstorage_with_relationship_template(self): - tosca_file = '../tests/data/storage/' \ - 'tosca_blockstorage_with_relationship_template.yaml' - hot_file = '../tests/data/hot_output/storage/' \ - 'hot_blockstorage_with_relationship_template.yaml' - params = {'cpus': 1, - 'storage_location': '/dev/vdc', - 'storage_size': '1 GB'} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_blockstorage_with_attachment_notation1(self): - tosca_file = '../tests/data/storage/' \ - 'tosca_blockstorage_with_attachment_notation1.yaml' - hot_file1 = '../tests/data/hot_output/storage/' \ - 'hot_blockstorage_with_attachment_notation1_alt1.yaml' - hot_file2 = '../tests/data/hot_output/storage/' \ - 'hot_blockstorage_with_attachment_notation1_alt2.yaml' - params = {'cpus': 1, - 'storage_location': 'some_folder', - 'storage_size': '1 GB', - 'storage_snapshot_id': 'ssid'} - diff1 = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file1, - params) - try: - self.assertEqual({}, diff1, '<difference> : ' + - json.dumps(diff1, indent=4, - separators=(', ', ': '))) - except Exception: - diff2 = TranslationUtils.compare_tosca_translation_with_hot( - tosca_file, hot_file2, params) - self.assertEqual({}, diff2, '<difference> : ' + - json.dumps(diff2, indent=4, - separators=(', ', ': '))) - - def test_hot_translate_blockstorage_with_attachment_notation2(self): - tosca_file = '../tests/data/storage/' \ - 'tosca_blockstorage_with_attachment_notation2.yaml' - hot_file1 = '../tests/data/hot_output/storage/' \ - 'hot_blockstorage_with_attachment_notation2_alt1.yaml' - hot_file2 = '../tests/data/hot_output/storage/' \ - 'hot_blockstorage_with_attachment_notation2_alt2.yaml' - params = {'cpus': 1, - 'storage_location': '/dev/vdc', - 'storage_size': '1 GB', - 'storage_snapshot_id': 'ssid'} - diff1 = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file1, - params) - try: - self.assertEqual({}, diff1, '<difference> : ' + - json.dumps(diff1, indent=4, - separators=(', ', ': '))) - except Exception: - diff2 = TranslationUtils.compare_tosca_translation_with_hot( - tosca_file, hot_file2, params) - self.assertEqual({}, diff2, '<difference> : ' + - json.dumps(diff2, indent=4, - separators=(', ', ': '))) - - def test_hot_translate_multiple_blockstorage_with_attachment(self): - tosca_file = '../tests/data/storage/' \ - 'tosca_multiple_blockstorage_with_attachment.yaml' - hot_file1 = '../tests/data/hot_output/storage/' \ - 'hot_multiple_blockstorage_with_attachment_alt1.yaml' - hot_file2 = '../tests/data/hot_output/storage/' \ - 'hot_multiple_blockstorage_with_attachment_alt2.yaml' - params = {'cpus': 1, - 'storage_location': '/dev/vdc', - 'storage_size': '1 GB', - 'storage_snapshot_id': 'ssid'} - diff1 = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file1, - params) - try: - self.assertEqual({}, diff1, '<difference> : ' + - json.dumps(diff1, indent=4, - separators=(', ', ': '))) - except Exception: - diff2 = TranslationUtils.compare_tosca_translation_with_hot( - tosca_file, hot_file2, params) - self.assertEqual({}, diff2, '<difference> : ' + - json.dumps(diff2, indent=4, - separators=(', ', ': '))) - - def test_hot_translate_single_object_store(self): - tosca_file = '../tests/data/storage/tosca_single_object_store.yaml' - hot_file = '../tests/data/hot_output/hot_single_object_store.yaml' - params = {'objectstore_name': 'myobjstore'} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_one_server_one_network(self): - tosca_file = '../tests/data/network/tosca_one_server_one_network.yaml' - hot_file = '../tests/data/hot_output/network/' \ - 'hot_one_server_one_network.yaml' - params = {'network_name': 'private_net'} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_server_on_existing_network(self): - tosca_file = '../tests/data/network/' \ - 'tosca_server_on_existing_network.yaml' - hot_file = '../tests/data/hot_output/network/' \ - 'hot_server_on_existing_network.yaml' - params = {'network_name': 'private_net'} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_two_servers_one_network(self): - tosca_file = '../tests/data/network/tosca_two_servers_one_network.yaml' - hot_file = '../tests/data/hot_output/network/' \ - 'hot_two_servers_one_network.yaml' - params = {'network_name': 'my_private_net', - 'network_cidr': '10.0.0.0/24', - 'network_start_ip': '10.0.0.100', - 'network_end_ip': '10.0.0.150'} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_one_server_three_networks(self): - tosca_file = '../tests/data/network/' \ - 'tosca_one_server_three_networks.yaml' - hot_file = '../tests/data/hot_output/network/' \ - 'hot_one_server_three_networks.yaml' - params = {} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_software_component(self): - tosca_file = '../tests/data/tosca_software_component.yaml' - hot_file = '../tests/data/hot_output/hot_software_component.yaml' - params = {'cpus': '1', - 'download_url': 'http://www.software.com/download'} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_web_application(self): - tosca_file = '../tests/data/tosca_web_application.yaml' - hot_file = '../tests/data/hot_output/hot_web_application.yaml' - params = {'cpus': '2', 'context_root': 'my_web_app'} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_template_with_url_import(self): - tosca_file = '../tests/data/' \ - 'tosca_single_instance_wordpress_with_url_import.yaml' - hot_file = '../tests/data/hot_output/' \ - 'hot_single_instance_wordpress.yaml' - params = {'db_name': 'wordpress', - 'db_user': 'wp_user', - 'db_pwd': 'wp_pass', - 'db_root_pwd': 'passw0rd', - 'db_port': 3366, - 'cpus': 8} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_template_by_url_with_local_import(self): - tosca_file = 'https://raw.githubusercontent.com/openstack/' \ - 'heat-translator/master/translator/tests/data/' \ - 'tosca_single_instance_wordpress.yaml' - hot_file = '../tests/data/hot_output/' \ - 'hot_single_instance_wordpress.yaml' - params = {'db_name': 'wordpress', - 'db_user': 'wp_user', - 'db_pwd': 'wp_pass', - 'db_root_pwd': 'passw0rd', - 'db_port': 3366, - 'cpus': 8} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_hot_translate_template_by_url_with_local_abspath_import(self): - tosca_file = 'https://raw.githubusercontent.com/openstack/' \ - 'heat-translator/master/translator/tests/data/' \ - 'tosca_single_instance_wordpress_with_local_abspath' \ - '_import.yaml' - hot_file = '../tests/data/hot_output/' \ - 'hot_single_instance_wordpress.yaml' - params = {'db_name': 'wordpress', - 'db_user': 'wp_user', - 'db_pwd': 'wp_pass', - 'db_root_pwd': 'passw0rd', - 'db_port': 3366, - 'cpus': 8} - - self.assertRaises( - ValidationError, - TranslationUtils.compare_tosca_translation_with_hot, - tosca_file, hot_file, params) - expected_msg = _('Absolute file name "/tmp/wordpress.yaml" cannot be ' - 'used in a URL-based input template "https://raw.' - 'githubusercontent.com/openstack/heat-translator/' - 'master/translator/tests/data/tosca_single_instance_' - 'wordpress_with_local_abspath_import.yaml".') - ExceptionCollector.assertExceptionMessage(ImportError, expected_msg) - - def test_hot_translate_template_by_url_with_url_import(self): - tosca_url = 'https://raw.githubusercontent.com/openstack/' \ - 'heat-translator/master/translator/tests/data/' \ - 'tosca_single_instance_wordpress_with_url_import.yaml' - hot_file = '../tests/data/hot_output/' \ - 'hot_single_instance_wordpress.yaml' - params = {'db_name': 'wordpress', - 'db_user': 'wp_user', - 'db_pwd': 'wp_pass', - 'db_root_pwd': 'passw0rd', - 'db_port': 3366, - 'cpus': 8} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_url, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_translate_hello_world_csar(self): - tosca_file = '../tests/data/csar_hello_world.zip' - hot_file = '../tests/data/hot_output/hot_hello_world.yaml' - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - {}) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_translate_single_instance_wordpress_csar(self): - tosca_file = '../tests/data/csar_single_instance_wordpress.zip' - hot_file = '../tests/data/hot_output/' \ - 'hot_single_instance_wordpress_from_csar.yaml' - params = {'db_name': 'wordpress', - 'db_user': 'wp_user', - 'db_pwd': 'wp_pass', - 'db_root_pwd': 'passw0rd', - 'db_port': 3366, - 'cpus': 8} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_translate_elk_csar_from_url(self): - tosca_file = 'https://github.com/openstack/heat-translator/raw/' \ - 'master/translator/tests/data/csar_elk.zip' - hot_file = '../tests/data/hot_output/hot_elk_from_csar.yaml' - params = {'github_url': - 'http://github.com/paypal/rest-api-sample-app-nodejs.git', - 'my_cpus': 4} - diff = TranslationUtils.compare_tosca_translation_with_hot(tosca_file, - hot_file, - params) - self.assertEqual({}, diff, '<difference> : ' + - json.dumps(diff, indent=4, separators=(', ', ': '))) - - def test_translate_csar_not_zip(self): - tosca_file = '../tests/data/csar_not_zip.zip' - hot_file = '' - params = {} - - self.assertRaises( - ValidationError, - TranslationUtils.compare_tosca_translation_with_hot, - tosca_file, hot_file, params) - path = os.path.normpath(os.path.join( - os.path.dirname(os.path.realpath(__file__)), tosca_file)) - expected_msg = _('"%s" is not a valid zip file.') % path - ExceptionCollector.assertExceptionMessage(ValidationError, - expected_msg) - - def test_translate_csar_metadata_not_yaml(self): - tosca_file = '../tests/data/csar_metadata_not_yaml.zip' - hot_file = '' - params = {} - - self.assertRaises( - ValidationError, - TranslationUtils.compare_tosca_translation_with_hot, - tosca_file, hot_file, params) - path = os.path.normpath(os.path.join( - os.path.dirname(os.path.realpath(__file__)), tosca_file)) - expected_msg = _('The file "TOSCA-Metadata/TOSCA.meta" in the CSAR ' - '"%s" does not contain valid YAML content.') % path - ExceptionCollector.assertExceptionMessage(ValidationError, - expected_msg) - - def test_translate_csar_wrong_metadata_file(self): - tosca_file = '../tests/data/csar_wrong_metadata_file.zip' - hot_file = '' - params = {} - - self.assertRaises( - ValidationError, - TranslationUtils.compare_tosca_translation_with_hot, - tosca_file, hot_file, params) - path = os.path.normpath(os.path.join( - os.path.dirname(os.path.realpath(__file__)), tosca_file)) - expected_msg = _('"%s" is not a valid CSAR as it does not contain the ' - 'required file "TOSCA.meta" in the folder ' - '"TOSCA-Metadata".') % path - ExceptionCollector.assertExceptionMessage(ValidationError, - expected_msg) - - def test_translate_csar_wordpress_invalid_import_path(self): - tosca_file = '../tests/data/csar_wordpress_invalid_import_path.zip' - hot_file = '' - params = {} - - self.assertRaises( - ValidationError, - TranslationUtils.compare_tosca_translation_with_hot, - tosca_file, hot_file, params) - expected_msg = _('Import "Definitions/wordpress.yaml" is not valid.') - ExceptionCollector.assertExceptionMessage(ImportError, expected_msg) - - def test_translate_csar_wordpress_invalid_script_url(self): - tosca_file = '../tests/data/csar_wordpress_invalid_script_url.zip' - hot_file = '' - params = {} - - self.assertRaises( - ValidationError, - TranslationUtils.compare_tosca_translation_with_hot, - tosca_file, hot_file, params) - expected_msg = _('The resource at ' - '"https://raw.githubusercontent.com/openstack/' - 'heat-translator/master/translator/tests/data/' - 'custom_types/wordpress1.yaml" cannot be accessed.') - ExceptionCollector.assertExceptionMessage(URLException, expected_msg) |