Skip to content

Commit

Permalink
Add archive/unarchive actions to ServiceTemplate
Browse files Browse the repository at this point in the history
  • Loading branch information
agrare committed Jun 4, 2018
1 parent a457408 commit b332cf7
Show file tree
Hide file tree
Showing 4 changed files with 143 additions and 1 deletion.
16 changes: 16 additions & 0 deletions app/controllers/api/service_templates_controller.rb
Original file line number Diff line number Diff line change
Expand Up @@ -29,6 +29,22 @@ def order_resource(_type, id, data)
order_service_template(id, data)
end

def archive_resource(type, id, _data)
service_template = resource_search(id, type, collection_class(type))
service_template.archive!
action_result(true, "Archived Service Template")
rescue => err
action_result(false, "Could not archive Service Template - #{err}")
end

def unarchive_resource(type, id, _data)
service_template = resource_search(id, type, collection_class(type))
service_template.unarchive!
action_result(true, "Unarchived Service Template")
rescue => err
action_result(false, "Could not unarchive Service Template - #{err}")
end

private

def set_additional_attributes
Expand Down
8 changes: 8 additions & 0 deletions config/api.yml
Original file line number Diff line number Diff line change
Expand Up @@ -2775,6 +2775,10 @@
:identifier: atomic_catalogitem_new
- :name: order
:identifier: svc_catalog_provision
- :name: archive
:identifier: svc_catalog_archive
- :name: unarchive
:identifier: svc_catalog_unarchive
:subcollection_actions:
:post:
- :name: edit
Expand All @@ -2800,6 +2804,10 @@
:identifier: catalogitem_delete
- :name: order
:identifier: svc_catalog_provision
- :name: archive
:identifier: svc_catalog_archive
- :name: unarchive
:identifier: svc_catalog_unarchive
:options:
- :validate_action
:delete:
Expand Down
2 changes: 1 addition & 1 deletion spec/requests/custom_actions_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -162,7 +162,7 @@ def expect_result_to_have_custom_actions_hash

expect_result_to_have_keys(%w(id href actions))
action_specs = response.parsed_body["actions"]
expect(action_specs.size).to eq(3)
expect(action_specs.size).to eq(4)
expect(action_specs.first["name"]).to eq("edit")
end

Expand Down
118 changes: 118 additions & 0 deletions spec/requests/service_templates_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -548,4 +548,122 @@
end
end
end

describe "Service Templates archive" do
let(:service_template) { FactoryGirl.create(:service_template, :with_provision_resource_action_and_dialog) }

it "is forbidden without appropriate role" do
api_basic_authorize

post(api_service_template_url(nil, service_template), :params => { :action => "archive" })

expect(response).to have_http_status(:forbidden)
end

it "can be archived as a resource action" do
api_basic_authorize action_identifier(:service_templates, :archive, :resource_actions, :post)

post(api_service_template_url(nil, service_template), :params => { :action => "archive" })

expect(response).to have_http_status(:ok)
expect(response.parsed_body).to include("message" => "Archived Service Template")
end

it "can be archived as an action on the collection" do
api_basic_authorize action_identifier(:service_templates, :archive, :resource_actions, :post)

post(api_service_templates_url, :params => { :action => "archive", :resources => [{:href => api_service_template_url(nil, service_template)}] })

expected = {
"results" => [a_hash_including("message" => "Archived Service Template")]
}
expect(response).to have_http_status(:ok)
expect(response.parsed_body).to include(expected)
end

it "shows the action" do
api_basic_authorize(action_identifier(:service_templates, :archive, :resource_actions, :post),
action_identifier(:service_templates, :read, :resource_actions, :get))

get(api_service_template_url(nil, service_template))

actions = response.parsed_body["actions"].collect { |action| action["name"] }
expect(actions).to include("archive")
end

it "can archive multiple service templates" do
service_template2 = FactoryGirl.create(:service_template, :with_provision_resource_action_and_dialog)
api_basic_authorize action_identifier(:service_templates, :archive, :resource_actions, :post)

post(api_service_templates_url, :params => { :action => "archive", :resources =>
[{:href => api_service_template_url(nil, service_template)},
{:href => api_service_template_url(nil, service_template2)}]})

expected = {
"results" => [a_hash_including("message" => "Archived Service Template"),
a_hash_including("message" => "Archived Service Template")]
}
expect(response).to have_http_status(:ok)
expect(response.parsed_body).to include(expected)
end
end

describe "Service Templates unarchive" do
let(:service_template) { FactoryGirl.create(:service_template, :with_provision_resource_action_and_dialog) }

it "is forbidden without appropriate role" do
api_basic_authorize

post(api_service_template_url(nil, service_template), :params => { :action => "unarchive" })

expect(response).to have_http_status(:forbidden)
end

it "can be unarchived as a resource action" do
api_basic_authorize action_identifier(:service_templates, :unarchive, :resource_actions, :post)

post(api_service_template_url(nil, service_template), :params => { :action => "unarchive" })

expect(response).to have_http_status(:ok)
expect(response.parsed_body).to include("message" => "Unarchived Service Template")
end

it "can be unarchived as an action on the collection" do
api_basic_authorize action_identifier(:service_templates, :unarchive, :resource_actions, :post)

post(api_service_templates_url, :params => { :action => "unarchive", :resources => [{:href => api_service_template_url(nil, service_template)}] })

expected = {
"results" => [a_hash_including("message" => "Unarchived Service Template")]
}
expect(response).to have_http_status(:ok)
expect(response.parsed_body).to include(expected)
end

it "shows the action" do
api_basic_authorize(action_identifier(:service_templates, :unarchive, :resource_actions, :post),
action_identifier(:service_templates, :read, :resource_actions, :get))

get(api_service_template_url(nil, service_template))

actions = response.parsed_body["actions"].collect { |action| action["name"] }
expect(actions).to include("unarchive")
end

it "can unarchive multiple service templates" do
service_template2 = FactoryGirl.create(:service_template, :with_provision_resource_action_and_dialog)
api_basic_authorize action_identifier(:service_templates, :unarchive, :resource_actions, :post)

post(api_service_templates_url, :params => { :action => "unarchive", :resources =>
[{:href => api_service_template_url(nil, service_template)},
{:href => api_service_template_url(nil, service_template2)}]})

expected = {
"results" => [a_hash_including("message" => "Unarchived Service Template"),
a_hash_including("message" => "Unarchived Service Template")]
}
expect(response).to have_http_status(:ok)
expect(response.parsed_body).to include(expected)
end
end
end

0 comments on commit b332cf7

Please sign in to comment.