fog-vcloud-director 0.1.0
Sign up to get free protection for your applications and to get access to all the features.
- checksums.yaml +7 -0
- data/.editorconfig +11 -0
- data/.gitignore +17 -0
- data/.hound.yml +2 -0
- data/.rubocop.yml +240 -0
- data/.ruby-gemset +1 -0
- data/.travis.yml +15 -0
- data/Gemfile +4 -0
- data/LICENSE.md +20 -0
- data/README.md +962 -0
- data/Rakefile +19 -0
- data/fog-vcloud-director.gemspec +31 -0
- data/lib/fog/vcloud_director.rb +1 -0
- data/lib/fog/vcloud_director/compute.rb +916 -0
- data/lib/fog/vcloud_director/core.rb +69 -0
- data/lib/fog/vcloud_director/generators/compute/compose_common.rb +122 -0
- data/lib/fog/vcloud_director/generators/compute/compose_vapp.rb +25 -0
- data/lib/fog/vcloud_director/generators/compute/create_snapshot.rb +25 -0
- data/lib/fog/vcloud_director/generators/compute/customization.rb +105 -0
- data/lib/fog/vcloud_director/generators/compute/disks.rb +186 -0
- data/lib/fog/vcloud_director/generators/compute/edge_gateway_service_configuration.rb +243 -0
- data/lib/fog/vcloud_director/generators/compute/instantiate_vapp_template_params.rb +30 -0
- data/lib/fog/vcloud_director/generators/compute/metadata.rb +104 -0
- data/lib/fog/vcloud_director/generators/compute/org_vdc_network.rb +88 -0
- data/lib/fog/vcloud_director/generators/compute/recompose_vapp.rb +34 -0
- data/lib/fog/vcloud_director/generators/compute/vapp.rb +28 -0
- data/lib/fog/vcloud_director/generators/compute/vm.rb +32 -0
- data/lib/fog/vcloud_director/generators/compute/vm_network.rb +119 -0
- data/lib/fog/vcloud_director/models/compute/catalog.rb +22 -0
- data/lib/fog/vcloud_director/models/compute/catalog_item.rb +30 -0
- data/lib/fog/vcloud_director/models/compute/catalog_items.rb +33 -0
- data/lib/fog/vcloud_director/models/compute/catalogs.rb +30 -0
- data/lib/fog/vcloud_director/models/compute/custom_field.rb +18 -0
- data/lib/fog/vcloud_director/models/compute/custom_fields.rb +67 -0
- data/lib/fog/vcloud_director/models/compute/disk.rb +53 -0
- data/lib/fog/vcloud_director/models/compute/disks.rb +44 -0
- data/lib/fog/vcloud_director/models/compute/media.rb +26 -0
- data/lib/fog/vcloud_director/models/compute/medias.rb +75 -0
- data/lib/fog/vcloud_director/models/compute/network.rb +25 -0
- data/lib/fog/vcloud_director/models/compute/networks.rb +62 -0
- data/lib/fog/vcloud_director/models/compute/organization.rb +37 -0
- data/lib/fog/vcloud_director/models/compute/organizations.rb +28 -0
- data/lib/fog/vcloud_director/models/compute/tag.rb +31 -0
- data/lib/fog/vcloud_director/models/compute/tags.rb +41 -0
- data/lib/fog/vcloud_director/models/compute/task.rb +55 -0
- data/lib/fog/vcloud_director/models/compute/tasks.rb +36 -0
- data/lib/fog/vcloud_director/models/compute/template_vm.rb +52 -0
- data/lib/fog/vcloud_director/models/compute/template_vms.rb +41 -0
- data/lib/fog/vcloud_director/models/compute/vapp.rb +144 -0
- data/lib/fog/vcloud_director/models/compute/vapp_template.rb +26 -0
- data/lib/fog/vcloud_director/models/compute/vapp_templates.rb +40 -0
- data/lib/fog/vcloud_director/models/compute/vapps.rb +40 -0
- data/lib/fog/vcloud_director/models/compute/vdc.rb +45 -0
- data/lib/fog/vcloud_director/models/compute/vdcs.rb +37 -0
- data/lib/fog/vcloud_director/models/compute/vm.rb +197 -0
- data/lib/fog/vcloud_director/models/compute/vm_customization.rb +40 -0
- data/lib/fog/vcloud_director/models/compute/vm_customizations.rb +29 -0
- data/lib/fog/vcloud_director/models/compute/vm_network.rb +27 -0
- data/lib/fog/vcloud_director/models/compute/vm_networks.rb +19 -0
- data/lib/fog/vcloud_director/models/compute/vms.rb +46 -0
- data/lib/fog/vcloud_director/parsers/compute/disks.rb +53 -0
- data/lib/fog/vcloud_director/parsers/compute/metadata.rb +61 -0
- data/lib/fog/vcloud_director/parsers/compute/network.rb +104 -0
- data/lib/fog/vcloud_director/parsers/compute/vm.rb +86 -0
- data/lib/fog/vcloud_director/parsers/compute/vm_customization.rb +55 -0
- data/lib/fog/vcloud_director/parsers/compute/vm_network.rb +107 -0
- data/lib/fog/vcloud_director/parsers/compute/vm_parser_helper.rb +62 -0
- data/lib/fog/vcloud_director/parsers/compute/vms.rb +68 -0
- data/lib/fog/vcloud_director/parsers/compute/vms_by_metadata.rb +37 -0
- data/lib/fog/vcloud_director/query.rb +59 -0
- data/lib/fog/vcloud_director/requests/compute/delete_catalog_item.rb +22 -0
- data/lib/fog/vcloud_director/requests/compute/delete_catalog_item_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/delete_disk.rb +60 -0
- data/lib/fog/vcloud_director/requests/compute/delete_disk_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/delete_logout.rb +18 -0
- data/lib/fog/vcloud_director/requests/compute/delete_media.rb +122 -0
- data/lib/fog/vcloud_director/requests/compute/delete_media_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/delete_network.rb +62 -0
- data/lib/fog/vcloud_director/requests/compute/delete_shadow_vm.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp.rb +59 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp_metadata_item_metadata.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp_template.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/delete_vapp_template_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_allocated_ip_addresses.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog.rb +63 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_item.rb +48 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_item_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalog_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_catalogs_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_control_access_params_catalog.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_control_access_params_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_cpu_rasd_item.rb +65 -0
- data/lib/fog/vcloud_director/requests/compute/get_current_session.rb +83 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk.rb +123 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_disk_owner.rb +70 -0
- data/lib/fog/vcloud_director/requests/compute/get_disks_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_disks_rasd_items_list.rb +90 -0
- data/lib/fog/vcloud_director/requests/compute/get_edge_gateway.rb +109 -0
- data/lib/fog/vcloud_director/requests/compute/get_entity.rb +38 -0
- data/lib/fog/vcloud_director/requests/compute/get_execute_query.rb +736 -0
- data/lib/fog/vcloud_director/requests/compute/get_groups_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_guest_customization_system_section_vapp.rb +69 -0
- data/lib/fog/vcloud_director/requests/compute/get_guest_customization_system_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_href.rb +21 -0
- data/lib/fog/vcloud_director/requests/compute/get_lease_settings_section_vapp.rb +59 -0
- data/lib/fog/vcloud_director/requests/compute/get_lease_settings_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_media.rb +111 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_drives_rasd_items_list.rb +92 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_media_owner.rb +70 -0
- data/lib/fog/vcloud_director/requests/compute/get_medias_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_memory_rasd_item.rb +64 -0
- data/lib/fog/vcloud_director/requests/compute/get_metadata.rb +41 -0
- data/lib/fog/vcloud_director/requests/compute/get_network.rb +67 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_cards_items_list.rb +70 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_complete.rb +78 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_config_section_vapp.rb +61 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_config_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_connection_system_section_vapp.rb +68 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_connection_system_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_section_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_network_section_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_operating_system_section.rb +59 -0
- data/lib/fog/vcloud_director/requests/compute/get_org_settings.rb +38 -0
- data/lib/fog/vcloud_director/requests/compute/get_org_vdc_gateways.rb +83 -0
- data/lib/fog/vcloud_director/requests/compute/get_organization.rb +100 -0
- data/lib/fog/vcloud_director/requests/compute/get_organization_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_organization_metadata_item_metadata.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_organizations.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/get_organizations_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_product_sections_vapp.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_product_sections_vapp_template.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_request.rb +19 -0
- data/lib/fog/vcloud_director/requests/compute/get_runtime_info_section_type.rb +57 -0
- data/lib/fog/vcloud_director/requests/compute/get_serial_ports_items_list.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_shadow_vm.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_snapshot_section.rb +55 -0
- data/lib/fog/vcloud_director/requests/compute/get_startup_section.rb +64 -0
- data/lib/fog/vcloud_director/requests/compute/get_supported_systems_info.rb +239 -0
- data/lib/fog/vcloud_director/requests/compute/get_supported_versions.rb +1159 -0
- data/lib/fog/vcloud_director/requests/compute/get_task.rb +168 -0
- data/lib/fog/vcloud_director/requests/compute/get_task_list.rb +130 -0
- data/lib/fog/vcloud_director/requests/compute/get_template_vm.rb +74 -0
- data/lib/fog/vcloud_director/requests/compute/get_template_vms.rb +41 -0
- data/lib/fog/vcloud_director/requests/compute/get_thumbnail.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_users_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp.rb +176 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_metadata.rb +84 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_metadata_item_metadata.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_ovf_descriptor.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_owner.rb +58 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_customization_system_section.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_metadata_item_metadata.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_ovf_descriptor.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_template_owner.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapp_templates_from_query.rb +95 -0
- data/lib/fog/vcloud_director/requests/compute/get_vapps_in_lease_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_vcloud.rb +76 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc.rb +174 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_metadata_item_metadata.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_storage_class.rb +83 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_storage_class_metadata.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdc_storage_class_metadata_item_metadata.rb +25 -0
- data/lib/fog/vcloud_director/requests/compute/get_vdcs_from_query.rb +94 -0
- data/lib/fog/vcloud_director/requests/compute/get_virtual_hardware_section.rb +29 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm.rb +74 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_capabilities.rb +61 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_compliance_results.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_customization.rb +31 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_disks.rb +51 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_network.rb +56 -0
- data/lib/fog/vcloud_director/requests/compute/get_vm_pending_question.rb +34 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms.rb +41 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms_by_metadata.rb +20 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms_disk_attached_to.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/get_vms_in_lease_from_query.rb +150 -0
- data/lib/fog/vcloud_director/requests/compute/instantiate_vapp_template.rb +173 -0
- data/lib/fog/vcloud_director/requests/compute/post_acquire_ticket.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_answer_vm_pending_question.rb +36 -0
- data/lib/fog/vcloud_director/requests/compute/post_attach_disk.rb +51 -0
- data/lib/fog/vcloud_director/requests/compute/post_cancel_task.rb +43 -0
- data/lib/fog/vcloud_director/requests/compute/post_capture_vapp.rb +70 -0
- data/lib/fog/vcloud_director/requests/compute/post_check_vm_compliance.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/post_clone_media.rb +102 -0
- data/lib/fog/vcloud_director/requests/compute/post_clone_vapp.rb +62 -0
- data/lib/fog/vcloud_director/requests/compute/post_clone_vapp_template.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_compose_vapp.rb +45 -0
- data/lib/fog/vcloud_director/requests/compute/post_configure_edge_gateway_services.rb +73 -0
- data/lib/fog/vcloud_director/requests/compute/post_consolidate_vm_vapp.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_consolidate_vm_vapp_template.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_create_catalog_item.rb +56 -0
- data/lib/fog/vcloud_director/requests/compute/post_create_org_vdc_network.rb +171 -0
- data/lib/fog/vcloud_director/requests/compute/post_create_snapshot.rb +21 -0
- data/lib/fog/vcloud_director/requests/compute/post_deploy_vapp.rb +51 -0
- data/lib/fog/vcloud_director/requests/compute/post_detach_disk.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_disable_nested_hv.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_disable_vapp_template_download.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/post_discard_vapp_state.rb +30 -0
- data/lib/fog/vcloud_director/requests/compute/post_eject_cd_rom.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_enable_nested_hv.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_enable_vapp_template_download.rb +24 -0
- data/lib/fog/vcloud_director/requests/compute/post_enter_maintenance_mode.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/post_exit_maintenance_mode.rb +22 -0
- data/lib/fog/vcloud_director/requests/compute/post_insert_cd_rom.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_install_vmware_tools.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_instantiate_vapp_template.rb +196 -0
- data/lib/fog/vcloud_director/requests/compute/post_login_session.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/post_power_off_vapp.rb +36 -0
- data/lib/fog/vcloud_director/requests/compute/post_power_on_vapp.rb +71 -0
- data/lib/fog/vcloud_director/requests/compute/post_reboot_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_recompose_vapp.rb +21 -0
- data/lib/fog/vcloud_director/requests/compute/post_reconfigure_vm.rb +118 -0
- data/lib/fog/vcloud_director/requests/compute/post_remove_all_snapshots.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_reset_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_revert_snapshot.rb +27 -0
- data/lib/fog/vcloud_director/requests/compute/post_shutdown_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_suspend_vapp.rb +33 -0
- data/lib/fog/vcloud_director/requests/compute/post_undeploy_vapp.rb +66 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_catalog_item_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_disk_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_media_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_vapp_metadata.rb +86 -0
- data/lib/fog/vcloud_director/requests/compute/post_update_vapp_template_metadata.rb +52 -0
- data/lib/fog/vcloud_director/requests/compute/post_upgrade_hw_version.rb +28 -0
- data/lib/fog/vcloud_director/requests/compute/post_upload_disk.rb +133 -0
- data/lib/fog/vcloud_director/requests/compute/post_upload_media.rb +120 -0
- data/lib/fog/vcloud_director/requests/compute/post_upload_vapp_template.rb +46 -0
- data/lib/fog/vcloud_director/requests/compute/put_catalog_item_metadata_item_metadata.rb +50 -0
- data/lib/fog/vcloud_director/requests/compute/put_cpu.rb +88 -0
- data/lib/fog/vcloud_director/requests/compute/put_disk_metadata_item_metadata.rb +46 -0
- data/lib/fog/vcloud_director/requests/compute/put_disks.rb +39 -0
- data/lib/fog/vcloud_director/requests/compute/put_guest_customization_section_vapp.rb +141 -0
- data/lib/fog/vcloud_director/requests/compute/put_media_metadata_item_metadata.rb +50 -0
- data/lib/fog/vcloud_director/requests/compute/put_memory.rb +89 -0
- data/lib/fog/vcloud_director/requests/compute/put_metadata_value.rb +26 -0
- data/lib/fog/vcloud_director/requests/compute/put_network.rb +162 -0
- data/lib/fog/vcloud_director/requests/compute/put_network_connection_system_section_vapp.rb +152 -0
- data/lib/fog/vcloud_director/requests/compute/put_product_sections.rb +46 -0
- data/lib/fog/vcloud_director/requests/compute/put_vapp_metadata_item_metadata.rb +85 -0
- data/lib/fog/vcloud_director/requests/compute/put_vapp_name_and_description.rb +36 -0
- data/lib/fog/vcloud_director/requests/compute/put_vapp_template_metadata_item_metadata.rb +50 -0
- data/lib/fog/vcloud_director/requests/compute/put_vm.rb +72 -0
- data/lib/fog/vcloud_director/requests/compute/put_vm_capabilities.rb +44 -0
- data/lib/fog/vcloud_director/version.rb +5 -0
- data/spec/spec_helper.rb +15 -0
- data/spec/vcloud_director/generators/compute/instantiate_vapp_template_params_spec.rb +68 -0
- data/spec/vcloud_director/requests/compute/instantiate_vapp_template_spec.rb +78 -0
- data/spec/vcloud_director/spec_helper.rb +11 -0
- data/tasks/bundler.rake +3 -0
- data/tasks/console.rake +12 -0
- data/tasks/lint.rake +3 -0
- data/tasks/test.rake +13 -0
- data/tests/helper.rb +32 -0
- data/tests/helpers/collection_helper.rb +97 -0
- data/tests/helpers/compute/flavors_helper.rb +32 -0
- data/tests/helpers/compute/server_helper.rb +25 -0
- data/tests/helpers/compute/servers_helper.rb +10 -0
- data/tests/helpers/formats_helper.rb +98 -0
- data/tests/helpers/formats_helper_tests.rb +110 -0
- data/tests/helpers/mock_helper.rb +95 -0
- data/tests/helpers/model_helper.rb +31 -0
- data/tests/helpers/responds_to_helper.rb +11 -0
- data/tests/helpers/schema_validator_tests.rb +107 -0
- data/tests/helpers/succeeds_helper.rb +9 -0
- data/tests/lorem.txt +1 -0
- data/tests/vcloud_director/ensure_list_tests.rb +84 -0
- data/tests/vcloud_director/fixtures/test.iso +1 -0
- data/tests/vcloud_director/fixtures/vapp.xml +532 -0
- data/tests/vcloud_director/fixtures/vm.xml +213 -0
- data/tests/vcloud_director/generators/compute/compose_vapp_tests.rb +108 -0
- data/tests/vcloud_director/models/compute/catalog_items_tests.rb +42 -0
- data/tests/vcloud_director/models/compute/catalogs_tests.rb +40 -0
- data/tests/vcloud_director/models/compute/helper.rb +60 -0
- data/tests/vcloud_director/models/compute/media_tests.rb +58 -0
- data/tests/vcloud_director/models/compute/network_tests.rb +108 -0
- data/tests/vcloud_director/models/compute/organizations_tests.rb +18 -0
- data/tests/vcloud_director/models/compute/tasks_tests.rb +56 -0
- data/tests/vcloud_director/models/compute/vapp_life_cycle_tests.rb +93 -0
- data/tests/vcloud_director/models/compute/vapp_template_tests.rb +29 -0
- data/tests/vcloud_director/models/compute/vapp_tests.rb +61 -0
- data/tests/vcloud_director/models/compute/vdcs_tests.rb +54 -0
- data/tests/vcloud_director/models/compute/vms_tests.rb +101 -0
- data/tests/vcloud_director/requests/compute/admin_tests.rb +16 -0
- data/tests/vcloud_director/requests/compute/catalog_tests.rb +42 -0
- data/tests/vcloud_director/requests/compute/disk_tests.rb +178 -0
- data/tests/vcloud_director/requests/compute/edge_gateway_tests.rb +217 -0
- data/tests/vcloud_director/requests/compute/groups_tests.rb +18 -0
- data/tests/vcloud_director/requests/compute/helper.rb +32 -0
- data/tests/vcloud_director/requests/compute/media_tests.rb +195 -0
- data/tests/vcloud_director/requests/compute/network_tests.rb +186 -0
- data/tests/vcloud_director/requests/compute/organization_tests.rb +37 -0
- data/tests/vcloud_director/requests/compute/ovf_descriptor_tests.rb +36 -0
- data/tests/vcloud_director/requests/compute/query_tests.rb +99 -0
- data/tests/vcloud_director/requests/compute/schema_helper.rb +663 -0
- data/tests/vcloud_director/requests/compute/session_tests.rb +14 -0
- data/tests/vcloud_director/requests/compute/supported_systems_tests.rb +11 -0
- data/tests/vcloud_director/requests/compute/task_tests.rb +35 -0
- data/tests/vcloud_director/requests/compute/users_tests.rb +18 -0
- data/tests/vcloud_director/requests/compute/vapp_tests.rb +123 -0
- data/tests/vcloud_director/requests/compute/vdc_storage_profile_tests.rb +27 -0
- data/tests/vcloud_director/requests/compute/vdc_tests.rb +36 -0
- data/tests/vcloud_director/requests/compute/versions_tests.rb +13 -0
- data/tests/vcloud_director/requests/compute/vm_tests.rb +185 -0
- data/tests/watchr.rb +22 -0
- metadata +461 -0
@@ -0,0 +1,18 @@
|
|
1
|
+
Shindo.tests('Compute::VcloudDirector | groups requests', ['vclouddirector']) do
|
2
|
+
|
3
|
+
@service = Fog::Compute::VcloudDirector.new
|
4
|
+
|
5
|
+
tests('#get_groups_from_query') do
|
6
|
+
pending if Fog.mocking?
|
7
|
+
%w[idrecords records references].each do |format|
|
8
|
+
tests(":format => #{format}") do
|
9
|
+
tests('#body').data_matches_schema(VcloudDirector::Compute::Schema::CONTAINER_TYPE) do
|
10
|
+
@body = @service.get_groups_from_query(:format => format).body
|
11
|
+
end
|
12
|
+
key = (format == 'references') ? 'GroupReference' : 'GroupRecord'
|
13
|
+
tests("#body.key?(:#{key})").returns(true) { @body.key?(key.to_sym) }
|
14
|
+
end
|
15
|
+
end
|
16
|
+
end
|
17
|
+
|
18
|
+
end
|
@@ -0,0 +1,32 @@
|
|
1
|
+
class VcloudDirector
|
2
|
+
module Compute
|
3
|
+
module Helper
|
4
|
+
def self.test_name
|
5
|
+
@test_name ||= 'fog-test-%x' % Time.now.to_i
|
6
|
+
end
|
7
|
+
|
8
|
+
def self.fixture(filename)
|
9
|
+
File.join(File.expand_path('../../../fixtures', __FILE__), filename)
|
10
|
+
end
|
11
|
+
|
12
|
+
def self.current_org(service)
|
13
|
+
service.get_organization(current_org_id(service)).body
|
14
|
+
end
|
15
|
+
|
16
|
+
def self.current_org_id(service)
|
17
|
+
session = service.get_current_session.body
|
18
|
+
link = session[:Link].find do |l|
|
19
|
+
l[:type] == 'application/vnd.vmware.vcloud.org+xml'
|
20
|
+
end
|
21
|
+
link[:href].split('/').last
|
22
|
+
end
|
23
|
+
|
24
|
+
def self.first_vdc_id(org)
|
25
|
+
link = org[:Link].find do |l|
|
26
|
+
l[:type] == 'application/vnd.vmware.vcloud.vdc+xml'
|
27
|
+
end
|
28
|
+
link[:href].split('/').last
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
end
|
@@ -0,0 +1,195 @@
|
|
1
|
+
Shindo.tests('Compute::VcloudDirector | media requests', ['vclouddirector']) do
|
2
|
+
|
3
|
+
@service = Fog::Compute::VcloudDirector.new
|
4
|
+
|
5
|
+
tests('error conditions') do
|
6
|
+
tests('#post_upload_media') do
|
7
|
+
tests('Invalid image_type').raises(Fog::Compute::VcloudDirector::BadRequest) do
|
8
|
+
@service.post_upload_media('00000000-0000-0000-0000-000000000000', 'test.iso', 'isox', 0)
|
9
|
+
end
|
10
|
+
tests('Invalid size').raises(Fog::Compute::VcloudDirector::BadRequest) do
|
11
|
+
@service.post_upload_media('00000000-0000-0000-0000-000000000000', 'test.iso', 'iso', -1)
|
12
|
+
end
|
13
|
+
end
|
14
|
+
tests('Upload to non-existent vDC').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
15
|
+
@service.post_upload_media('00000000-0000-0000-0000-000000000000', 'test.iso', 'iso', 0)
|
16
|
+
end
|
17
|
+
tests('Retrieve non-existent Media').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
18
|
+
@service.get_media('00000000-0000-0000-0000-000000000000')
|
19
|
+
end
|
20
|
+
tests('Retrieve owner of non-existent Media').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
21
|
+
@service.get_media_owner('00000000-0000-0000-0000-000000000000')
|
22
|
+
end
|
23
|
+
tests('Delete non-existent Media').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
24
|
+
@service.delete_media('00000000-0000-0000-0000-000000000000')
|
25
|
+
end
|
26
|
+
end
|
27
|
+
|
28
|
+
@org = VcloudDirector::Compute::Helper.current_org(@service)
|
29
|
+
@media_name = VcloudDirector::Compute::Helper.test_name
|
30
|
+
|
31
|
+
tests('Upload and manipulate a media object') do
|
32
|
+
File.open(VcloudDirector::Compute::Helper.fixture('test.iso'), 'rb') do |iso|
|
33
|
+
tests('#post_upload_media').data_matches_schema(VcloudDirector::Compute::Schema::MEDIA_TYPE) do
|
34
|
+
@vdc_id = VcloudDirector::Compute::Helper.first_vdc_id(@org)
|
35
|
+
@size = File.size(iso.path)
|
36
|
+
@media = @service.post_upload_media(@vdc_id, @media_name, 'iso', @size).body
|
37
|
+
end
|
38
|
+
|
39
|
+
tests('media object has exactly one file').returns(true) do
|
40
|
+
@media[:Files][:File].size == 1
|
41
|
+
end
|
42
|
+
|
43
|
+
tests('media object file has an upload link').returns(true) do
|
44
|
+
@link = @media[:Files][:File].first[:Link]
|
45
|
+
@link[:rel] == 'upload:default'
|
46
|
+
end
|
47
|
+
|
48
|
+
unless Fog.mocking?
|
49
|
+
headers = {
|
50
|
+
'Content-Length' => @size,
|
51
|
+
'Content-Type' => 'application/octet-stream',
|
52
|
+
'x-vcloud-authorization' => @service.vcloud_token
|
53
|
+
}
|
54
|
+
Excon.put(
|
55
|
+
@link[:href], :body => iso.read, :expects => 200, :headers => headers
|
56
|
+
)
|
57
|
+
end
|
58
|
+
|
59
|
+
@service.process_task(@media[:Tasks][:Task])
|
60
|
+
@media_id = @media[:href].split('/').last
|
61
|
+
|
62
|
+
tests("#get_media(#{@media_id})").data_matches_schema(VcloudDirector::Compute::Schema::MEDIA_TYPE) do
|
63
|
+
@media = @service.get_media(@media_id).body
|
64
|
+
end
|
65
|
+
tests("media[:name]").returns(@media_name) { @media[:name] }
|
66
|
+
tests("media[:imageType]").returns('iso') { @media[:imageType] }
|
67
|
+
tests("media[:size]").returns(@size) { @media[:size].to_i }
|
68
|
+
|
69
|
+
tests("#get_media_owner(#{@media_id})").data_matches_schema(VcloudDirector::Compute::Schema::OWNER_TYPE) do
|
70
|
+
@owner = @service.get_media_owner(@media_id).body
|
71
|
+
end
|
72
|
+
tests("owner[:User][:name]").returns(@service.user_name) { @owner[:User][:name] }
|
73
|
+
|
74
|
+
tests('media metadata') do
|
75
|
+
pending if Fog.mocking?
|
76
|
+
|
77
|
+
tests("#put_media_metadata_item_metadata(#{@media_id})").data_matches_schema(VcloudDirector::Compute::Schema::TASK_TYPE) do
|
78
|
+
@task = @service.put_media_metadata_item_metadata(@media_id, 'fog-test-key', 'fog-test-value').body
|
79
|
+
end
|
80
|
+
@service.process_task(@task)
|
81
|
+
|
82
|
+
tests("#put_media_metadata_item_metadata(#{@media_id})") do
|
83
|
+
tests("#put_media_metadata_item_metadata(Boolean)").returns(true) do
|
84
|
+
task = @service.put_media_metadata_item_metadata(@media_id, 'fog-test-boolean', true).body
|
85
|
+
@service.process_task(task)
|
86
|
+
end
|
87
|
+
tests("#put_media_metadata_item_metadata(DateTime)").returns(true) do
|
88
|
+
task = @service.put_media_metadata_item_metadata(@media_id, 'fog-test-datetime', DateTime.now).body
|
89
|
+
@service.process_task(task)
|
90
|
+
end
|
91
|
+
tests("#put_media_metadata_item_metadata(Number)").returns(true) do
|
92
|
+
task = @service.put_media_metadata_item_metadata(@media_id, 'fog-test-number', 111).body
|
93
|
+
@service.process_task(task)
|
94
|
+
end
|
95
|
+
end
|
96
|
+
|
97
|
+
tests("#post_update_media_metadata(#{@media_id})").data_matches_schema(VcloudDirector::Compute::Schema::TASK_TYPE) do
|
98
|
+
metadata = {
|
99
|
+
'fog-test-key-update' => 'fog-test-value-update',
|
100
|
+
'fog-test-boolean-update' => false,
|
101
|
+
'fog-test-datetime-update' => DateTime.now,
|
102
|
+
'fog-test-number-update' => 222
|
103
|
+
}
|
104
|
+
@task = @service.post_update_media_metadata(@media_id, metadata).body
|
105
|
+
end
|
106
|
+
@service.process_task(@task)
|
107
|
+
|
108
|
+
tests("#get_media_metadata(#{@media_id})") do
|
109
|
+
tests('response format').data_matches_schema(VcloudDirector::Compute::Schema::METADATA_TYPE) do
|
110
|
+
@metadata = @service.get_media_metadata(@media_id).body
|
111
|
+
end
|
112
|
+
tests('TypedValue') do
|
113
|
+
pending if @service.api_version.to_f < 5.1
|
114
|
+
tests('key').returns('MetadataStringValue') do
|
115
|
+
entry = @metadata[:MetadataEntry].find {|e| e[:Key] == 'fog-test-key'}
|
116
|
+
entry[:TypedValue][:xsi_type]
|
117
|
+
end
|
118
|
+
tests('boolean').returns('MetadataBooleanValue') do
|
119
|
+
entry = @metadata[:MetadataEntry].find {|e| e[:Key] == 'fog-test-boolean'}
|
120
|
+
entry[:TypedValue][:xsi_type]
|
121
|
+
end
|
122
|
+
tests('datetime').returns('MetadataDateTimeValue') do
|
123
|
+
entry = @metadata[:MetadataEntry].find {|e| e[:Key] == 'fog-test-datetime'}
|
124
|
+
entry[:TypedValue][:xsi_type]
|
125
|
+
end
|
126
|
+
tests('number').returns('MetadataNumberValue') do
|
127
|
+
entry = @metadata[:MetadataEntry].find {|e| e[:Key] == 'fog-test-number'}
|
128
|
+
entry[:TypedValue][:xsi_type]
|
129
|
+
end
|
130
|
+
tests('key-update').returns('MetadataStringValue') do
|
131
|
+
entry = @metadata[:MetadataEntry].find {|e| e[:Key] == 'fog-test-key-update'}
|
132
|
+
entry[:TypedValue][:xsi_type]
|
133
|
+
end
|
134
|
+
tests('boolean-update').returns('MetadataBooleanValue') do
|
135
|
+
entry = @metadata[:MetadataEntry].find {|e| e[:Key] == 'fog-test-boolean-update'}
|
136
|
+
entry[:TypedValue][:xsi_type]
|
137
|
+
end
|
138
|
+
tests('datetime-update').returns('MetadataDateTimeValue') do
|
139
|
+
entry = @metadata[:MetadataEntry].find {|e| e[:Key] == 'fog-test-datetime-update'}
|
140
|
+
entry[:TypedValue][:xsi_type]
|
141
|
+
end
|
142
|
+
tests('number-update').returns('MetadataNumberValue') do
|
143
|
+
entry = @metadata[:MetadataEntry].find {|e| e[:Key] == 'fog-test-number-update'}
|
144
|
+
entry[:TypedValue][:xsi_type]
|
145
|
+
end
|
146
|
+
end
|
147
|
+
end
|
148
|
+
end
|
149
|
+
|
150
|
+
tests("#post_clone_media(#{@media_id})").data_matches_schema(VcloudDirector::Compute::Schema::MEDIA_TYPE) do
|
151
|
+
@media = @service.post_clone_media(@vdc_id, @media_id, :IsSourceDelete => true).body
|
152
|
+
end
|
153
|
+
@service.process_task(@media[:Tasks][:Task])
|
154
|
+
@media_id = @media[:href].split('/').last
|
155
|
+
tests("media[:name] starts '#{@media_name}-copy-'").returns(true) do
|
156
|
+
!!(@media[:name] =~ /^#{@media_name}-copy-/)
|
157
|
+
end
|
158
|
+
|
159
|
+
tests("#delete_media(#{@media_id})").data_matches_schema(VcloudDirector::Compute::Schema::TASK_TYPE) do
|
160
|
+
@task = @service.delete_media(@media_id).body
|
161
|
+
end
|
162
|
+
@service.process_task(@task)
|
163
|
+
end
|
164
|
+
end
|
165
|
+
|
166
|
+
tests('Media item no longer exists') do
|
167
|
+
tests("#get_media(#{@media_id})").raises(Fog::Compute::VcloudDirector::Forbidden) do
|
168
|
+
@service.get_media(@media_id)
|
169
|
+
end
|
170
|
+
tests("#get_media_owner(#{@media_id})").raises(Fog::Compute::VcloudDirector::Forbidden) do
|
171
|
+
@service.get_media_owner(@media_id)
|
172
|
+
end
|
173
|
+
tests("#get_media_metadata(#{@media_id})").raises(Fog::Compute::VcloudDirector::Forbidden) do
|
174
|
+
pending if Fog.mocking?
|
175
|
+
@service.get_media_metadata(@media_id)
|
176
|
+
end
|
177
|
+
tests("#delete_media(#{@media_id})").raises(Fog::Compute::VcloudDirector::Forbidden) do
|
178
|
+
@service.delete_media(@media_id)
|
179
|
+
end
|
180
|
+
end
|
181
|
+
|
182
|
+
tests('#get_medias_from_query') do
|
183
|
+
pending if Fog.mocking?
|
184
|
+
%w[idrecords records references].each do |format|
|
185
|
+
tests(":format => #{format}") do
|
186
|
+
tests('#body').data_matches_schema(VcloudDirector::Compute::Schema::CONTAINER_TYPE) do
|
187
|
+
@body = @service.get_medias_from_query(:format => format).body
|
188
|
+
end
|
189
|
+
key = (format == 'references') ? 'MediaReference' : 'MediaRecord'
|
190
|
+
tests("#body.key?(:#{key})").returns(true) { @body.key?(key.to_sym) }
|
191
|
+
end
|
192
|
+
end
|
193
|
+
end
|
194
|
+
|
195
|
+
end
|
@@ -0,0 +1,186 @@
|
|
1
|
+
|
2
|
+
require 'pp'
|
3
|
+
|
4
|
+
Shindo.tests('Compute::VcloudDirector | network requests', ['vclouddirector']) do
|
5
|
+
|
6
|
+
GET_NETWORK_FORMAT = {
|
7
|
+
:type => String,
|
8
|
+
:name => String,
|
9
|
+
:href => String,
|
10
|
+
:id => String,
|
11
|
+
:description => Fog::Nullable::String,
|
12
|
+
:is_inherited => Fog::Boolean,
|
13
|
+
:gateway => Fog::Nullable::String,
|
14
|
+
:netmask => String,
|
15
|
+
:dns1 => Fog::Nullable::String,
|
16
|
+
:dns2 => Fog::Nullable::String,
|
17
|
+
:dns_suffix => Fog::Nullable::String,
|
18
|
+
:ip_ranges => [{
|
19
|
+
:start_address => String,
|
20
|
+
:end_address => String
|
21
|
+
}]
|
22
|
+
}
|
23
|
+
|
24
|
+
@service = Fog::Compute::VcloudDirector.new
|
25
|
+
@org = VcloudDirector::Compute::Helper.current_org(@service)
|
26
|
+
@created_net_id = nil
|
27
|
+
|
28
|
+
tests('Create network in non-existent vDC').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
29
|
+
@service.post_create_org_vdc_network('00000000-0000-0000-0000-000000000000', 'bob')
|
30
|
+
end
|
31
|
+
|
32
|
+
tests('Delete non-existent OrgNetwork').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
33
|
+
@service.delete_network('00000000-0000-0000-0000-000000000000')
|
34
|
+
end
|
35
|
+
|
36
|
+
tests('Retrieve non-existent OrgNetwork (get_network)').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
37
|
+
@service.get_network('00000000-0000-0000-0000-000000000000')
|
38
|
+
end
|
39
|
+
|
40
|
+
tests('Retrieve non-existent OrgNetwork (get_network_complete)').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
41
|
+
@service.get_network_complete('00000000-0000-0000-0000-000000000000')
|
42
|
+
end
|
43
|
+
|
44
|
+
tests('#get_network').data_matches_schema(GET_NETWORK_FORMAT) do
|
45
|
+
link = @org[:Link].find do |l|
|
46
|
+
l[:rel] == 'down' && l[:type] == 'application/vnd.vmware.vcloud.orgNetwork+xml'
|
47
|
+
end
|
48
|
+
pending unless link # nothing to test here cannot continue
|
49
|
+
@network_id = link[:href].split('/').last
|
50
|
+
@service.get_network(@network_id).body
|
51
|
+
end
|
52
|
+
|
53
|
+
tests('#get_network_metadata').data_matches_schema(VcloudDirector::Compute::Schema::METADATA_TYPE) do
|
54
|
+
pending if Fog.mocking?
|
55
|
+
pending unless @network_id # nothing to test here cannot continue
|
56
|
+
@service.get_network_metadata(@network_id).body
|
57
|
+
end
|
58
|
+
|
59
|
+
tests('#post_create_org_vdc_network') do
|
60
|
+
#pending unless Fog.mocking?
|
61
|
+
link = @org[:Link].find do |l|
|
62
|
+
l[:rel] == 'down' && l[:type] == 'application/vnd.vmware.vcloud.vdc+xml'
|
63
|
+
end
|
64
|
+
|
65
|
+
vdc_id = link[:href].split('/').last
|
66
|
+
name = VcloudDirector::Compute::Helper.test_name
|
67
|
+
|
68
|
+
options = {
|
69
|
+
:Description => "Testing post_create_org_vdc_network #{name}",
|
70
|
+
:Configuration => {
|
71
|
+
:IpScopes => {
|
72
|
+
:IpScope => {
|
73
|
+
:IsInherited => 'false',
|
74
|
+
:Gateway => '198.51.100.1',
|
75
|
+
:Netmask => '255.255.255.0',
|
76
|
+
:Dns1 => '198.51.100.2',
|
77
|
+
:Dns2 => '198.51.100.3',
|
78
|
+
:DnsSuffix => 'example.com',
|
79
|
+
:IpRanges => [
|
80
|
+
{ :IpRange => { :StartAddress => '198.51.100.10', :EndAddress => '198.51.100.20' } },
|
81
|
+
{ :IpRange => { :StartAddress => '198.51.100.30', :EndAddress => '198.51.100.40' } },
|
82
|
+
]
|
83
|
+
},
|
84
|
+
},
|
85
|
+
:FenceMode => 'isolated',
|
86
|
+
}
|
87
|
+
}
|
88
|
+
|
89
|
+
body = @service.post_create_org_vdc_network(vdc_id, name, options).body
|
90
|
+
@created_net_id = body[:href].split('/').last if body[:href]
|
91
|
+
@service.process_task(body[:Tasks][:Task]) if body && body.key?(:Tasks)
|
92
|
+
|
93
|
+
tests('fetched name matches created name').returns(name) do
|
94
|
+
net = @service.get_network_complete(@created_net_id).body
|
95
|
+
net[:name]
|
96
|
+
end
|
97
|
+
|
98
|
+
end
|
99
|
+
|
100
|
+
tests('#get_network_complete schema').data_matches_schema(VcloudDirector::Compute::Schema::NETWORK_TYPE) do
|
101
|
+
link = @org[:Link].find do |l|
|
102
|
+
l[:rel] == 'down' && l[:type] == 'application/vnd.vmware.vcloud.orgNetwork+xml'
|
103
|
+
end
|
104
|
+
pending unless link # nothing to test here cannot continue
|
105
|
+
@network_id = link[:href].split('/').last
|
106
|
+
@service.get_network_complete(@network_id).body
|
107
|
+
end
|
108
|
+
|
109
|
+
tests('#get_network_complete') do
|
110
|
+
new_network = @service.get_network_complete(@created_net_id).body
|
111
|
+
tests('network has a :name') do
|
112
|
+
new_network.fetch(:name)
|
113
|
+
end
|
114
|
+
tests('network has a :Description') do
|
115
|
+
new_network.fetch(:Description)
|
116
|
+
end
|
117
|
+
tests('network has a :Gateway') do
|
118
|
+
new_network[:Configuration][:IpScopes][:IpScope][:Gateway]
|
119
|
+
end
|
120
|
+
tests('network has a several :IpRanges') do
|
121
|
+
new_network[:Configuration][:IpScopes][:IpScope][:IpRanges].size >= 1
|
122
|
+
end
|
123
|
+
end
|
124
|
+
|
125
|
+
tests('#put_network') do
|
126
|
+
|
127
|
+
new_options = {
|
128
|
+
:Description => "Testing put_network",
|
129
|
+
:Configuration => {
|
130
|
+
:IpScopes => {
|
131
|
+
:IpScope => {
|
132
|
+
:IsInherited => 'false',
|
133
|
+
:Gateway => '198.51.100.1',
|
134
|
+
:Netmask => '255.255.255.0',
|
135
|
+
:Dns1 => '198.51.100.2',
|
136
|
+
:Dns2 => '198.51.100.3',
|
137
|
+
:DnsSuffix => 'example.com',
|
138
|
+
:IpRanges => [
|
139
|
+
{ :IpRange => { :StartAddress => '198.51.100.10', :EndAddress => '198.51.100.20' } },
|
140
|
+
{ :IpRange => { :StartAddress => '198.51.100.30', :EndAddress => '198.51.100.40' } },
|
141
|
+
]
|
142
|
+
},
|
143
|
+
},
|
144
|
+
:FenceMode => 'isolated',
|
145
|
+
}
|
146
|
+
}
|
147
|
+
|
148
|
+
original_network = @service.get_network_complete(@created_net_id).body
|
149
|
+
name = original_network[:name]
|
150
|
+
|
151
|
+
task = @service.put_network(@created_net_id, name, new_options).body
|
152
|
+
@service.process_task(task)
|
153
|
+
|
154
|
+
tests('fetched :Gateway matches updated :Gateway').returns(
|
155
|
+
new_options[:Configuration][:IpScopes][:IpScope][:Gateway]
|
156
|
+
) do
|
157
|
+
net = @service.get_network_complete(@created_net_id).body
|
158
|
+
net[:Configuration][:IpScopes][:IpScope][:Gateway]
|
159
|
+
end
|
160
|
+
|
161
|
+
tests('fetched :IpRanges count is matches updated data').returns(
|
162
|
+
new_options[:Configuration][:IpScopes][:IpScope][:IpRanges].size
|
163
|
+
) do
|
164
|
+
net = @service.get_network_complete(@created_net_id).body
|
165
|
+
# dammit, the API returns with IpRange as a list, not IpRanges
|
166
|
+
net[:Configuration][:IpScopes][:IpScope][:IpRanges][:IpRange].size
|
167
|
+
end
|
168
|
+
|
169
|
+
tests('fetched :Network matches updated :Description').returns(
|
170
|
+
new_options[:Description]
|
171
|
+
) do
|
172
|
+
net = @service.get_network_complete(@created_net_id).body
|
173
|
+
net[:Description]
|
174
|
+
end
|
175
|
+
|
176
|
+
end
|
177
|
+
|
178
|
+
tests('#delete_network') do
|
179
|
+
@delete_task = @service.delete_network(@created_net_id).body
|
180
|
+
@service.process_task(@delete_task)
|
181
|
+
tests('created network has been deleted').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
182
|
+
@service.get_network(@created_net_id)
|
183
|
+
end
|
184
|
+
end
|
185
|
+
|
186
|
+
end
|
@@ -0,0 +1,37 @@
|
|
1
|
+
Shindo.tests('Compute::VcloudDirector | organization requests', ['vclouddirector']) do
|
2
|
+
|
3
|
+
@service = Fog::Compute::VcloudDirector.new
|
4
|
+
|
5
|
+
tests('#get_organizations').data_matches_schema(VcloudDirector::Compute::Schema::ORG_LIST_TYPE) do
|
6
|
+
@org_list = @service.get_organizations.body
|
7
|
+
end
|
8
|
+
|
9
|
+
tests('#get_organization').data_matches_schema(VcloudDirector::Compute::Schema::ORG_TYPE) do
|
10
|
+
org = @org_list[:Org].find {|o| o[:name] == @service.org_name}
|
11
|
+
@org_uuid = org[:href].split('/').last
|
12
|
+
@service.get_organization(@org_uuid).body
|
13
|
+
end
|
14
|
+
|
15
|
+
tests('#get_organization_metadata').data_matches_schema(VcloudDirector::Compute::Schema::METADATA_TYPE) do
|
16
|
+
pending if Fog.mocking?
|
17
|
+
@service.get_organization_metadata(@org_uuid).body
|
18
|
+
end
|
19
|
+
|
20
|
+
tests('#get_organizations_from_query') do
|
21
|
+
pending if Fog.mocking?
|
22
|
+
%w[idrecords records references].each do |format|
|
23
|
+
tests(":format => #{format}") do
|
24
|
+
tests('#body').data_matches_schema(VcloudDirector::Compute::Schema::CONTAINER_TYPE) do
|
25
|
+
@body = @service.get_organizations_from_query(:format => format).body
|
26
|
+
end
|
27
|
+
key = (format == 'references') ? 'OrganizationReference' : 'OrganizationRecord'
|
28
|
+
tests("#body.key?(:#{key})").returns(true) { @body.key?(key.to_sym) }
|
29
|
+
end
|
30
|
+
end
|
31
|
+
end
|
32
|
+
|
33
|
+
tests('retrieve non-existent Org').raises(Fog::Compute::VcloudDirector::Forbidden) do
|
34
|
+
@service.get_organization('00000000-0000-0000-0000-000000000000')
|
35
|
+
end
|
36
|
+
|
37
|
+
end
|