Files
ubicloud/model/vm_pool.rb
Jeremy Evans 30247a3800 Include model annotations at the bottom of all model files
This makes it easier for developers new to the codebase to
easily get important information on the model's table in the
same file as the model code.

To ensure the model annotations stay accurate, run them on
test_up/test_down.  In CI, regenerate the annotations, and
check for no changes, similar to how the linters work.
2024-11-13 09:13:30 -08:00

42 lines
1.2 KiB
Ruby

# frozen_string_literal: true
require_relative "../model"
class VmPool < Sequel::Model
one_to_one :strand, key: :id
one_to_many :vms, key: :pool_id
include ResourceMethods
include SemaphoreMethods
semaphore :destroy
def pick_vm
DB.transaction do
# first lock the whole pool in the join table so that no other thread can
# pick a vm from this pool
vms_dataset.for_update.all
pick_vm_id_q = vms_dataset.left_join(:github_runner, vm_id: :id)
.where(Sequel[:github_runner][:vm_id] => nil, Sequel[:vm][:display_state] => "running")
.select(Sequel[:vm][:id])
Vm.where(id: pick_vm_id_q).first
end
end
end
# Table: vm_pool
# Columns:
# id | uuid | PRIMARY KEY
# size | integer | NOT NULL
# vm_size | text | NOT NULL
# boot_image | text | NOT NULL
# location | text | NOT NULL
# storage_size_gib | bigint | NOT NULL
# arch | arch | NOT NULL DEFAULT 'x64'::arch
# storage_encrypted | boolean | NOT NULL DEFAULT true
# storage_skip_sync | boolean | NOT NULL DEFAULT false
# Indexes:
# vm_pool_pkey | PRIMARY KEY btree (id)
# Referenced By:
# vm | vm_pool_id_fkey | (pool_id) REFERENCES vm_pool(id)