From 9936e465bfcb8bc18711647a2a2b5d8699956cb4 Mon Sep 17 00:00:00 2001 From: Aparna Karve Date: Fri, 5 Oct 2018 12:52:41 -0700 Subject: [PATCH 1/3] `validate_vms` POST body can contain `service_template_id` this is the edit ServiceTemplate record use case where we need to specify the id of the ServiceTemplate record --- app/controllers/api/transformation_mappings_controller.rb | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/app/controllers/api/transformation_mappings_controller.rb b/app/controllers/api/transformation_mappings_controller.rb index aeb78be92a..33183a1733 100644 --- a/app/controllers/api/transformation_mappings_controller.rb +++ b/app/controllers/api/transformation_mappings_controller.rb @@ -26,7 +26,7 @@ def edit_resource(type, id, data) def validate_vms_resource(type, id, data = {}) transformation_mapping = resource_search(id, type, collection_class(type)) - (transformation_mapping.search_vms_and_validate(data["import"]) || {}).tap do |res| + (transformation_mapping.search_vms_and_validate(data["import"], data["service_template_id"]) || {}).tap do |res| %w(valid_vms invalid_vms conflict_vms).each do |key| next unless res.key?(key) res[key].each do |entry| From 1f90bb4d419f18036f3738251f59e7a8ec514b7a Mon Sep 17 00:00:00 2001 From: Aparna Karve Date: Fri, 5 Oct 2018 12:54:18 -0700 Subject: [PATCH 2/3] tests for VM validity when ServiceTemplate record is edited --- spec/requests/transformation_mappings_spec.rb | 73 +++++++++++++++++++ 1 file changed, 73 insertions(+) diff --git a/spec/requests/transformation_mappings_spec.rb b/spec/requests/transformation_mappings_spec.rb index 83392305df..2edbf4d770 100644 --- a/spec/requests/transformation_mappings_spec.rb +++ b/spec/requests/transformation_mappings_spec.rb @@ -305,6 +305,79 @@ def href_slug(obj) expect(updated_mapping_destination).to match_array(reference_destination) expect(transformation_mapping.transformation_mapping_items.count).to eq(TransformationMappingItem.all.count) end + + context "can validate vms with csv data and service_template_id are specified" do + it "vm belongs to the service_template record" do + api_basic_authorize(action_identifier(:transformation_mappings, :validate_vms, :resource_actions, :post)) + source_ems = FactoryGirl.create(:ems_cluster) + destination_ems = FactoryGirl.create(:ems_cluster) + transformation_mapping = + FactoryGirl.create(:transformation_mapping, + :transformation_mapping_items => [TransformationMappingItem.new(:source => source_ems, :destination => destination_ems)]) + vm = FactoryGirl.create(:vm_vmware, :name => 'test_vm', :ems_cluster => source_ems, :ext_management_system => FactoryGirl.create(:ext_management_system)) + service_template = FactoryGirl.create(:service_template_transformation_plan) + + FactoryGirl.create( + :service_resource, + :resource => vm, + :service_template => service_template, + :status => "Active" + ) + + request = { + "action" => "validate_vms", + "import" => [ + {"name" => vm.name, "uid" => vm.uid_ems} + ], + "service_template_id" => service_template.id.to_s + } + post(api_transformation_mapping_url(nil, transformation_mapping), :params => request) + + expected = { + "valid" => [a_hash_including("name" => vm.name, "id" => vm.id.to_s, "status" => "ok", "reason" => "ok", "cluster" => source_ems.name)], + "invalid" => [], + "conflicted" => [] + } + expect(response).to have_http_status(:ok) + expect(response.parsed_body).to include(expected) + end + + it "vm does not belong to the service_template record" do + api_basic_authorize(action_identifier(:transformation_mappings, :validate_vms, :resource_actions, :post)) + source_ems = FactoryGirl.create(:ems_cluster) + destination_ems = FactoryGirl.create(:ems_cluster) + transformation_mapping = + FactoryGirl.create(:transformation_mapping, + :transformation_mapping_items => [TransformationMappingItem.new(:source => source_ems, :destination => destination_ems)]) + vm = FactoryGirl.create(:vm_vmware, :name => 'test_vm', :ems_cluster => source_ems, :ext_management_system => FactoryGirl.create(:ext_management_system)) + service_template = FactoryGirl.create(:service_template_transformation_plan) + service_template2 = FactoryGirl.create(:service_template_transformation_plan) + + FactoryGirl.create( + :service_resource, + :resource => vm, + :service_template => service_template, + :status => "Active" + ) + + request = { + "action" => "validate_vms", + "import" => [ + {"name" => vm.name, "uid" => vm.uid_ems} + ], + "service_template_id" => service_template2.id.to_s + } + post(api_transformation_mapping_url(nil, transformation_mapping), :params => request) + + expected = { + "valid" => [], + "invalid" => [a_hash_including("name" => "test_vm", "reason" => "in_other_plan")], + "conflicted" => [] + } + expect(response).to have_http_status(:ok) + expect(response.parsed_body).to include(expected) + end + end end end From 569bc98dcb58c66d646af85c11dbc267b29804ae Mon Sep 17 00:00:00 2001 From: Aparna Karve Date: Wed, 24 Oct 2018 11:56:11 -0700 Subject: [PATCH 3/3] improve test readability --- spec/requests/transformation_mappings_spec.rb | 24 +++++++++++-------- 1 file changed, 14 insertions(+), 10 deletions(-) diff --git a/spec/requests/transformation_mappings_spec.rb b/spec/requests/transformation_mappings_spec.rb index 2edbf4d770..cb74db24ec 100644 --- a/spec/requests/transformation_mappings_spec.rb +++ b/spec/requests/transformation_mappings_spec.rb @@ -309,12 +309,14 @@ def href_slug(obj) context "can validate vms with csv data and service_template_id are specified" do it "vm belongs to the service_template record" do api_basic_authorize(action_identifier(:transformation_mappings, :validate_vms, :resource_actions, :post)) - source_ems = FactoryGirl.create(:ems_cluster) - destination_ems = FactoryGirl.create(:ems_cluster) + ems_source = FactoryGirl.create(:ext_management_system) + ems_destination = FactoryGirl.create(:ext_management_system) + source_cluster = FactoryGirl.create(:ems_cluster, :ext_management_system => ems_source) + destination_cluster = FactoryGirl.create(:ems_cluster, :ext_management_system => ems_destination) transformation_mapping = FactoryGirl.create(:transformation_mapping, - :transformation_mapping_items => [TransformationMappingItem.new(:source => source_ems, :destination => destination_ems)]) - vm = FactoryGirl.create(:vm_vmware, :name => 'test_vm', :ems_cluster => source_ems, :ext_management_system => FactoryGirl.create(:ext_management_system)) + :transformation_mapping_items => [TransformationMappingItem.new(:source => source_cluster, :destination => destination_cluster)]) + vm = FactoryGirl.create(:vm_vmware, :ems_cluster => source_cluster, :ext_management_system => ems_source) service_template = FactoryGirl.create(:service_template_transformation_plan) FactoryGirl.create( @@ -334,7 +336,7 @@ def href_slug(obj) post(api_transformation_mapping_url(nil, transformation_mapping), :params => request) expected = { - "valid" => [a_hash_including("name" => vm.name, "id" => vm.id.to_s, "status" => "ok", "reason" => "ok", "cluster" => source_ems.name)], + "valid" => [a_hash_including("name" => vm.name, "id" => vm.id.to_s, "status" => "ok", "reason" => "ok", "cluster" => source_cluster.name)], "invalid" => [], "conflicted" => [] } @@ -344,12 +346,14 @@ def href_slug(obj) it "vm does not belong to the service_template record" do api_basic_authorize(action_identifier(:transformation_mappings, :validate_vms, :resource_actions, :post)) - source_ems = FactoryGirl.create(:ems_cluster) - destination_ems = FactoryGirl.create(:ems_cluster) + source_ems = FactoryGirl.create(:ext_management_system) + source_cluster = FactoryGirl.create(:ems_cluster, :ext_management_system => source_ems) + destination_ems = FactoryGirl.create(:ext_management_system) + destination_cluster = FactoryGirl.create(:ems_cluster, :ext_management_system => destination_ems) transformation_mapping = FactoryGirl.create(:transformation_mapping, - :transformation_mapping_items => [TransformationMappingItem.new(:source => source_ems, :destination => destination_ems)]) - vm = FactoryGirl.create(:vm_vmware, :name => 'test_vm', :ems_cluster => source_ems, :ext_management_system => FactoryGirl.create(:ext_management_system)) + :transformation_mapping_items => [TransformationMappingItem.new(:source => source_cluster, :destination => destination_cluster)]) + vm = FactoryGirl.create(:vm_vmware, :ems_cluster => source_cluster, :ext_management_system => source_ems) service_template = FactoryGirl.create(:service_template_transformation_plan) service_template2 = FactoryGirl.create(:service_template_transformation_plan) @@ -371,7 +375,7 @@ def href_slug(obj) expected = { "valid" => [], - "invalid" => [a_hash_including("name" => "test_vm", "reason" => "in_other_plan")], + "invalid" => [a_hash_including("name" => vm.name, "reason" => "in_other_plan")], "conflicted" => [] } expect(response).to have_http_status(:ok)