Skip to content

Commit

Permalink
Merge pull request #17896 from d-m-u/adding_ci_mixin
Browse files Browse the repository at this point in the history
Add CiFeatureMixin
  • Loading branch information
bdunne authored Aug 27, 2018
2 parents 748d1fa + 15909ca commit 6c78ec8
Show file tree
Hide file tree
Showing 9 changed files with 64 additions and 61 deletions.
Original file line number Diff line number Diff line change
@@ -1,5 +1,6 @@
class ManageIQ::Providers::EmbeddedAnsible::AutomationManager::Job < ManageIQ::Providers::EmbeddedAutomationManager::OrchestrationStack
include ManageIQ::Providers::AnsibleTower::Shared::AutomationManager::Job
include CiFeatureMixin

require_nested :Status

Expand All @@ -19,4 +20,8 @@ def raw_stdout_via_worker(userid, format = 'txt')

super(userid, format, 'embedded_ansible')
end

def retireable?
false
end
end
5 changes: 5 additions & 0 deletions app/models/mixins/ci_feature_mixin.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,5 @@
module CiFeatureMixin
def retireable?
true
end
end
1 change: 1 addition & 0 deletions app/models/orchestration_stack.rb
Original file line number Diff line number Diff line change
Expand Up @@ -11,6 +11,7 @@ class OrchestrationStack < ApplicationRecord
include TenantIdentityMixin
include CustomActionsMixin
include SupportsFeatureMixin
include CiFeatureMixin

acts_as_miq_taggable

Expand Down
5 changes: 5 additions & 0 deletions app/models/service.rb
Original file line number Diff line number Diff line change
Expand Up @@ -66,6 +66,7 @@ class Service < ApplicationRecord
include ProcessTasksMixin
include TenancyMixin
include SupportsFeatureMixin
include CiFeatureMixin
include Metric::CiMixin

include_concern 'RetirementManagement'
Expand Down Expand Up @@ -214,6 +215,10 @@ def composite?
children.present?
end

def retireable?
type.present?
end

def atomic?
children.empty?
end
Expand Down
14 changes: 5 additions & 9 deletions app/models/service_retire_task.rb
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,11 @@ def after_request_task_create
def create_retire_subtasks(parent_service)
parent_service.direct_service_children.each { |child| create_retire_subtasks(child) }
parent_service.service_resources.collect do |svc_rsc|
next unless retireable?(svc_rsc, parent_service)
next unless svc_rsc.resource.try(:retireable?)
# TODO: the next line deals with the filtering for provisioning
# (https://github.com/ManageIQ/manageiq/blob/3921e87915b5a69937b9d4a70bb24ab71b97c165/app/models/service_template/filter.rb#L5)
# which should be extended to retirement as part of later work
# svc_rsc.resource_type != "ServiceTemplate" || self.class.include_service_template?(self, srr.id, parent_service)
nh = attributes.except("id", "created_on", "updated_on", "type", "state", "status", "message")
nh['options'] = options.except(:child_tasks)
# Initial Options[:dialog] to an empty hash so we do not pass down dialog values to child services tasks
Expand All @@ -45,14 +49,6 @@ def create_retire_subtasks(parent_service)
end.compact!
end

def retireable?(svc_rsc, parent_service)
srr = svc_rsc.resource
srr.present? &&
srr.respond_to?(:retire_now) &&
srr.type.present? &&
(svc_rsc.resource_type != "ServiceTemplate" || self.class.include_service_template?(self, srr.id, parent_service))
end

