Skip to content

Commit

Permalink
Merge pull request #18960 from ZitaNemeckova/use_direct_cb
Browse files Browse the repository at this point in the history
When copying ServiceTemplate copy only direct_custom_buttons
  • Loading branch information
gmcculloug authored Jul 11, 2019
2 parents 6b64bb6 + bb47290 commit 36ce57a
Show file tree
Hide file tree
Showing 2 changed files with 24 additions and 6 deletions.
2 changes: 1 addition & 1 deletion app/models/service_template/copy.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ def template_copy(new_name = "Copy of " + name + Time.zone.now.to_s)
dup.tap do |template|
template.update_attributes(:name => new_name, :display => false)
service_resources.each { |service_resource| resource_copy(service_resource, template) }
custom_buttons.each { |custom_button| custom_button_copy(custom_button, template) }
direct_custom_buttons.each { |custom_button| custom_button_copy(custom_button, template) }
custom_button_sets.each { |custom_button_set| custom_button_set_copy(custom_button_set, template) }
end.save!
end
Expand Down
28 changes: 23 additions & 5 deletions spec/models/service_template_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -272,7 +272,8 @@
context "#template_copy" do
let(:service_template_ansible_tower) { FactoryBot.create(:service_template_ansible_tower) }
let(:service_template_orchestration) { FactoryBot.create(:service_template_orchestration) }
let(:custom_button) { FactoryBot.create(:custom_button, :applies_to_class => "Service") }
let(:custom_button) { FactoryBot.create(:custom_button, :applies_to => @st1) }
let(:custom_button_for_service) { FactoryBot.create(:custom_button, :applies_to_class => "Service") }
let(:custom_button_set) { FactoryBot.create(:custom_button_set, :owner => @st1) }
before do
@st1 = FactoryBot.create(:service_template)
Expand All @@ -288,15 +289,32 @@
expect(new_service_template.guid).not_to eq(@st1.guid)
end

it "with custom button" do
it "with custom button copy only direct_custom_buttons" do
custom_button
expect(@st1.custom_buttons.count).to eq(1)
custom_button_for_service
expect(@st1.custom_buttons.count).to eq(2)
number_of_service_templates = ServiceTemplate.count
@st1.template_copy("new_template")
expect(ServiceTemplate.count).to eq(2)
expect(ServiceTemplate.count).to eq(number_of_service_templates + 1)
new_service_template = ServiceTemplate.find_by(:name => "new_template")
expect(new_service_template.display).to be(false)
expect(new_service_template.guid).not_to eq(@st1.guid)
expect(new_service_template.custom_buttons.count).to eq(2)
expect(new_service_template.direct_custom_buttons.count).to eq(@st1.direct_custom_buttons.count)
end

it "with custom button it can copy a copy" do
custom_button
custom_button_for_service
expect(@st1.custom_buttons.count).to eq(2)
number_of_service_templates = ServiceTemplate.count
@st1.template_copy("new_template")
new_service_template = ServiceTemplate.find_by(:name => "new_template")
new_service_template.template_copy("Copy of a copy")
expect(ServiceTemplate.count).to eq(number_of_service_templates + 2)
copy_of_copy = ServiceTemplate.find_by(:name => "Copy of a copy")
expect(copy_of_copy.display).to be(false)
expect(copy_of_copy.guid).not_to eq(new_service_template.guid)
expect(copy_of_copy.direct_custom_buttons.count).to eq(new_service_template.direct_custom_buttons.count)
end

it "with custom button set" do
Expand Down

0 comments on commit 36ce57a

Please sign in to comment.