feat(tests): support pure-go sqlite driver

This tests the sqlite with/out CGO, updates the minimum tests go version
to 1.18, and adds the latest go version `^1` to the sqlite CI tests.

Related: https://github.com/go-gorm/sqlite/pull/161
This commit is contained in:
Ayman Bagabas 2023-07-05 19:29:15 -04:00
parent 2066138684
commit 326225c4bd
No known key found for this signature in database
GPG Key ID: C8D51D2157C919AC
6 changed files with 125 additions and 56 deletions

View File

@ -16,7 +16,7 @@ jobs:
sqlite: sqlite:
strategy: strategy:
matrix: matrix:
go: ['1.19', '1.18'] go: ['^1', '1.19', '1.18']
platform: [ubuntu-latest] # can not run in windows OS platform: [ubuntu-latest] # can not run in windows OS
runs-on: ${{ matrix.platform }} runs-on: ${{ matrix.platform }}

View File

@ -1,18 +1,49 @@
module gorm.io/gorm/tests module gorm.io/gorm/tests
go 1.16 go 1.18
replace gorm.io/driver/sqlite => github.com/aymanbagabas/sqlite v1.5.3-0.20230705235344-744e464ebb48
require ( require (
github.com/google/uuid v1.3.0 github.com/google/uuid v1.3.0
github.com/jackc/pgx/v5 v5.3.1 // indirect
github.com/jinzhu/now v1.1.5 github.com/jinzhu/now v1.1.5
github.com/lib/pq v1.10.8 github.com/lib/pq v1.10.9
github.com/mattn/go-sqlite3 v1.14.16 // indirect gorm.io/driver/mysql v1.5.1
gorm.io/driver/mysql v1.5.0 gorm.io/driver/postgres v1.5.2
gorm.io/driver/postgres v1.5.0 gorm.io/driver/sqlite v1.5.2
gorm.io/driver/sqlite v1.5.0
gorm.io/driver/sqlserver v1.5.1 gorm.io/driver/sqlserver v1.5.1
gorm.io/gorm v1.25.1 gorm.io/gorm v1.25.2-0.20230530020048-26663ab9bf55
)
require (
github.com/dustin/go-humanize v1.0.1 // indirect
github.com/go-sql-driver/mysql v1.7.1 // indirect
github.com/golang-sql/civil v0.0.0-20220223132316-b832511892a9 // indirect
github.com/golang-sql/sqlexp v0.1.0 // indirect
github.com/jackc/pgpassfile v1.0.0 // indirect
github.com/jackc/pgservicefile v0.0.0-20221227161230-091c0ba34f0a // indirect
github.com/jackc/pgx/v5 v5.4.1 // indirect
github.com/jinzhu/inflection v1.0.0 // indirect
github.com/kballard/go-shellquote v0.0.0-20180428030007-95032a82bc51 // indirect
github.com/mattn/go-isatty v0.0.19 // indirect
github.com/mattn/go-sqlite3 v1.14.17 // indirect
github.com/microsoft/go-mssqldb v1.3.0 // indirect
github.com/remyoudompheng/bigfft v0.0.0-20230129092748-24d4a6f8daec // indirect
golang.org/x/crypto v0.11.0 // indirect
golang.org/x/mod v0.12.0 // indirect
golang.org/x/sys v0.10.0 // indirect
golang.org/x/text v0.11.0 // indirect
golang.org/x/tools v0.11.0 // indirect
lukechampine.com/uint128 v1.3.0 // indirect
modernc.org/cc/v3 v3.41.0 // indirect
modernc.org/ccgo/v3 v3.16.14 // indirect
modernc.org/libc v1.24.1 // indirect
modernc.org/mathutil v1.6.0 // indirect
modernc.org/memory v1.6.0 // indirect
modernc.org/opt v0.1.3 // indirect
modernc.org/sqlite v1.23.1 // indirect
modernc.org/strutil v1.1.3 // indirect
modernc.org/token v1.1.0 // indirect
) )
replace gorm.io/gorm => ../ replace gorm.io/gorm => ../

View File

