Skip to content

Commit

Permalink
Update circle.ci
Browse files Browse the repository at this point in the history
  • Loading branch information
go-jet committed Dec 19, 2021
1 parent 972fc1d commit b92af7c
Show file tree
Hide file tree
Showing 9 changed files with 127 additions and 126 deletions.
168 changes: 73 additions & 95 deletions .circleci/config.yml
Original file line number Diff line number Diff line change
@@ -1,28 +1,37 @@
# Golang CircleCI 2.0 configuration file
#
# Check https://circleci.com/docs/2.0/language-go/ for more details
version: 2
version: 2.1
orbs:
codecov: codecov/[email protected]
jobs:
build-postgres-and-mysql:
build_and_tests:
docker:
# specify the version
- image: circleci/golang:1.13

- image: circleci/postgres:10.8-alpine
environment: # environment variables for primary container
- image: circleci/golang:1.16
- image: circleci/postgres:12
environment:
POSTGRES_USER: jet
POSTGRES_PASSWORD: jet
POSTGRES_DB: jetdb
PGPORT: 50901

- image: circleci/mysql:8.0.16
command: [--default-authentication-plugin=mysql_native_password]
- image: circleci/mysql:8.0.27
command: [ --default-authentication-plugin=mysql_native_password ]
environment:
MYSQL_ROOT_PASSWORD: jet
MYSQL_DATABASE: dvds
MYSQL_USER: jet
MYSQL_PASSWORD: jet
MYSQL_TCP_PORT: 50902

working_directory: /go/src/github.com/go-jet/jet
- image: circleci/mariadb:10.3
command: [ '--default-authentication-plugin=mysql_native_password', '--port=50903' ]
environment:
MYSQL_ROOT_PASSWORD: jet
MYSQL_DATABASE: dvds
MYSQL_USER: jet
MYSQL_PASSWORD: jet

environment: # environment variables for the build itself
TEST_RESULTS: /tmp/test-results # path to where test results will be saved
Expand All @@ -32,25 +41,22 @@ jobs:

- run:
name: Submodule init
command: |
git submodule init
git submodule update
cd ./tests/testdata && git fetch && git checkout master
command: cd tests && make checkout-testdata

- restore_cache: # restores saved cache if no changes are detected since last run
keys:
- go-mod-v4-{{ checksum "go.sum" }}

- run:
name: Install dependencies
command: |
cd /go/src/github.com/go-jet/jet
go get github.com/jstemmer/go-junit-report
go build -o /home/circleci/.local/bin/jet ./cmd/jet/
name: Install jet generator
command: cd tests && make install-jet-gen

- run:
name: Waiting for Postgres to be ready
command: |
for i in `seq 1 10`;
do
nc -z localhost 5432 && echo Success && exit 0
nc -z localhost 50901 && echo Success && exit 0
echo -n .
sleep 1
done
Expand All @@ -61,109 +67,81 @@ jobs:
command: |
for i in `seq 1 10`;
do
nc -z 127.0.0.1 3306 && echo Success && exit 0
nc -z 127.0.0.1 50902 && echo Success && exit 0
echo -n .
sleep 1
done
echo Failed waiting for MySQL && exit 1
- run:
name: Waiting for MariaDB to be ready
command: |
for i in `seq 1 10`;
do
nc -z 127.0.0.1 50903 && echo Success && exit 0
echo -n .
sleep 1
done
echo Failed waiting for MySQL && exit 1
- run:
name: Install MySQL CLI;
command: |
sudo apt-get --allow-releaseinfo-change update && sudo apt-get install default-mysql-client
- run:
name: Create MySQL user and databases
name: Create MySQL/MariaDB user and test databases
command: |
mysql -h 127.0.0.1 -u root -pjet -e "grant all privileges on *.* to 'jet'@'%';"
mysql -h 127.0.0.1 -u root -pjet -e "set global sql_mode = 'STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';"
mysql -h 127.0.0.1 -u jet -pjet -e "create database test_sample"
mysql -h 127.0.0.1 -u jet -pjet -e "create database dvds2"
mysql -h 127.0.0.1 -P 50902 -u root -pjet -e "grant all privileges on *.* to 'jet'@'%';"
mysql -h 127.0.0.1 -P 50902 -u root -pjet -e "set global sql_mode = 'STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';"
mysql -h 127.0.0.1 -P 50902 -u jet -pjet -e "create database test_sample"
mysql -h 127.0.0.1 -P 50902 -u jet -pjet -e "create database dvds2"
mysql -h 127.0.0.1 -P 50903 -u root -pjet -e "grant all privileges on *.* to 'jet'@'%';"
mysql -h 127.0.0.1 -P 50903 -u root -pjet -e "set global sql_mode = 'STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';"
mysql -h 127.0.0.1 -P 50903 -u jet -pjet -e "create database test_sample"
mysql -h 127.0.0.1 -P 50903 -u jet -pjet -e "create database dvds2"
- run:
name: Init Postgres database
command: |
cd tests
go run ./init/init.go -testsuite all
cd ..
name: Init databases
command: |
cd tests
go run ./init/init.go -testsuite all
# to create test results report
- run:
name: Install go-junit-report
command: go install github.com/jstemmer/go-junit-report@latest

