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,58 @@
|
|
1
|
+
require File.expand_path(File.join(File.dirname(__FILE__), 'helper'))
|
2
|
+
|
3
|
+
Shindo.tests('Compute::VcloudDirector | media', ['vclouddirector']) do
|
4
|
+
pending if Fog.mocking?
|
5
|
+
|
6
|
+
medias = vdc.medias
|
7
|
+
media_name = VcloudDirector::Compute::Helper.test_name
|
8
|
+
|
9
|
+
tests('Compute::VcloudDirector | media', ['create']) do
|
10
|
+
tests('#create').returns(Fog::Compute::VcloudDirector::Media) do
|
11
|
+
File.open(VcloudDirector::Compute::Helper.fixture('test.iso'), 'rb') do |iso|
|
12
|
+
medias.create(media_name, iso).class
|
13
|
+
end
|
14
|
+
end
|
15
|
+
end
|
16
|
+
|
17
|
+
media = medias.get_by_name(media_name)
|
18
|
+
|
19
|
+
tests('Compute::VcloudDirector | media') do
|
20
|
+
tests('#href').returns(String) { media.href.class }
|
21
|
+
tests('#type').returns('application/vnd.vmware.vcloud.media+xml') { media.type }
|
22
|
+
tests('#id').returns(String) { media.id.class }
|
23
|
+
tests('#name').returns(String) { media.name.class }
|
24
|
+
end
|
25
|
+
|
26
|
+
tests('Compute::VcloudDirector | media', ['lazy load attrs']) do
|
27
|
+
media.lazy_load_attrs.each do |lazy_attr|
|
28
|
+
tests("##{lazy_attr} is not loaded yet").returns(NonLoaded) { media.attributes[lazy_attr] }
|
29
|
+
end
|
30
|
+
end
|
31
|
+
|
32
|
+
tests('Compute::VcloudDirector | media', ['load on demand']) do
|
33
|
+
tests('#description is not loaded yet').returns(NonLoaded) { media.attributes[:description] }
|
34
|
+
tests('#description is loaded on demand').returns(String) { media.description.class }
|
35
|
+
tests('#description is now loaded').returns(true) { media.attributes[:description] != NonLoaded }
|
36
|
+
end
|
37
|
+
|
38
|
+
tests('Compute::VcloudDirector | media', ['lazy load attrs']) do
|
39
|
+
media.lazy_load_attrs.each do |lazy_attr|
|
40
|
+
tests("##{lazy_attr} is now loaded").returns(true) { media.attributes[lazy_attr] != NonLoaded }
|
41
|
+
end
|
42
|
+
end
|
43
|
+
|
44
|
+
tests('Compute::VcloudDirector | media' ['attributes']) do
|
45
|
+
tests('#status').returns(Fixnum) { media.status.class }
|
46
|
+
tests('#image_type').returns(String) { media.image_type.class }
|
47
|
+
tests('#size').returns(Fixnum) { media.size.class }
|
48
|
+
end
|
49
|
+
|
50
|
+
tests('Compute::VcloudDirector | media', ['get']) do
|
51
|
+
tests('#get_by_name').returns(media.name) { medias.get_by_name(media.name).name }
|
52
|
+
tests('#get').returns(media.id) { medias.get(media.id).id }
|
53
|
+
end
|
54
|
+
|
55
|
+
tests('Compute::VcloudDirector | media', ['destroy']) do
|
56
|
+
tests('#destroy').returns(true) { media.destroy }
|
57
|
+
end
|
58
|
+
end
|
@@ -0,0 +1,108 @@
|
|
1
|
+
require File.expand_path(File.join(File.dirname(__FILE__), 'helper'))
|
2
|
+
|
3
|
+
Shindo.tests("Compute::VcloudDirector | networks", ['vclouddirector', 'all']) do
|
4
|
+
|
5
|
+
# unless there is at least one network we cannot run these tests
|
6
|
+
pending if organization.networks.empty?
|
7
|
+
|
8
|
+
service = Fog::Compute::VcloudDirector.new
|
9
|
+
|
10
|
+
networks = organization.networks
|
11
|
+
network_raw = nil
|
12
|
+
|
13
|
+
# Run initial tests against a natRouted network, since these
|
14
|
+
# are more likely to be created, and must be populated with
|
15
|
+
# Gateway and EdgeGateway sections
|
16
|
+
network = networks.find do |net|
|
17
|
+
network_raw = service.get_network_complete(net.id).body
|
18
|
+
network_raw[:Configuration][:FenceMode] == 'natRouted'
|
19
|
+
end
|
20
|
+
|
21
|
+
# We don't have a sufficiently populated natRouted network to test against
|
22
|
+
pending if network_raw.nil?
|
23
|
+
|
24
|
+
UUID_REGEX = /^[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12}$/
|
25
|
+
IP_REGEX = /^[0-9]+\.[0-9]+\.[0-9]+\.[0-9]+$/
|
26
|
+
|
27
|
+
tests("Compute::VcloudDirector | network") do
|
28
|
+
tests("#id").returns(0) { network.id =~ UUID_REGEX }
|
29
|
+
tests("#name").returns(String) { network.name.class }
|
30
|
+
tests("#href").returns(String) { network.href.class }
|
31
|
+
tests("#type").returns("application/vnd.vmware.vcloud.orgNetwork+xml"){ network.type }
|
32
|
+
end
|
33
|
+
|
34
|
+
tests("Compute::VcloudDirector | network", ['lazy load attrs']) do
|
35
|
+
network.lazy_load_attrs.each do |lazy_attr|
|
36
|
+
tests("##{lazy_attr} is not loaded yet").returns(NonLoaded) { network.attributes[lazy_attr] }
|
37
|
+
end
|
38
|
+
end
|
39
|
+
|
40
|
+
tests("Compute::VcloudDirector | network", ['load on demand']) do
|
41
|
+
network_raw_gateway = network_raw[:Configuration][:IpScopes][:IpScope][:Gateway]
|
42
|
+
tests("#gateway is not loaded yet").returns(NonLoaded) { network.attributes[:gateway] }
|
43
|
+
tests("#gateway is loaded on demand").returns(network_raw_gateway) { network.gateway }
|
44
|
+
tests("#gateway is now loaded").returns(true) { network.attributes[:gateway] != NonLoaded }
|
45
|
+
end
|
46
|
+
|
47
|
+
tests("Compute::VcloudDirector | network", ['all lazy load attrs should now be loaded with data']) do
|
48
|
+
network.lazy_load_attrs.each do |field|
|
49
|
+
tests("##{field.to_s} is now loaded").returns(true) { network.attributes[field] != NonLoaded }
|
50
|
+
end
|
51
|
+
end
|
52
|
+
|
53
|
+
tests("Compute::VcloudDirector | network", ['ip_ranges is an array of start-end pairs']) do
|
54
|
+
tests("#ip_ranges is an Array").returns(Array) { network.ip_ranges.class }
|
55
|
+
network.ip_ranges.each do |range|
|
56
|
+
tests("each ip_range has a :start_address").returns(0) { range[:start_address] =~ IP_REGEX }
|
57
|
+
tests("each ip_range has an :end_address").returns(0) { range[:end_address] =~ IP_REGEX }
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
tests("Compute::VcloudDirector | network", ['is_shared is a string boolean']) do
|
62
|
+
tests("#is_shared is either 'true' or 'false'").returns(true) {
|
63
|
+
[ 'false', 'true' ].include?(network.is_shared)
|
64
|
+
}
|
65
|
+
end
|
66
|
+
|
67
|
+
# NB: get_by_name is buggy with orgVdcNetworks - network names are only
|
68
|
+
# unique per-vDC, not per organization.
|
69
|
+
# As a result, it returns the *first* network matching that name.
|
70
|
+
tests("Compute::VcloudDirector | networks", ['get']) do
|
71
|
+
tests("#get_by_name").returns(network.name) { networks.get_by_name(network.name).name }
|
72
|
+
tests("#get").returns(network.id) { networks.get(network.id).id }
|
73
|
+
end
|
74
|
+
|
75
|
+
|
76
|
+
# Now let's also check against an isolated network, since these have some
|
77
|
+
# additional features like DHCP ServiceConfigurations.
|
78
|
+
isolated_network_raw = nil
|
79
|
+
isolated_network = networks.find do |net|
|
80
|
+
isolated_network_raw = service.get_network_complete(net.id).body
|
81
|
+
isolated_network_raw[:Configuration][:FenceMode] == 'isolated'
|
82
|
+
end
|
83
|
+
|
84
|
+
pending if isolated_network_raw.nil?
|
85
|
+
|
86
|
+
tests("Compute::VcloudDirector | isolated network", ['load on demand']) do
|
87
|
+
tests("#fence_mode is not loaded yet").returns(NonLoaded) { isolated_network.attributes[:fence_mode] }
|
88
|
+
tests("#fence_mode is loaded on demand").returns('isolated') { isolated_network.fence_mode }
|
89
|
+
tests("#fence_mode is now loaded").returns(true) { isolated_network.attributes[:fence_mode] != NonLoaded }
|
90
|
+
end
|
91
|
+
|
92
|
+
# We should also be able to find these same networks via Query API
|
93
|
+
tests("Compute::VcloudDirector | networks", ['find_by_query']) do
|
94
|
+
tests('we can retrieve :name without lazy loading').returns(network.name) do
|
95
|
+
query_network = networks.find_by_query(:filter => "name==#{network.name}").first
|
96
|
+
query_network.attributes[:name]
|
97
|
+
end
|
98
|
+
tests('by name: natRouted').returns(network.name) do
|
99
|
+
query_network = networks.find_by_query(:filter => "name==#{network.name}").first
|
100
|
+
query_network.name
|
101
|
+
end
|
102
|
+
tests('by name: isolated').returns(isolated_network.name) do
|
103
|
+
query_network = networks.find_by_query(:filter => "name==#{isolated_network.name}").first
|
104
|
+
query_network.name
|
105
|
+
end
|
106
|
+
end
|
107
|
+
|
108
|
+
end
|
@@ -0,0 +1,18 @@
|
|
1
|
+
require File.expand_path(File.join(File.dirname(__FILE__), 'helper'))
|
2
|
+
|
3
|
+
Shindo.tests("Compute::VcloudDirector | organizations", ['vclouddirector', 'all']) do
|
4
|
+
organizations = vcloud_director.organizations
|
5
|
+
tests("#There is at least one organization").returns(true) { organizations.size >= 1 }
|
6
|
+
|
7
|
+
org = organizations.get_by_name(vcloud_director.org_name)
|
8
|
+
|
9
|
+
tests("Compute::VcloudDirector | organization") do
|
10
|
+
tests("#name").returns(String) { org.name.class }
|
11
|
+
tests("#type").returns("application/vnd.vmware.vcloud.org+xml") { org.type }
|
12
|
+
end
|
13
|
+
|
14
|
+
tests("Compute::VcloudDirector | organization", ['get']) do
|
15
|
+
tests("#get_by_name").returns(org.name) { organizations.get_by_name(org.name).name }
|
16
|
+
tests("#get").returns(org.id) { organizations.get(org.id).id }
|
17
|
+
end
|
18
|
+
end
|
@@ -0,0 +1,56 @@
|
|
1
|
+
require File.expand_path(File.join(File.dirname(__FILE__), 'helper'))
|
2
|
+
|
3
|
+
Shindo.tests('Compute::VcloudDirector | tasks', ['vclouddirector']) do
|
4
|
+
|
5
|
+
@service = Fog::Compute::VcloudDirector.new()
|
6
|
+
|
7
|
+
if Fog.mocking?
|
8
|
+
# add a bunch of tasks
|
9
|
+
50.times do
|
10
|
+
task_id = @service.enqueue_task(
|
11
|
+
"Bogus Task",
|
12
|
+
'BogusTaskName',
|
13
|
+
{
|
14
|
+
:href => 'https://example.com/api/bogus/12345678-1234-1234-1234-123456789012',
|
15
|
+
:name => 'Bogus object',
|
16
|
+
:type => 'application/vnd.vmware.vcloud.bogus+xml'
|
17
|
+
}
|
18
|
+
)
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
tasks = organization.tasks
|
23
|
+
pending if tasks.empty?
|
24
|
+
task = tasks.first
|
25
|
+
|
26
|
+
tests('Compute::VcloudDirector | task') do
|
27
|
+
tests('#href').returns(String) { task.href.class }
|
28
|
+
tests('#type').returns('application/vnd.vmware.vcloud.task+xml') { task.type }
|
29
|
+
tests('#id').returns(String) { task.id.class }
|
30
|
+
tests('#name').returns(String) { task.name.class }
|
31
|
+
tests('#status').returns(String) { task.status.class }
|
32
|
+
tests('#end_time').returns(Time) { task.end_time.class }
|
33
|
+
tests('#expiry_time').returns(Time) { task.expiry_time.class }
|
34
|
+
tests('#operation').returns(String) { task.operation.class }
|
35
|
+
tests('#operation_name').returns(String) { task.operation_name.class }
|
36
|
+
end
|
37
|
+
|
38
|
+
tests('Compute::VcloudDirector | task', ['get']) do
|
39
|
+
tests('#get_by_name').returns(task.name) { tasks.get_by_name(task.name).name }
|
40
|
+
tests('#get').returns(task.id) { tasks.get(task.id).id }
|
41
|
+
end
|
42
|
+
|
43
|
+
# We should also be able to find tasks via the Query API
|
44
|
+
# NB: Query name == task.operation_name
|
45
|
+
tests("Compute::VcloudDirector | tasks", ['find_by_query']) do
|
46
|
+
tests('we can retrieve :name without lazy loading').returns(task.operation_name) do
|
47
|
+
query_task = tasks.find_by_query(:filter => "name==#{task.operation_name}").first
|
48
|
+
query_task.attributes[:name]
|
49
|
+
end
|
50
|
+
tests('by name').returns(task.operation_name) do
|
51
|
+
query_task = tasks.find_by_query(:filter => "name==#{task.operation_name}").first
|
52
|
+
query_task.name
|
53
|
+
end
|
54
|
+
end
|
55
|
+
|
56
|
+
end
|
@@ -0,0 +1,93 @@
|
|
1
|
+
require File.expand_path(File.join(File.dirname(__FILE__), 'helper'))
|
2
|
+
|
3
|
+
VAPP_NAME = "shindo07"
|
4
|
+
NETWORK_NAME = "DevOps - Dev Network Connection"
|
5
|
+
NETWORK_MODE = "POOL"
|
6
|
+
CATALOG_NAME = "Public VM Templates"
|
7
|
+
CATALOG_ITEM_NAME = "DEVWEB"
|
8
|
+
TAGS = { :company => "acme", :environment => "testing" }
|
9
|
+
|
10
|
+
Shindo.tests("Compute::VcloudDirector | vapp", ['vclouddirector', 'creation']) do
|
11
|
+
pending if Fog.mocking?
|
12
|
+
pending # FIXME: vCloud environment needs to be set up in advance
|
13
|
+
tests("#it creates a vApp from a catalog item").returns(true){ the_catalog_item.instantiate(VAPP_NAME, { :network_id => the_network.id, :network_name => NETWORK_NAME}) }
|
14
|
+
vapp = vapps.get_by_name(VAPP_NAME)
|
15
|
+
tests("#Finds the just created vApp").returns(VAPP_NAME) { vapp.name }
|
16
|
+
tests("#it has one vm").returns(1) { vapp.vms.size}
|
17
|
+
tests("Compute::VcloudDirector | vm", ['configuration']) do
|
18
|
+
vm = vapp.vms.first
|
19
|
+
tests("Compute::VcloudDirector | vm", ['network']) do
|
20
|
+
network = vm.network
|
21
|
+
network.network = NETWORK_NAME
|
22
|
+
network.is_connected = true
|
23
|
+
network.ip_address_allocation_mode = NETWORK_MODE
|
24
|
+
tests("save network changes").returns(true){ network.save }
|
25
|
+
network.reload
|
26
|
+
tests("#network").returns(NETWORK_NAME) { network.network }
|
27
|
+
tests("#is_connected").returns(true) { network.is_connected }
|
28
|
+
tests("#ip_address_allocation_mode").returns(NETWORK_MODE) { network.ip_address_allocation_mode }
|
29
|
+
end
|
30
|
+
|
31
|
+
tests("Compute::VcloudDirector | vm", ['customization']) do
|
32
|
+
customization = vm.customization
|
33
|
+
customization.script = 'this is the user data'
|
34
|
+
customization.enabled = true
|
35
|
+
tests("save customization changes").returns(true){ customization.save }
|
36
|
+
tests("#script").returns('this is the user data') { customization.script }
|
37
|
+
tests("#enabled").returns(true) { customization.enabled }
|
38
|
+
end
|
39
|
+
|
40
|
+
tests("Compute::VcloudDirector | vm", ['doble the disk size']) do
|
41
|
+
disk = vm.disks.get_by_name('Hard disk 1')
|
42
|
+
tests("#disk_size").returns(Fixnum) { disk.capacity.class}
|
43
|
+
new_size = disk.capacity * 2
|
44
|
+
disk.capacity = new_size
|
45
|
+
disk.reload
|
46
|
+
tests("#disk_size is now doubled").returns(new_size) { disk.capacity }
|
47
|
+
end
|
48
|
+
|
49
|
+
tests("Compute::VcloudDirector | vm", ['add a new disk']) do
|
50
|
+
tests("hard disk 2 doesn't exist").returns(nil) { vm.disks.get_by_name('Hard disk 2') }
|
51
|
+
tests("#create").returns(true) { vm.disks.create(1024) }
|
52
|
+
tests("hard disk 2 exists").returns(1024) { vm.disks.get_by_name('Hard disk 2').capacity }
|
53
|
+
tests("delete disk 2").returns(true) { vm.disks.get_by_name('Hard disk 2').destroy }
|
54
|
+
tests("hard disk 2 doesn't exist anymore").returns(nil) { vm.disks.get_by_name('Hard disk 2') }
|
55
|
+
end
|
56
|
+
|
57
|
+
tests("Compute::VcloudDirector | vm", ['doble the memory size']) do
|
58
|
+
tests("#memory").returns(Fixnum) { vm.memory.class}
|
59
|
+
new_size = vm.memory * 2
|
60
|
+
vm.memory = new_size
|
61
|
+
vm.reload
|
62
|
+
tests("#memory is now doubled").returns(new_size) { vm.memory }
|
63
|
+
end
|
64
|
+
|
65
|
+
tests("Compute::VcloudDirector | vm", ['doble the cpu size']) do
|
66
|
+
tests("#cpu").returns(Fixnum) { vm.cpu.class}
|
67
|
+
new_size = vm.cpu * 2
|
68
|
+
vm.cpu = new_size
|
69
|
+
vm.reload
|
70
|
+
tests("#memory is now doubled").returns(new_size) { vm.cpu }
|
71
|
+
end
|
72
|
+
|
73
|
+
tests("Compute::VcloudDirector | vm", ['tags']) do
|
74
|
+
TAGS.each_pair do |k,v|
|
75
|
+
tests('create tag').returns(true) {vm.tags.create(k, v)}
|
76
|
+
end
|
77
|
+
tests('there are two tags').returns(2){ vm.tags.size }
|
78
|
+
tests('#get_by_name').returns("acme"){ vm.tags.get_by_name('company').value }
|
79
|
+
tests('#get_by_name').returns("testing"){ vm.tags.get_by_name('environment').value }
|
80
|
+
tests('delete company').returns(true){ vm.tags.get_by_name('company').destroy }
|
81
|
+
tests("company doesn't exists anymore").returns(nil){ vm.tags.get_by_name('company') }
|
82
|
+
tests('there is only one tag').returns(1){ vm.tags.size }
|
83
|
+
end
|
84
|
+
|
85
|
+
tests("Compute::VcloudDirector | vm", ['power on']) do
|
86
|
+
tests('#vm is off').returns("off"){ vm.status }
|
87
|
+
tests('#power_on').returns(true){ vm.power_on }
|
88
|
+
vm.reload
|
89
|
+
tests('#vm is on').returns("on"){ vm.status }
|
90
|
+
end
|
91
|
+
|
92
|
+
end
|
93
|
+
end
|
@@ -0,0 +1,29 @@
|
|
1
|
+
require File.expand_path(File.join(File.dirname(__FILE__), 'helper'))
|
2
|
+
|
3
|
+
Shindo.tests("Compute::VcloudDirector | vapp_templates", ['vclouddirector', 'all']) do
|
4
|
+
|
5
|
+
# unless there is atleast one vapp we cannot run these tests
|
6
|
+
pending if vdc.vapp_templates.empty?
|
7
|
+
|
8
|
+
vapp_templates = vdc.vapp_templates
|
9
|
+
vapp = vapp_templates.first
|
10
|
+
|
11
|
+
tests("Compute::VcloudDirector | vapp_template") do
|
12
|
+
tests("#id").returns(String){ vapp.id.class }
|
13
|
+
tests("#name").returns(String){ vapp.name.class }
|
14
|
+
tests("#href").returns(String){ vapp.href.class }
|
15
|
+
tests("#type").returns("application/vnd.vmware.vcloud.vAppTemplate+xml"){ vapp.type }
|
16
|
+
end
|
17
|
+
|
18
|
+
tests("Compute::VcloudDirector | vapp_template vms") do
|
19
|
+
tests("#vms").returns(Fog::Compute::VcloudDirector::TemplateVms) { vapp.vms.class }
|
20
|
+
pending if Fog.mock?
|
21
|
+
vm = vapp.vms[0]
|
22
|
+
tests("#name").returns(String){ vm.name.class }
|
23
|
+
tests("#type").returns("application/vnd.vmware.vcloud.vm+xml"){ vm.type }
|
24
|
+
|
25
|
+
end
|
26
|
+
|
27
|
+
|
28
|
+
|
29
|
+
end
|
@@ -0,0 +1,61 @@
|
|
1
|
+
require File.expand_path(File.join(File.dirname(__FILE__), 'helper'))
|
2
|
+
|
3
|
+
Shindo.tests("Compute::VcloudDirector | vapps", ['vclouddirector', 'all']) do
|
4
|
+
|
5
|
+
# unless there is atleast one vapp we cannot run these tests
|
6
|
+
pending if vdc.vapps.empty?
|
7
|
+
|
8
|
+
vapps = vdc.vapps
|
9
|
+
vapp = vapps.first
|
10
|
+
|
11
|
+
tests("Compute::VcloudDirector | vapp") do
|
12
|
+
tests("#id").returns(String){ vapp.id.class }
|
13
|
+
tests("#name").returns(String){ vapp.name.class }
|
14
|
+
tests("#href").returns(String){ vapp.href.class }
|
15
|
+
tests("#type").returns("application/vnd.vmware.vcloud.vApp+xml"){ vapp.type }
|
16
|
+
end
|
17
|
+
|
18
|
+
tests("Compute::VcloudDirector | vapp", ['lazy load attrs']) do
|
19
|
+
vapp.lazy_load_attrs.each do |lazy_attr|
|
20
|
+
tests("##{lazy_attr} is not loaded yet").returns(NonLoaded) { vapp.attributes[lazy_attr] }
|
21
|
+
end
|
22
|
+
end
|
23
|
+
|
24
|
+
tests("Compute::VcloudDirector | vapp", ['load on demand']) do
|
25
|
+
tests("#description is not loaded yet").returns(NonLoaded) { vapp.attributes[:description] }
|
26
|
+
tests("#description is loaded on demand").returns(String) { vapp.description.class }
|
27
|
+
tests("#description is now loaded").returns(true) { vapp.attributes[:description] != NonLoaded }
|
28
|
+
end
|
29
|
+
|
30
|
+
tests("Compute::VcloudDirector | vapp", ['lazy load attrs']) do
|
31
|
+
vapp.lazy_load_attrs.each do |lazy_attr|
|
32
|
+
tests("##{lazy_attr} is now loaded").returns(true) { vapp.attributes[lazy_attr] != NonLoaded }
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
tests("Compute::VcloudDirector | vapp", ['get']) do
|
37
|
+
tests("#get_by_name").returns(vapp.name) { vapps.get_by_name(vapp.name).name }
|
38
|
+
tests("#get").returns(vapp.id) { vapps.get(vapp.id).id }
|
39
|
+
end
|
40
|
+
|
41
|
+
tests("Compute::VcloudDirector | vapp", ['custom_fields']) do
|
42
|
+
pending if Fog.mocking?
|
43
|
+
tests("#set_custom_field").returns('2'){ vapp.custom_fields[:custom_field] = '2' }
|
44
|
+
|
45
|
+
tests("#get_custom_field_by_name").returns('2') { vapp.custom_fields[:custom_field].value }
|
46
|
+
tests("#delete_custom_field").returns([]){ vapp.custom_fields.delete(:custom_field); vapp.custom_fields }
|
47
|
+
end
|
48
|
+
|
49
|
+
# We should also be able to find this vApp via Query API
|
50
|
+
tests("Compute::VcloudDirector | vapps", ['find_by_query']) do
|
51
|
+
tests('we can retrieve :name without lazy loading').returns(vapp.name) do
|
52
|
+
query_vapp = vapps.find_by_query(:filter => "name==#{vapp.name}").first
|
53
|
+
query_vapp.attributes[:name]
|
54
|
+
end
|
55
|
+
tests('we can retrieve name via model object returned by query').returns(vapp.name) do
|
56
|
+
query_vapp = vapps.find_by_query(:filter => "name==#{vapp.name}").first
|
57
|
+
query_vapp.name
|
58
|
+
end
|
59
|
+
end
|
60
|
+
|
61
|
+
end
|
@@ -0,0 +1,54 @@
|
|
1
|
+
require File.expand_path(File.join(File.dirname(__FILE__), 'helper'))
|
2
|
+
|
3
|
+
Shindo.tests("Compute::VcloudDirector | vdcs", ['vclouddirector', 'all']) do
|
4
|
+
tests("#There is one or more vdc").returns(true){ organization.vdcs.size >= 1 }
|
5
|
+
|
6
|
+
vdcs = organization.vdcs
|
7
|
+
vdc = vdcs.first
|
8
|
+
|
9
|
+
tests("Compute::VcloudDirector | vdc") do
|
10
|
+
tests("#id").returns(String) { vdc.id.class }
|
11
|
+
tests("#name").returns(String) { vdc.name.class }
|
12
|
+
tests("#href").returns(String) { vdc.href.class }
|
13
|
+
tests("#type").returns("application/vnd.vmware.vcloud.vdc+xml") { vdc.type }
|
14
|
+
end
|
15
|
+
|
16
|
+
tests("Compute::VcloudDirector | vdc", ['lazy load attrs']) do
|
17
|
+
vdc.lazy_load_attrs.each do |lazy_attr|
|
18
|
+
tests("##{lazy_attr} is not loaded yet").returns(NonLoaded) { vdc.attributes[lazy_attr] }
|
19
|
+
end
|
20
|
+
end
|
21
|
+
|
22
|
+
tests("Compute::VcloudDirector | vdc", ['load on demand']) do
|
23
|
+
tests("#description is not loaded yet").returns(NonLoaded) { vdc.attributes[:description] }
|
24
|
+
tests("#description is loaded on demand").returns(String) { vdc.description.class }
|
25
|
+
tests("#description is now loaded").returns(true) { vdc.attributes[:description] != NonLoaded }
|
26
|
+
end
|
27
|
+
|
28
|
+
tests("Compute::VcloudDirector | vdc", ['lazy load attrs']) do
|
29
|
+
lazy_attrs = vdc.lazy_load_attrs
|
30
|
+
lazy_attrs.delete(:storage_capacity) if vcloud_director.api_version.to_f >= 5.1
|
31
|
+
lazy_attrs.each do |lazy_attr|
|
32
|
+
tests("##{lazy_attr} is now loaded").returns(true) { vdc.attributes[lazy_attr] != NonLoaded }
|
33
|
+
end
|
34
|
+
end
|
35
|
+
|
36
|
+
tests("Compute::VcloudDirector | vdc", ['get']) do
|
37
|
+
tests("#get_by_name").returns(vdc.name) { vdcs.get_by_name(vdc.name).name }
|
38
|
+
tests("#get").returns(vdc.id) { vdcs.get(vdc.id).id }
|
39
|
+
end
|
40
|
+
|
41
|
+
pending if Fog.mocking?
|
42
|
+
|
43
|
+
# We should also be able to find this same vdc via Query API
|
44
|
+
tests("Compute::VcloudDirector | vdcs", ['find_by_query']) do
|
45
|
+
tests('we can retrieve :name without lazy loading').returns(vdc.name) do
|
46
|
+
query_vdc = vdcs.find_by_query(:filter => "name==#{vdc.name}").first
|
47
|
+
query_vdc.attributes[:name]
|
48
|
+
end
|
49
|
+
tests('by name').returns(vdc.name) do
|
50
|
+
query_vdc = vdcs.find_by_query(:filter => "name==#{vdc.name}").first
|
51
|
+
query_vdc.name
|
52
|
+
end
|
53
|
+
end
|
54
|
+
end
|