读完之后,我想我需要这个 TestMain(m *testing.M)
构造来设置我的数据库。然而,在运行测试时,db总是为零。我该怎么解决这个问题?
var db *sql.DB
func TestMain(m *testing.M) {
db, err := sql.Open("mysql", os.Getenv("DSN"))
if err != nil {
log.Fatal("error opening database")
}
defer db.Close()
log.Printf("here testing with %v", db)
code := m.Run()
log.Printf("finished test")
os.Exit(code)
}
func Test_getRole(t *testing.T) {
if db == nil {
t.Fatalf("db is nil")
}
}
输出为:
2018/05/02 19:10:14 here testing with &{{bugzilla:SECRET@tcp(example.com:3306)/bugzilla?multiStatements=true 0x7aba40} 0 {0 0} [] map[] 0 0 0xc42001e180 0xc4200740c0 false map[] map[] 0 0 0 <nil> 0x4e9850}
--- FAIL: Test_getRole (0.00s)
main_test.go:32: db is nil
https://github.com/unee-t/processinvitations/blob/testfail/main_test.go#l43 是指向完整代码段的链接。
1条答案
按热度按时间wfauudbj1#
你的台词
db, err := sql.Open("mysql", os.Getenv("DSN"))
创建局部变量db(函数testmain的局部变量)。而是使用: