forked from synapsecns/sanguine
-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathsuite_test.go
123 lines (104 loc) · 3.1 KB
/
suite_test.go
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
package db_test
import (
"database/sql"
"fmt"
"os"
"sync"
"sync/atomic"
"testing"
"time"
"github.com/synapsecns/sanguine/core"
"github.com/synapsecns/sanguine/core/dbcommon"
"github.com/synapsecns/sanguine/core/metrics"
"github.com/synapsecns/sanguine/core/metrics/localmetrics"
"github.com/synapsecns/sanguine/core/testsuite"
"github.com/synapsecns/sanguine/services/scribe/db"
"github.com/synapsecns/sanguine/services/scribe/metadata"
"github.com/Flaque/filet"
. "github.com/stretchr/testify/assert"
"github.com/stretchr/testify/suite"
"github.com/synapsecns/sanguine/services/scribe/db/datastore/sql/mysql"
"github.com/synapsecns/sanguine/services/scribe/db/datastore/sql/sqlite"
"gorm.io/gorm/schema"
)
type DBSuite struct {
*testsuite.TestSuite
dbs []db.EventDB
logIndex atomic.Int64
scribeMetrics metrics.Handler
}
// NewEventDBSuite creates a new EventDBSuite.
func NewEventDBSuite(tb testing.TB) *DBSuite {
tb.Helper()
return &DBSuite{
TestSuite: testsuite.NewTestSuite(tb),
dbs: []db.EventDB{},
}
}
func (t *DBSuite) SetupTest() {
t.TestSuite.SetupTest()
t.logIndex.Store(0)
sqliteStore, err := sqlite.NewSqliteStore(t.GetTestContext(), filet.TmpDir(t.T(), ""), t.scribeMetrics, false)
Nil(t.T(), err)
t.dbs = []db.EventDB{sqliteStore}
t.setupMysqlDB()
}
func (t *DBSuite) SetupSuite() {
t.TestSuite.SetupSuite()
// don't use metrics on ci for integration tests
isCI := core.GetEnvBool("CI", false)
useMetrics := !isCI
metricsHandler := metrics.Null
if useMetrics {
localmetrics.SetupTestJaeger(t.GetSuiteContext(), t.T())
metricsHandler = metrics.Jaeger
}
var err error
t.scribeMetrics, err = metrics.NewByType(t.GetSuiteContext(), metadata.BuildInfo(), metricsHandler)
t.Require().Nil(err)
}
func (t *DBSuite) setupMysqlDB() {
// skip if mysql test disabled, this really only needs to be run in ci
// skip if mysql test disabled
if os.Getenv(dbcommon.EnableMysqlTestVar) == "" {
return
}
// sets up the conn string to the default database
connString := dbcommon.GetTestConnString()
// sets up the myqsl db
testDB, err := sql.Open("mysql", connString)
Nil(t.T(), err)
// close the db once the ocnnection is odne
defer func() {
Nil(t.T(), testDB.Close())
}()
// override the naming strategy to prevent tests from messing with each other.
// todo this should be solved via a proper teardown process or transactions.
mysql.NamingStrategy = schema.NamingStrategy{
TablePrefix: fmt.Sprintf("test%d_%d_", t.GetTestID(), time.Now().Unix()),
}
mysql.MaxIdleConns = 10
mysql.MaxOpenConns = 10
// create the sql store
mysqlStore, err := mysql.NewMysqlStore(t.GetTestContext(), connString, t.scribeMetrics, false)
Nil(t.T(), err)
// add the db
t.dbs = append(t.dbs, mysqlStore)
}
func (t *DBSuite) RunOnAllDBs(testFunc func(testDB db.EventDB)) {
t.T().Helper()
wg := sync.WaitGroup{}
for _, testDB := range t.dbs {
wg.Add(1)
// capture the value
go func(testDB db.EventDB) {
defer wg.Done()
testFunc(testDB)
}(testDB)
}
wg.Wait()
}
// TestDBSuite tests the db suite.
func TestEventDBSuite(t *testing.T) {
suite.Run(t, NewEventDBSuite(t))
}