Files
ubicloud/prog/test/ha_postgres_resource.rb
Furkan Sahin 12dbeb57a1 Update location references with foreign key in the controlplane
We are basically updating the location references everywhere with a
location id and adding the location relationship to the models to be
able to fetch location names when needed.
This also makes the LocationNameConverter model obsolete, so we are
removing it.

Use model id as value for Sequel::Model in resource creation form

Use id of the location as preselected value in Postgres update form
2025-03-23 15:48:19 +01:00

149 lines
4.3 KiB
Ruby

# frozen_string_literal: true
require_relative "../../lib/util"
class Prog::Test::HaPostgresResource < Prog::Test::Base
semaphore :destroy
def self.assemble
postgres_test_project = Project.create(name: "Postgres-HA-Test-Project")
Project[Config.postgres_service_project_id] ||
Project.create(name: "Postgres-Service-Project") { _1.id = Config.postgres_service_project_id }
Project[Config.minio_service_project_id] ||
Project.create(name: "Minio-Service-Project") { _1.id = Config.minio_service_project_id }
frame = {
"postgres_test_project_id" => postgres_test_project.id,
"failover_wait_started" => false
}
Strand.create_with_id(
prog: "Test::HaPostgresResource",
label: "start",
stack: [frame]
)
end
label def start
st = Prog::Minio::MinioClusterNexus.assemble(Config.postgres_service_project_id,
"postgres-minio-test-0", Location::HETZNER_FSN1_ID, "admin", 32, 1, 1, 1, "standard-2")
update_stack({"minio_cluster_id" => st.id})
hop_wait_minio_cluster
end
label def wait_minio_cluster
if minio_cluster.strand.label == "wait"
hop_create_postgres_resource
else
nap 10
end
end
label def create_postgres_resource
st = Prog::Postgres::PostgresResourceNexus.assemble(
project_id: frame["postgres_test_project_id"],
location_id: Location::HETZNER_FSN1_ID,
name: "postgres-test-ha",
target_vm_size: "standard-2",
target_storage_size_gib: 128,
ha_type: "async"
)
update_stack({"postgres_resource_id" => st.id})
hop_wait_postgres_resource
end
label def wait_postgres_resource
server_count = postgres_resource.servers.count
nap 10 if server_count != postgres_resource.target_server_count || postgres_resource.servers.filter { _1.strand.label != "wait" }.any?
hop_test_postgres
end
label def test_postgres
unless representative_server.run_query(test_queries_sql) == "DROP TABLE\nCREATE TABLE\nINSERT 0 10\n4159.90\n415.99\n4.1"
update_stack({"fail_message" => "Failed to run test queries"})
hop_destroy_postgres
end
hop_trigger_failover
end
label def trigger_failover
primary = postgres_resource.servers.find { _1.timeline_access == "push" }
update_stack({"primary_ubid" => primary.ubid})
primary.vm.sshable.cmd("echo -e '\nfoobar' | sudo tee -a /etc/postgresql/#{postgres_resource.version}/main/conf.d/001-service.conf")
# Get postgres pid and send SIGKILL
primary.vm.sshable.cmd("ps aux | grep -v grep | grep '/usr/lib/postgresql/#{postgres_resource.version}/bin/postgres' | awk '{print $2}' | xargs sudo kill -9")
hop_wait_failover
end
label def wait_failover
# Wait 3 minutes for the failover to finish.
failover_wait_started = frame["failover_wait_started"]
update_stack({"failover_wait_started" => true})
nap 180 unless failover_wait_started
hop_test_postgres_after_failover
end
label def test_postgres_after_failover
unless representative_server.run_query(read_queries_sql) == "4159.90\n415.99\n4.1"
update_stack({"fail_message" => "Failed to run read queries after failover"})
hop_destroy_postgres
end
unless representative_server.run_query(test_queries_sql) == "DROP TABLE\nCREATE TABLE\nINSERT 0 10\n4159.90\n415.99\n4.1"
update_stack({"fail_message" => "Failed to run write queries after failover"})
end
hop_destroy_postgres
end
label def destroy_postgres
postgres_resource.incr_destroy
minio_cluster.incr_destroy
hop_destroy
end
label def destroy
postgres_test_project.destroy
fail_test(frame["fail_message"]) if frame["fail_message"]
pop "Postgres tests are finished!"
end
label def failed
nap 15
end
def postgres_test_project
@postgres_test_project ||= Project[frame["postgres_test_project_id"]]
end
def postgres_resource
@postgres_resource ||= PostgresResource[frame["postgres_resource_id"]]
end
def representative_server
@representative_server ||= postgres_resource.representative_server
end
def minio_cluster
@minio_cluster ||= MinioCluster[frame["minio_cluster_id"]]
end
def test_queries_sql
File.read("./prog/test/testdata/order_analytics_queries.sql")
end
def read_queries_sql
File.read("./prog/test/testdata/order_analytics_read_queries.sql")
end
end