diff --git a/app/models/resource_action_workflow.rb b/app/models/resource_action_workflow.rb index 7db6f704d84b..afa343aa0fd2 100644 --- a/app/models/resource_action_workflow.rb +++ b/app/models/resource_action_workflow.rb @@ -104,7 +104,7 @@ def load_dialog(resource_action, values, options) dialog.target_resource = @target if options[:display_view_only] dialog.init_fields_with_values_for_request(values) - elsif options[:provision_workflow] + elsif options[:provision_workflow] || options[:init_defaults] dialog.initialize_value_context(values) dialog.load_values_into_fields(values, false) elsif options[:refresh] || options[:submit_workflow] diff --git a/app/models/service_template.rb b/app/models/service_template.rb index 38068341c645..6878bc451a24 100644 --- a/app/models/service_template.rb +++ b/app/models/service_template.rb @@ -427,7 +427,8 @@ def provision_workflow(user, dialog_options = nil, request_options = {}) :target => self, :initiator => request_options[:initiator], :submit_workflow => request_options[:submit_workflow], - :provision_workflow => request_options[:provision_workflow] + :provision_workflow => request_options[:provision_workflow], + :init_defaults => request_options[:init_defaults] } ResourceActionWorkflow.new(dialog_options, user, provision_action, ra_options).tap do |wf| diff --git a/config/settings.yml b/config/settings.yml index ccec2474aeea..fa74eaad118c 100644 --- a/config/settings.yml +++ b/config/settings.yml @@ -979,6 +979,7 @@ :name: :maindb: ExtManagementSystem :container_deployment_wizard: false + :run_automate_methods_on_service_catalog_api_submit: false :prototype: :queue_type: miq_queue :artemis: diff --git a/spec/models/resource_action_workflow_spec.rb b/spec/models/resource_action_workflow_spec.rb index 7df222987cf9..f81b1afdaff7 100644 --- a/spec/models/resource_action_workflow_spec.rb +++ b/spec/models/resource_action_workflow_spec.rb @@ -228,6 +228,16 @@ end end + context "when the options set init_defaults to true" do + let(:options) { {:init_defaults => true} } + + it "calls init_fields_with_values_for_request" do + expect(dialog).to receive(:initialize_value_context).with(values).ordered + expect(dialog).to receive(:load_values_into_fields).with(values, false).ordered + ResourceActionWorkflow.new(values, nil, resource_action, options) + end + end + context "when the options are set to a refresh request" do let(:options) { {:refresh => true} } diff --git a/spec/models/service_template_spec.rb b/spec/models/service_template_spec.rb index 2190e32cd448..e76e8f35ee6b 100644 --- a/spec/models/service_template_spec.rb +++ b/spec/models/service_template_spec.rb @@ -882,6 +882,29 @@ context "#provision_request" do let(:arg1) { {'ordered_by' => 'fred'} } + context "with init_defaults" do + let(:arg2) { {:init_defaults => true} } + + it "provisions a service template without errors" do + expect(resource_action_workflow).to receive(:validate_dialog).and_return([]) + expect(resource_action_workflow).to receive(:make_request).and_return(miq_request) + expect(resource_action_workflow).to receive(:request_options=).with( + :init_defaults => true, :provision_workflow => true + ) + + expect(service_template.provision_request(user, arg1, arg2)).to eq(miq_request) + end + + it "provisions a service template with errors" do + expect(resource_action_workflow).to receive(:validate_dialog).and_return(%w(Error1 Error2)) + expect(resource_action_workflow).to receive(:request_options=).with( + :init_defaults => true, :provision_workflow => true + ) + + expect { service_template.provision_request(user, arg1, arg2) }.to raise_error(RuntimeError) + end + end + context "with submit_workflow" do let(:arg2) { {:initiator => 'control', :submit_workflow => true} }