Я тестирование HTTP пользовательского конечной точки для beegoBeego - конечная точка тестирования
package test
import (
"github.com/astaxie/beego"
. "github.com/smartystreets/goconvey/convey"
_ "golife-api-cons/routers"
"net/http"
"net/http/httptest"
"path/filepath"
"runtime"
"testing"
)
func init() {
_, file, _, _ := runtime.Caller(1)
apppath, _ := filepath.Abs(filepath.Dir(filepath.Join(file, ".."+string(filepath.Separator))))
beego.TestBeegoInit(apppath)
}
// TestGet is a sample to run an endpoint test
func TestGet(t *testing.T) {
r, _ := http.NewRequest("GET", "/my/endpoint/fetches/data", nil)
w := httptest.NewRecorder()
beego.BeeApp.Handlers.ServeHTTP(w, r)
beego.Trace("testing", "TestGet", "Code[%d]\n%s", w.Code, w.Body.String())
Convey("Subject: Test Station Endpoint\n", t, func() {
Convey("Status Code Should Be 200", func() {
So(w.Code, ShouldEqual, 200)
})
Convey("The Result Should Not Be Empty", func() {
So(w.Body.Len(), ShouldBeGreaterThan, 0)
})
})
}
Когда я бегу с помощью go test -v
,
я получаю в ответ dial tcp :0: getsockopt: connection refused
Я использую MariaDB работает на моем местном, Я проверил с помощью netstat -tulpn
, что моя база данных работает отлично (я получаю действительный ответ, если я использую почтальон и мой сервер работает)
Одно странное наблюдение, после включения линии _ "golife-api-cons/routers"
я получаю эту ошибку еще до того, являются тестовыми в выбежала
Мой тест проходит с ответом 200 OK, но без каких-либо данных, как я получаю в ответ Вышеупомянутый ошибку
EDIT
путь по умолчанию, используемый TestBeegoInit
функцией используемого /path/to/my/project/test
, которая не является искомым путь, поэтому я попытался дать абсолютный путь тоже, до сих пор я не могу подключиться DB.
Какие настройки используют ваше приложение? Вы говорите, что ваш db работает, но как ваш тест знает, к чему подключиться db? – dusual
@dusual - Какие-либо конкретные настройки вам нужны? Проверьте, как beego.TestBeegoInit (<путь/to/config/file>) в источнике – poorva