From 50ef77f228721bc6876664797d6b7789b9c96603 Mon Sep 17 00:00:00 2001 From: Jaden Hums Date: Mon, 8 Sep 2025 20:38:54 -0700 Subject: [PATCH 1/6] github action for testing --- .github/workflows/tests.yml | 71 +++++++++++++++++++++++++++++++++++++ Dockerfile | 2 +- 2 files changed, 72 insertions(+), 1 deletion(-) create mode 100644 .github/workflows/tests.yml diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml new file mode 100644 index 0000000..e44a73e --- /dev/null +++ b/.github/workflows/tests.yml @@ -0,0 +1,71 @@ +name: Test Suite + +on: + pull_request: + branches: [ main ] + push: + branches: [ main ] + +jobs: + test: + runs-on: ubuntu-latest + + services: + postgres: + image: postgres:17 + env: + POSTGRES_DB: echobase_test + POSTGRES_USER: user + POSTGRES_PASSWORD: pass + ports: + - 5433:5432 + options: >- + --health-cmd pg_isready + --health-interval 10s + --health-timeout 5s + --health-retries 5 + + steps: + - name: Checkout code + uses: actions/checkout@v4 + + - name: Set up Go + uses: actions/setup-go@v5 + with: + go-version: '1.24' + cache: true + + - name: Install sql-migrate + run: go install github.com/rubenv/sql-migrate/sql-migrate@latest + + - name: Wait for PostgreSQL + run: | + until pg_isready -h localhost -p 5433 -U user; do + echo "Waiting for PostgreSQL..." + sleep 2 + done + + - name: Run database migrations + run: sql-migrate up -env=test + env: + DATABASE_URL: postgresql://user:pass@localhost:5433/echobase_test?sslmode=disable + + - name: Download dependencies + run: go mod download + + - name: Run tests with coverage + run: go test -v -race -coverprofile=coverage.out ./... + env: + EB_DSN: postgresql://user:pass@localhost:5433/echobase_test?sslmode=disable + + - name: Check test coverage threshold + run: | + go tool cover -func=coverage.out | grep total | awk '{ + coverage = substr($3, 1, length($3)-1) + if (coverage < 80) { + print "Coverage " coverage "% is below 80% threshold" + exit 1 + } else { + print "Coverage " coverage "% meets threshold" + } + }' diff --git a/Dockerfile b/Dockerfile index ddae9b9..bee92d5 100644 --- a/Dockerfile +++ b/Dockerfile @@ -1,4 +1,4 @@ -FROM golang:1 AS builder +FROM golang:1.25 AS builder WORKDIR /go/src/app COPY go.mod go.sum ./ From e00b325c9db68c8e1e42c6bf53a19a78dc20aa36 Mon Sep 17 00:00:00 2001 From: Jaden Hums Date: Mon, 8 Sep 2025 20:43:53 -0700 Subject: [PATCH 2/6] testing --- .github/workflows/tests.yml | 14 +------------- 1 file changed, 1 insertion(+), 13 deletions(-) diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index e44a73e..efd66d5 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -54,18 +54,6 @@ jobs: run: go mod download - name: Run tests with coverage - run: go test -v -race -coverprofile=coverage.out ./... + run: go test -v -race ./... env: EB_DSN: postgresql://user:pass@localhost:5433/echobase_test?sslmode=disable - - - name: Check test coverage threshold - run: | - go tool cover -func=coverage.out | grep total | awk '{ - coverage = substr($3, 1, length($3)-1) - if (coverage < 80) { - print "Coverage " coverage "% is below 80% threshold" - exit 1 - } else { - print "Coverage " coverage "% meets threshold" - } - }' From 67757e70be742481464fe1a2c9a8d419fb7b84c8 Mon Sep 17 00:00:00 2001 From: Jaden Hums Date: Mon, 8 Sep 2025 20:46:31 -0700 Subject: [PATCH 3/6] update descriptions --- .github/workflows/tests.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index efd66d5..b63204a 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -53,7 +53,7 @@ jobs: - name: Download dependencies run: go mod download - - name: Run tests with coverage + - name: Run tests run: go test -v -race ./... env: EB_DSN: postgresql://user:pass@localhost:5433/echobase_test?sslmode=disable From 88c133b18d8ae6489c67c33b50e52ba62774432c Mon Sep 17 00:00:00 2001 From: Jaden Hums Date: Mon, 8 Sep 2025 20:48:26 -0700 Subject: [PATCH 4/6] edit port --- .github/workflows/tests.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index b63204a..51ba004 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -18,7 +18,7 @@ jobs: POSTGRES_USER: user POSTGRES_PASSWORD: pass ports: - - 5433:5432 + - 5432:5432 options: >- --health-cmd pg_isready --health-interval 10s @@ -40,7 +40,7 @@ jobs: - name: Wait for PostgreSQL run: | - until pg_isready -h localhost -p 5433 -U user; do + until pg_isready -h localhost -p 5432 -U user; do echo "Waiting for PostgreSQL..." sleep 2 done From b98b7560a69b1bab7ee8ae88b5b0f92ba9dce58c Mon Sep 17 00:00:00 2001 From: Jaden Hums Date: Mon, 8 Sep 2025 20:49:59 -0700 Subject: [PATCH 5/6] change port --- .github/workflows/tests.yml | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index 51ba004..b63204a 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -18,7 +18,7 @@ jobs: POSTGRES_USER: user POSTGRES_PASSWORD: pass ports: - - 5432:5432 + - 5433:5432 options: >- --health-cmd pg_isready --health-interval 10s @@ -40,7 +40,7 @@ jobs: - name: Wait for PostgreSQL run: | - until pg_isready -h localhost -p 5432 -U user; do + until pg_isready -h localhost -p 5433 -U user; do echo "Waiting for PostgreSQL..." sleep 2 done From fca4ca9f6b7a9b6edd702ab762abfb3376fc8e1a Mon Sep 17 00:00:00 2001 From: Jaden Hums Date: Mon, 8 Sep 2025 20:52:55 -0700 Subject: [PATCH 6/6] update go version --- .github/workflows/tests.yml | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/.github/workflows/tests.yml b/.github/workflows/tests.yml index b63204a..3da9530 100644 --- a/.github/workflows/tests.yml +++ b/.github/workflows/tests.yml @@ -32,7 +32,7 @@ jobs: - name: Set up Go uses: actions/setup-go@v5 with: - go-version: '1.24' + go-version: '1.25' cache: true - name: Install sql-migrate