Skip to content

Commit

Permalink
Move resource_groups relationship to VmOrTemplate model.
Browse files Browse the repository at this point in the history
Modified vms method, added templates method.

Added resource_group specs.

Updated ResourceGroup specs to reflect model changes.

Rely on default scope for vms method.

Remove tests that were only testing Rails.

Update templates association and specs.
  • Loading branch information
djberg96 authored and Daniel Berger committed May 24, 2017
1 parent ad8edb6 commit 00d2614
Show file tree
Hide file tree
Showing 5 changed files with 41 additions and 5 deletions.
3 changes: 1 addition & 2 deletions app/models/manageiq/providers/cloud_manager/vm.rb
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ class ManageIQ::Providers::CloudManager::Vm < ::Vm
belongs_to :flavor
belongs_to :orchestration_stack
belongs_to :cloud_tenant
belongs_to :resource_group

has_many :network_ports, :as => :device
has_many :cloud_subnets, -> { distinct }, :through => :network_ports
Expand Down Expand Up @@ -127,7 +126,7 @@ def resize_queue(userid, new_flavor)
def resize(new_flavor_id)
raise ArgumentError, _("new_flavor_id cannot be nil") if new_flavor_id.nil?
new_flavor = Flavor.find(new_flavor_id)
raise ArgumentError, _("flavor cannot be found") if new_flavor.nil?
raise ArgumentError, _("flavor cannot be found") if new_flavor.nil?
raw_resize(new_flavor)
end

Expand Down
8 changes: 7 additions & 1 deletion app/models/resource_group.rb
Original file line number Diff line number Diff line change
@@ -1,3 +1,9 @@
class ResourceGroup < ApplicationRecord
has_many :vms
alias_attribute :images, :templates

has_many :vm_or_templates

# Rely on default scopes to get expected information
has_many :vms, :class_name => 'Vm'
has_many :templates, :class_name => 'MiqTemplate'
end
2 changes: 2 additions & 0 deletions app/models/vm_or_template.rb
Original file line number Diff line number Diff line change
Expand Up @@ -79,6 +79,8 @@ class VmOrTemplate < ApplicationRecord
has_many :guest_applications, :dependent => :destroy
has_many :patches, :dependent => :destroy

belongs_to :resource_group

# Accounts - Users and Groups
has_many :accounts, :dependent => :destroy
has_many :users, -> { where(:accttype => 'user') }, :class_name => "Account"
Expand Down
20 changes: 18 additions & 2 deletions spec/models/resource_group_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -23,8 +23,24 @@
end

context "relationships" do
it "has many vms" do
expect(resource_group).to respond_to(:vms)
before do
@vm = FactoryGirl.create(:vm_google, :template => false, :resource_group => resource_group)
@template = FactoryGirl.create(:template_google, :template => true, :resource_group => resource_group)
end

it "returns the expected results for vms" do
expect(resource_group.vms).to include(@vm)
expect(resource_group.vms).to_not include(@template)
end

it "returns the expected results for templates" do
expect(resource_group.templates).to include(@template)
expect(resource_group.templates).to_not include(@vm)
end

it "returns the expected results for vm_or_templates" do
expect(resource_group.vm_or_templates).to include(@template)
expect(resource_group.vm_or_templates).to include(@vm)
end
end
end
13 changes: 13 additions & 0 deletions spec/models/vm_or_template_spec.rb
Original file line number Diff line number Diff line change
Expand Up @@ -335,6 +335,19 @@
end
end

context "#resource_group" do
before do
@resource_group = FactoryGirl.create(:resource_group)
@vm_with_rg = FactoryGirl.create(:vm_amazon, :resource_group => @resource_group)
@vm_without_rg = FactoryGirl.create(:vm_amazon)
end

it "has a has_one association with resource groups" do
expect(@vm_with_rg.resource_group).to eql(@resource_group)
expect(@vm_without_rg.resource_group).to be_nil
end
end

context "#scan_profile_categories" do
before do
@vm = FactoryGirl.create(:vm_vmware)
Expand Down

0 comments on commit 00d2614

Please sign in to comment.