This commit is contained in:
Lev Kokotov
2022-02-10 11:08:57 -08:00
parent 86386c7377
commit 12011be3ec
2 changed files with 30 additions and 7 deletions

View File

@@ -15,28 +15,28 @@ jobs:
username: mydockerhub-user
password: $DOCKERHUB_PASSWORD
environment:
POSTGRES_USER: sharding_user
POSTGRES_DB: shard0
POSTGRES_USER: postgres
POSTGRES_DB: postgres
# Add steps to the job
# See: https://circleci.com/docs/2.0/configuration-reference/#steps
steps:
- checkout
- restore_cache:
key: cargo-lock-3-{{ checksum "Cargo.lock" }}
key: cargo-lock-2-{{ checksum "Cargo.lock" }}
- run:
name: "Install dependencies"
command: "sudo apt-get update && sudo apt-get install -y postgresql-contrib-12 postgresql-client-12"
- run:
name: "Build"
command: "cargo build --release"
command: "cargo build"
- run:
name: "Test"
command: "cargo test"
- run:
name: "Launch in background"
command: "./target/release/pgcat & pgbench -i -h 127.0.0.1 -p 6432 & pgbench -h 127.0.0.1 -p 6432 --protocol extended -t 100 -c 2"
name: "Test end-to-end"
command: "bash .circleci/run_tests.sh"
- save_cache:
key: cargo-lock-3-{{ checksum "Cargo.lock" }}
key: cargo-lock-2-{{ checksum "Cargo.lock" }}
paths:
- target
- ~/.cargo

23
.circleci/run_tests.sh Normal file
View File

@@ -0,0 +1,23 @@
#!/bin/bash
set -e
./target/debug/pgcat &
sleep 1
psql -f tests/sharding/query_routing_setup.sql
# Setup PgBench
pgbench -i -h 127.0.0.1 -p 6432
# Run it
pgbench -h 127.0.0.1 -p 6432 -t 500 -c 2
psql -h 127.0.0.1 -p 6432 -f tests/sharding/query_routing_test_insert.sql
psql -h 127.0.0.1 -p 6432 -f tests/sharding/query_routing_test_select.sql
# psql -f tests/sharding/query_routing_test_validate.sql
psql -h 127.0.0.1 -p 6432 -f tests/sharding/query_routing_test_primary_replica.sql