// Copyright 2017 The Gitea Authors. All rights reserved. // Use of this source code is governed by a MIT-style // license that can be found in the LICENSE file. package integrations import ( "bytes" "database/sql" "fmt" "io" "log" "net/http" "os" "testing" "code.gitea.io/gitea/models" "code.gitea.io/gitea/modules/setting" "code.gitea.io/gitea/routers" "code.gitea.io/gitea/routers/routes" "github.com/Unknwon/com" "github.com/stretchr/testify/assert" "gopkg.in/macaron.v1" "gopkg.in/testfixtures.v2" ) var mac *macaron.Macaron func TestMain(m *testing.M) { initIntegrationTest() mac = routes.NewMacaron() routes.RegisterRoutes(mac) var helper testfixtures.Helper if setting.UseMySQL { helper = &testfixtures.MySQL{} } else if setting.UsePostgreSQL { helper = &testfixtures.PostgreSQL{} } else if setting.UseSQLite3 { helper = &testfixtures.SQLite{} } else { fmt.Println("Unsupported RDBMS for integration tests") os.Exit(1) } err := models.InitFixtures( helper, "models/fixtures/", ) if err != nil { fmt.Printf("Error initializing test database: %v\n", err) os.Exit(1) } os.Exit(m.Run()) } func initIntegrationTest() { if setting.CustomConf = os.Getenv("GITEA_CONF"); setting.CustomConf == "" { fmt.Println("Environment variable $GITEA_CONF not set") os.Exit(1) } setting.NewContext() models.LoadConfigs() switch { case setting.UseMySQL: db, err := sql.Open("mysql", fmt.Sprintf("%s:%s@tcp(%s)/", models.DbCfg.User, models.DbCfg.Passwd, models.DbCfg.Host)) defer db.Close() if err != nil { log.Fatalf("sql.Open: %v", err) } if _, err = db.Exec("CREATE DATABASE IF NOT EXISTS testgitea"); err != nil { log.Fatalf("db.Exec: %v", err) } case setting.UsePostgreSQL: db, err := sql.Open("postgres", fmt.Sprintf("postgres://%s:%s@%s/?sslmode=%s", models.DbCfg.User, models.DbCfg.Passwd, models.DbCfg.Host, models.DbCfg.SSLMode)) defer db.Close() if err != nil { log.Fatalf("sql.Open: %v", err) } rows, err := db.Query(fmt.Sprintf("SELECT 1 FROM pg_database WHERE datname = '%s'", models.DbCfg.Name)) if err != nil { log.Fatalf("db.Query: %v", err) } if rows.Next() { break // database already exists } if _, err = db.Exec("CREATE DATABASE testgitea"); err != nil { log.Fatalf("db.Exec: %v", err) } } routers.GlobalInit() } func prepareTestEnv(t *testing.T) { assert.NoError(t, models.LoadFixtures()) assert.NoError(t, os.RemoveAll("integrations/gitea-integration")) assert.NoError(t, com.CopyDir("integrations/gitea-integration-meta", "integrations/gitea-integration")) } type TestResponseWriter struct { HeaderCode int Writer io.Writer } func (w *TestResponseWriter) Header() http.Header { return make(map[string][]string) } func (w *TestResponseWriter) Write(b []byte) (int, error) { return w.Writer.Write(b) } func (w *TestResponseWriter) WriteHeader(n int) { w.HeaderCode = n } type TestResponse struct { HeaderCode int Body []byte } func MakeRequest(req *http.Request) *TestResponse { buffer := bytes.NewBuffer(nil) respWriter := &TestResponseWriter{ Writer: buffer, } mac.ServeHTTP(respWriter, req) return &TestResponse{ HeaderCode: respWriter.HeaderCode, Body: buffer.Bytes(), } }