def create_task(svc_rsc, parent_service, nh)
new_task = (svc_rsc.resource.type.demodulize + "RetireTask").constantize.new(nh)
new_task.options.merge!(
Expand Down
1 change: 1 addition & 0 deletions app/models/service_template.rb
Original file line number Diff line number Diff line change
Expand Up @@ -41,6 +41,7 @@ class ServiceTemplate < ApplicationRecord
include NewWithTypeStiMixin
include TenancyMixin
include ArchivedMixin
include CiFeatureMixin
include_concern 'Filter'

belongs_to :tenant
Expand Down
1 change: 1 addition & 0 deletions app/models/vm.rb
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,7 @@ class Vm < VmOrTemplate

extend InterRegionApiMethodRelay
include CustomActionsMixin
include CiFeatureMixin

include_concern 'Operations'

Expand Down
41 changes: 41 additions & 0 deletions spec/models/mixins/ci_feature_mixin_spec.rb
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
describe CiFeatureMixin do
let(:service) { FactoryGirl.create(:service) }
describe "#retireable?" do
it "vm is retireable" do
FactoryGirl.create(:service_resource, :service => service, :resource => FactoryGirl.create(:vm))

expect(service.service_resources.first.resource.retireable?).to eq(true)
end

it "orchestration stack is retireable" do
FactoryGirl.create(:service_resource, :service => service, :resource => FactoryGirl.create(:orchestration_stack_amazon))

expect(service.service_resources.first.resource.retireable?).to eq(true)
end

it "job not retireable" do
FactoryGirl.create(:service_resource, :service => service, :resource => FactoryGirl.create(:embedded_ansible_job))

expect(service.service_resources.first.resource.retireable?).to eq(false)
end

context "service" do
context "with type" do
let(:service1) { FactoryGirl.create(:service_ansible_tower, :type => ServiceAnsibleTower) }
it "is retireable" do
FactoryGirl.create(:service_resource, :service => service, :resource => service1)

expect(service.service_resources.first.resource.retireable?).to eq(true)
end
end

context "without type" do
it "is not retireable" do
FactoryGirl.create(:service_resource, :service => service, :resource => FactoryGirl.create(:service))

expect(service.service_resources.first.resource.retireable?).to eq(false)
end
end
end
end
end
52 changes: 0 additions & 52 deletions spec/models/service_retire_task_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -97,58 +97,6 @@
end
end

describe "#retireable?" do
include_context "service_bundle"

context "without srr" do
it "is not retireable" do
service.service_resources << FactoryGirl.create(:service_resource, :resource_type => "VmOrTemplate", :service_id => service_c1.id, :resource_id => nil)
@service_retire_task = FactoryGirl.create(:service_retire_task, :source => service, :miq_request_task_id => nil, :miq_request_id => @miq_request.id, :options => {:src_ids => [service.id] })

expect(@service_retire_task.retireable?(service.service_resources.first, service)).to be(false)
end
end

context "srr nonresponsive to retireable?" do
it "is not retireable" do
service.service_resources << FactoryGirl.create(:service_resource, :resource_type => "VmOrTemplate", :service_id => service_c1.id, :resource_id => User.first.id)
@service_retire_task = FactoryGirl.create(:service_retire_task, :source => service, :miq_request_task_id => nil, :miq_request_id => @miq_request.id, :options => {:src_ids => [service.id] })

expect(@service_retire_task.retireable?(service.service_resources.first, service)).to be(false)
end
end

context "srr sans type" do
let(:vm_without_type) { FactoryGirl.create(:vm, :type => nil) }
it "is not retireable" do
service.service_resources << FactoryGirl.create(:service_resource, :resource_type => "VmOrTemplate", :service_id => service_c1.id, :resource_id => vm_without_type.id)
@service_retire_task = FactoryGirl.create(:service_retire_task, :source => service, :miq_request_task_id => nil, :miq_request_id => @miq_request.id, :options => {:src_ids => [service.id] })

expect(@service_retire_task.retireable?(service.service_resources.first, service)).to be(false)
end
end

context "svc_rsc resource_type is not ServiceTemplate" do
it "is not retireable" do
service.service_resources << FactoryGirl.create(:service_resource, :resource_type => "VmOrTemplate", :service_id => service_c1.id, :resource_id => service_c1.id)
@service_retire_task = FactoryGirl.create(:service_retire_task, :source => service, :miq_request_task_id => nil, :miq_request_id => @miq_request.id, :options => {:src_ids => [service.id] })
allow(@service_retire_task.class).to receive(:include_service_template?).with(@service_retire_task, service.service_resources.first.id, service).and_return(true)

expect(@service_retire_task.retireable?(service.service_resources.first, service)).to be(false)
end
end

context "class includes service template" do
it "is not retireable" do
service.service_resources << FactoryGirl.create(:service_resource, :resource_type => "ServiceTemplate", :service_id => service_c1.id, :resource_id => vm.id)
@service_retire_task = FactoryGirl.create(:service_retire_task, :source => service, :miq_request_task_id => nil, :miq_request_id => @miq_request.id, :options => {:src_ids => [service.id] })
allow(@service_retire_task.class).to receive(:include_service_template?).with(@service_retire_task, service.service_resources.first.id, service).and_return(false)

expect(@service_retire_task.retireable?(service.service_resources.first, service)).to be(false)
end
end
end

describe "deliver_to_automate" do
before do
allow(MiqServer).to receive(:my_zone).and_return(Zone.seed.name)
Expand Down

0 comments on commit 6c78ec8

Please sign in to comment.