2017-04-25 12:54:51 +05:30
|
|
|
// 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"
|
2017-04-30 12:00:12 +05:30
|
|
|
"database/sql"
|
2017-04-25 12:54:51 +05:30
|
|
|
"fmt"
|
|
|
|
"io"
|
2017-04-30 12:00:12 +05:30
|
|
|
"log"
|
2017-04-25 12:54:51 +05:30
|
|
|
"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"
|
|
|
|
|
2017-04-28 18:53:28 +05:30
|
|
|
"github.com/Unknwon/com"
|
|
|
|
"github.com/stretchr/testify/assert"
|
2017-04-25 12:54:51 +05:30
|
|
|
"gopkg.in/macaron.v1"
|
|
|
|
"gopkg.in/testfixtures.v2"
|
|
|
|
)
|
|
|
|
|
|
|
|
var mac *macaron.Macaron
|
|
|
|
|
|
|
|
func TestMain(m *testing.M) {
|
2017-04-30 12:00:12 +05:30
|
|
|
initIntegrationTest()
|
2017-04-25 12:54:51 +05:30
|
|
|
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,
|
2017-04-28 18:53:28 +05:30
|
|
|
"models/fixtures/",
|
2017-04-25 12:54:51 +05:30
|
|
|
)
|
|
|
|
if err != nil {
|
|
|
|
fmt.Printf("Error initializing test database: %v\n", err)
|
|
|
|
os.Exit(1)
|
|
|
|
}
|
|
|
|
os.Exit(m.Run())
|
|
|
|
}
|
|
|
|
|
2017-04-30 12:00:12 +05:30
|
|
|
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()
|
|
|
|
}
|
|
|
|
|
2017-04-28 18:53:28 +05:30
|
|
|
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"))
|
|
|
|
}
|
|
|
|
|
2017-04-25 12:54:51 +05:30
|
|
|
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(),
|
|
|
|
}
|
|
|
|
}
|