Files
ubicloud/spec/model/github_runner_spec.rb
Enes Cakir e1286b290a Add create_vm_host spec helper
The VmHost model requires a Sshable record due to database constraints.
Currently, we're creating VmHost models with dummy Sshable data across
multiple test locations, leading to code duplication.

Additionally, we're creating VmHost instances using `VmHost.create(...)
{ _1.id = Sshable.create.id }`, which results in VmHost having a Sshable
UBID instead of its own UBID. While this doesn't break any test, it's
conceptually incorrect and should be fixed.
2025-02-03 08:34:22 +03:00

55 lines
2.1 KiB
Ruby

# frozen_string_literal: true
require_relative "spec_helper"
RSpec.describe GithubRunner do
subject(:github_runner) {
ins = GithubInstallation.create_with_id(installation_id: 123, name: "test-installation", type: "User")
vm = create_vm(vm_host: create_vm_host, boot_image: "github-ubuntu-2204")
Sshable.create { _1.id = vm.id }
described_class.create_with_id(repository_name: "test-repo", label: "ubicloud", vm_id: vm.id, installation_id: ins.id)
}
it "can log duration when it's from a vm pool" do
pool = VmPool.create_with_id(size: 1, vm_size: "standard-2", location: "hetzner-fsn1", boot_image: "github-ubuntu-2204", storage_size_gib: 86)
github_runner.vm.update(pool_id: pool.id)
expect(Clog).to receive(:emit).with("runner_tested").and_call_original
github_runner.log_duration("runner_tested", 10)
end
it "can log duration without a vm" do
github_runner.update(vm_id: nil)
expect(Clog).to receive(:emit).with("runner_tested").and_call_original
github_runner.log_duration("runner_tested", 10)
end
it "provisions a spare runner" do
expect(Prog::Vm::GithubRunner).to receive(:assemble)
.with(github_runner.installation, repository_name: github_runner.repository_name, label: github_runner.label)
.and_return(instance_double(Strand, subject: instance_double(described_class)))
github_runner.provision_spare_runner
end
it "initiates a new health monitor session" do
expect(github_runner.vm.sshable).to receive(:start_fresh_session)
github_runner.init_health_monitor_session
end
it "checks pulse" do
session = {
ssh_session: instance_double(Net::SSH::Connection::Session)
}
pulse = {
reading: "up",
reading_rpt: 5,
reading_chg: Time.now - 30
}
expect(session[:ssh_session]).to receive(:exec!).with("awk '/MemAvailable/ {print $2}' /proc/meminfo").and_return("123\n")
github_runner.check_pulse(session: session, previous_pulse: pulse)
expect(session[:ssh_session]).to receive(:exec!).and_raise Sshable::SshError
github_runner.check_pulse(session: session, previous_pulse: pulse)
end
end