- run: mkdir -p $TEST_RESULTS

# this will run all tests and exclude test files from code coverage report
- run: MY_SQL_SOURCE=MySQL go test -v ./... -covermode=atomic -coverpkg=github.com/go-jet/jet/postgres/...,github.com/go-jet/jet/mysql/...,github.com/go-jet/jet/sqlite/...,github.com/go-jet/jet/qrm/...,github.com/go-jet/jet/generator/...,github.com/go-jet/jet/internal/... -coverprofile=cover.out 2>&1 | go-junit-report > $TEST_RESULTS/results.xml
- run: |
go test -v ./... \
-covermode=atomic \
-coverpkg=github.com/go-jet/jet/v2/postgres/...,github.com/go-jet/jet/v2/mysql/...,github.com/go-jet/jet/v2/sqlite/...,github.com/go-jet/jet/v2/qrm/...,github.com/go-jet/jet/v2/generator/...,github.com/go-jet/jet/v2/internal/... \
-coverprofile=cover.out 2>&1 | go-junit-report > $TEST_RESULTS/results.xml
- run:
name: Upload code coverage
command: bash <(curl -s https://codecov.io/bash)
# run mariaDB tests. No need to collect coverage, because coverage is already included with mysql tests
- run: MY_SQL_SOURCE=MariaDB go test -v ./tests/mysql/

- save_cache:
key: go-mod-v4-{{ checksum "go.sum" }}
paths:
- "/go/pkg/mod"

- codecov/upload:
file: cover.out

- store_artifacts: # Upload test summary for display in Artifacts: https://circleci.com/docs/2.0/artifacts/
path: /tmp/test-results
destination: raw-test-output

- store_test_results: # Upload test results for display in Test Summary: https://circleci.com/docs/2.0/collect-test-data/
path: /tmp/test-results
build-mariadb:
docker:
# specify the version
- image: circleci/golang:1.13

- image: circleci/mariadb:10.3
command: [--default-authentication-plugin=mysql_native_password]
environment:
MYSQL_ROOT_PASSWORD: jet
MYSQL_DATABASE: dvds
MYSQL_USER: jet
MYSQL_PASSWORD: jet

working_directory: /go/src/github.com/go-jet/jet

environment: # environment variables for the build itself
TEST_RESULTS: /tmp/test-results # path to where test results will be saved

steps:
- checkout

- run:
name: Submodule init
command: |
git submodule init
git submodule update
cd ./tests/testdata && git fetch && git checkout master
- run:
name: Install dependencies
command: |
cd /go/src/github.com/go-jet/jet
go get github.com/jstemmer/go-junit-report
go build -o /home/circleci/.local/bin/jet ./cmd/jet/
- run:
name: Install MySQL CLI;
command: |
sudo apt-get --allow-releaseinfo-change update && sudo apt-get install default-mysql-client
- run:
name: Init MariaDB database
command: |
mysql -h 127.0.0.1 -u root -pjet -e "grant all privileges on *.* to 'jet'@'%';"
mysql -h 127.0.0.1 -u root -pjet -e "set global sql_mode = 'STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION';"
mysql -h 127.0.0.1 -u jet -pjet -e "create database test_sample"
mysql -h 127.0.0.1 -u jet -pjet -e "create database dvds2"
- run:
name: Init MariaDB database
command: |
cd tests
go run ./init/init.go -testsuite MariaDB
cd ..
- run:
name: Run MariaDB tests
command: |
MY_SQL_SOURCE=MariaDB go test -v ./tests/mysql/

workflows:
version: 2
build_and_test:
jobs:
- build-postgres-and-mysql
- build-mariadb
- build_and_tests
3 changes: 2 additions & 1 deletion .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -20,4 +20,5 @@ gen
.gentestdata
.tests/testdata/
.gen
.docker
.docker
.env
20 changes: 16 additions & 4 deletions tests/Makefile
Original file line number Diff line number Diff line change
Expand Up @@ -14,14 +14,28 @@ checkout-testdata:
docker-compose-up:
docker-compose up

init-all:
go run ./init/init.go -testsuite all

init-postgres:
go run ./init/init.go -testsuite postgres

init-mysql:
go run ./init/init.go -testsuite mysql

init-mariadb:
go run ./init/init.go -testsuite mariadb

init-sqlite:
go run ./init/init.go -testsuite sqlite

# jet-gen will call generator on each of the test databases to generate sql builder and model files need to run the tests.
jet-gen: install-jet-gen jet-gen-pg jet-gen-mysql jet-gen-mariadb jet-gen-sqlite
jet-gen-all: install-jet-gen jet-gen-postgres jet-gen-mysql jet-gen-mariadb jet-gen-sqlite

install-jet-gen:
go build -o ${GOPATH}/bin/jet ../cmd/jet/

jet-gen-pg:
jet-gen-postgres:
jet -dsn=postgres://jet:jet@localhost:50901/jetdb?sslmode=disable -schema=dvds -path=./.gentestdata/
jet -dsn=postgres://jet:jet@localhost:50901/jetdb?sslmode=disable -schema=chinook -path=./.gentestdata/
jet -dsn=postgres://jet:jet@localhost:50901/jetdb?sslmode=disable -schema=chinook2 -path=./.gentestdata/
Expand All @@ -44,7 +58,5 @@ jet-gen-sqlite:


# docker-compose-cleanup will stop and remove test containers, volumes, and images.
# If temp .docker/ folder is still not empty, use 'sudo rm -rf .docker' to remove it.
cleanup:
docker-compose down --volumes
$(info INFO: If the ./.docker folder is still not empty, use 'sudo rm -rf .docker/' to remove it.)
5 changes: 2 additions & 3 deletions tests/Readme.md
Original file line number Diff line number Diff line change
Expand Up @@ -14,8 +14,8 @@ To simplify the process there is a Makefile with a list of helper commands.
# Note that on the first run this command might take a couple of minutes.
make setup

# When databases are ready, we can generate sql builder and model types needed to compile the tests.
make jet-gen
# When databases are ready, we can generate sql builder and model types for each of the test databases
make jet-gen-all
```

Then we can run the tests the usual way:
Expand All @@ -26,5 +26,4 @@ go test -v ./...
To removes test containers, volumes, and images:
```shell
make cleanup
# If temp ./.docker folder is still not empty, use 'sudo rm -rf .docker' to remove it.
```
4 changes: 2 additions & 2 deletions tests/dbconfig/dbconfig.go
Original file line number Diff line number Diff line change
Expand Up @@ -19,12 +19,12 @@ var PostgresConnectString = fmt.Sprintf("host=%s port=%d user=%s password=%s dbn

// MySQL test database connection parameters
const (
MySqLHost = "localhost"
MySqLHost = "127.0.0.1"
MySQLPort = 50902
MySQLUser = "jet"
MySQLPassword = "jet"

MariaDBHost = "localhost"
MariaDBHost = "127.0.0.1"
MariaDBPort = 50903
MariaDBUser = "jet"
MariaDBPassword = "jet"
Expand Down
3 changes: 0 additions & 3 deletions tests/docker-compose.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -11,7 +11,6 @@ services:
- '50901:5432'
volumes:
- ./testdata/init/postgres:/docker-entrypoint-initdb.d
- ./.docker/postgres-data:/var/lib/postgresql/data

mysql:
image: mysql:8.0.27
Expand All @@ -25,7 +24,6 @@ services:
- '50902:3306'
volumes:
- ./testdata/init/mysql:/docker-entrypoint-initdb.d
- ./.docker/mysql-data:/var/lib/mysql

mariadb:
image: mariadb:10.3.32
Expand All @@ -39,4 +37,3 @@ services:
- '50903:3306'
volumes:
- ./testdata/init/mysql:/docker-entrypoint-initdb.d
- ./.docker/mariadb-data:/var/lib/mysql
Loading

0 comments on commit b92af7c

Please sign in to comment.