Files
ubicloud/spec/model/vm_pool_spec.rb
Burak Velioglu ee586fc6cb Lock only the selected row instead of whole pool
While allocating a vm from a pool, whole vms of the
related pool were locked. This was causing unnecessary
lock and increasing the run time of the query. So, locking
the selected row instead to allow concurrent requests to
continue with the next unlocked tuple.
2024-12-20 11:18:51 +03:00

45 lines
1.2 KiB
Ruby

# frozen_string_literal: true
require_relative "spec_helper"
RSpec.describe VmPool do
let(:pool) {
described_class.create_with_id(
size: 3,
vm_size: "standard-2",
boot_image: "img",
location: "loc",
storage_size_gib: 86
)
}
describe ".pick_vm nil case" do
it "returns nil if there are no vms" do
expect(pool.pick_vm).to be_nil
end
it "returns nil if there are no vms in running state" do
create_vm(pool_id: pool.id, display_state: "creating")
expect(pool.pick_vm).to be_nil
end
end
describe ".pick_vm" do
let(:prj) {
Project.create_with_id(name: "default").tap { _1.associate_with_project(_1) }
}
let(:vm) {
vm = create_vm(pool_id: pool.id, display_state: "running")
vm.associate_with_project(prj)
vm
}
it "returns the vm if there is one in running state" do
locking_vms = class_double(Vm)
expect(pool).to receive(:vms_dataset).and_return(locking_vms)
expect(locking_vms).to receive_message_chain(:where, :exclude, :for_update, :skip_locked, :first).and_return(vm) # rubocop:disable RSpec/MessageChain
expect(pool.pick_vm).to eq(vm)
end
end
end