@ -6,8 +6,7 @@ if [[ $(pwd) == *"gorm/tests"* ]]; then
cd .. cd ..
fi fi
if [ -d tests ] if [ -d tests ]; then
then
cd tests cd tests
go get -u -t ./... go get -u -t ./...
go mod download go mod download
@ -17,15 +16,14 @@ fi
# SqlServer for Mac M1 # SqlServer for Mac M1
if [[ -z $GITHUB_ACTION ]]; then if [[ -z $GITHUB_ACTION ]]; then
if [ -d tests ] if [ -d tests ]; then
then
cd tests cd tests
if [[ $(uname -a) == *" arm64" ]]; then if [[ $(uname -a) == *" arm64" ]]; then
MSSQL_IMAGE=mcr.microsoft.com/azure-sql-edge docker-compose start || true MSSQL_IMAGE=mcr.microsoft.com/azure-sql-edge docker-compose start || true
go install github.com/microsoft/go-sqlcmd/cmd/sqlcmd@latest || true go install github.com/microsoft/go-sqlcmd/cmd/sqlcmd@latest || true
SQLCMDPASSWORD=LoremIpsum86 sqlcmd -U sa -S localhost:9930 -Q "IF DB_ID('gorm') IS NULL CREATE DATABASE gorm" > /dev/null || true SQLCMDPASSWORD=LoremIpsum86 sqlcmd -U sa -S localhost:9930 -Q "IF DB_ID('gorm') IS NULL CREATE DATABASE gorm" >/dev/null || true
SQLCMDPASSWORD=LoremIpsum86 sqlcmd -U sa -S localhost:9930 -Q "IF SUSER_ID (N'gorm') IS NULL CREATE LOGIN gorm WITH PASSWORD = 'LoremIpsum86';" > /dev/null || true SQLCMDPASSWORD=LoremIpsum86 sqlcmd -U sa -S localhost:9930 -Q "IF SUSER_ID (N'gorm') IS NULL CREATE LOGIN gorm WITH PASSWORD = 'LoremIpsum86';" >/dev/null || true
SQLCMDPASSWORD=LoremIpsum86 sqlcmd -U sa -S localhost:9930 -Q "IF USER_ID (N'gorm') IS NULL CREATE USER gorm FROM LOGIN gorm; ALTER SERVER ROLE sysadmin ADD MEMBER [gorm];" > /dev/null || true SQLCMDPASSWORD=LoremIpsum86 sqlcmd -U sa -S localhost:9930 -Q "IF USER_ID (N'gorm') IS NULL CREATE USER gorm FROM LOGIN gorm; ALTER SERVER ROLE sysadmin ADD MEMBER [gorm];" >/dev/null || true
else else
docker-compose start docker-compose start
fi fi
@ -33,29 +31,43 @@ if [[ -z $GITHUB_ACTION ]]; then
fi fi
fi fi
for dialect in "${dialects[@]}"; do
for dialect in "${dialects[@]}" ; do if [ "$GORM_DIALECT" = "" ] || [ "$GORM_DIALECT" = "${dialect}" ]; then
if [ "$GORM_DIALECT" = "" ] || [ "$GORM_DIALECT" = "${dialect}" ]
then
echo "testing ${dialect}..." echo "testing ${dialect}..."
if [ "$GORM_VERBOSE" = "" ] cmd="GORM_DIALECT=${dialect} go test"
then tags=("")
GORM_DIALECT=${dialect} go test -race -count=1 ./...
if [ -d tests ] if [ "$GORM_DIALECT" = "sqlite" ]; then
then # Test SQLite pure-go driver
tags+=("pure")
fi
for tag in "${tags[@]}"; do
echo "testing ${dialect} with tag '${tag}'"
if [ -n "$tag" ]; then
cmd="$cmd -tags ${tag}"
fi
cmd="$cmd -race -count=1 ./..."
if [ "$GORM_VERBOSE" = "" ]; then
eval $cmd
if [ -d tests ]; then
cd tests cd tests
GORM_DIALECT=${dialect} go test -race -count=1 ./... eval $cmd
cd .. cd ..
fi fi
else else
GORM_DIALECT=${dialect} go test -race -count=1 -v ./... eval $cmd
if [ -d tests ] if [ -d tests ]; then
then
cd tests cd tests
GORM_DIALECT=${dialect} go test -race -count=1 -v ./... eval $cmd
cd .. cd ..
fi fi
fi fi
done
fi fi
done done

13
tests/tests_cgo_test.go Normal file
View File

@ -0,0 +1,13 @@
//go:build cgo && !pure
// +build cgo,!pure
package tests_test
import (
"os"
"path/filepath"
)
var (
sqliteDSN = filepath.Join(os.TempDir(), "gorm.db")
)

13
tests/tests_pure_test.go Normal file
View File

@ -0,0 +1,13 @@
//go:build !cgo || (cgo && pure)
// +build !cgo cgo,pure
package tests_test
import (
"os"
"path/filepath"
)
var (
sqliteDSN = filepath.Join(os.TempDir(), "gorm.db?_pragma=busy_timeout(5000)&_pragma=foreign_keys(1)")
)

View File

@ -4,7 +4,6 @@ import (
"log" "log"
"math/rand" "math/rand"
"os" "os"
"path/filepath"
"time" "time"
"gorm.io/driver/mysql" "gorm.io/driver/mysql"
@ -45,6 +44,7 @@ func init() {
RunMigrations() RunMigrations()
if DB.Dialector.Name() == "sqlite" { if DB.Dialector.Name() == "sqlite" {
DB.Exec("PRAGMA foreign_keys = ON") DB.Exec("PRAGMA foreign_keys = ON")
DB.Exec("PRAGMA busy_timeout = 5000")
} }
} }
} }
@ -89,7 +89,7 @@ func OpenTestConnection(cfg *gorm.Config) (db *gorm.DB, err error) {
db, err = gorm.Open(mysql.Open(dbDSN), cfg) db, err = gorm.Open(mysql.Open(dbDSN), cfg)
default: default:
log.Println("testing sqlite3...") log.Println("testing sqlite3...")
db, err = gorm.Open(sqlite.Open(filepath.Join(os.TempDir(), "gorm.db")), cfg) db, err = gorm.Open(sqlite.Open(sqliteDSN), cfg)
} }
if err != nil { if err != nil {