Files
gocryptotrader/engine/restful_server_test.go
Andrew bc0c32de3e (PROFILING): Add config support for setting runtime.SetMutexProfileFraction() value (#432)
* Added config option for SetMutexProfileFraction() to profiler increased test coverage and made tests runnable standalone

* Removed duplicate host and no longer const

* Added pprof endpoint to log
2020-01-30 13:20:41 +11:00

133 lines
3.2 KiB
Go

package engine
import (
"encoding/json"
"io/ioutil"
"net/http"
"net/http/httptest"
"reflect"
"runtime"
"testing"
"github.com/thrasher-corp/gocryptotrader/config"
)
func loadConfig(t *testing.T) *config.Config {
cfg := config.GetConfig()
err := cfg.LoadConfig("", true)
if err != nil {
t.Error("GetCurrencyConfig LoadConfig error", err)
}
configLoaded = true
return cfg
}
func makeHTTPGetRequest(t *testing.T, response interface{}) *http.Response {
w := httptest.NewRecorder()
err := RESTfulJSONResponse(w, response)
if err != nil {
t.Error("Failed to make response.", err)
}
return w.Result()
}
// TestConfigAllJsonResponse test if config/all restful json response is valid
func TestConfigAllJsonResponse(t *testing.T) {
cfg := loadConfig(t)
resp := makeHTTPGetRequest(t, cfg)
body, err := ioutil.ReadAll(resp.Body)
resp.Body.Close()
if err != nil {
t.Error("Body not readable", err)
}
var responseConfig config.Config
jsonErr := json.Unmarshal(body, &responseConfig)
if jsonErr != nil {
t.Error("Response not parseable as json", err)
}
if reflect.DeepEqual(responseConfig, cfg) {
t.Error("Json not equal to config")
}
}
func TestInvalidHostRequest(t *testing.T) {
Bot = &Engine{
Config: loadConfig(t),
}
req, err := http.NewRequest(http.MethodGet, "/config/all", nil)
if err != nil {
t.Fatal(err)
}
req.Host = "invalidsite.com"
resp := httptest.NewRecorder()
newRouter(true).ServeHTTP(resp, req)
if status := resp.Code; status != http.StatusNotFound {
t.Errorf("Response returned wrong status code expected %v got %v", http.StatusNotFound, status)
}
}
func TestValidHostRequest(t *testing.T) {
Bot = &Engine{
Config: loadConfig(t),
}
req, err := http.NewRequest(http.MethodGet, "/config/all", nil)
if err != nil {
t.Fatal(err)
}
req.Host = "localhost:9050"
resp := httptest.NewRecorder()
newRouter(true).ServeHTTP(resp, req)
if status := resp.Code; status != http.StatusOK {
t.Errorf("Response returned wrong status code expected %v got %v", http.StatusOK, status)
}
}
func TestProfilerEnabledShouldEnableProfileEndPoint(t *testing.T) {
Bot = &Engine{
Config: loadConfig(t),
}
req, err := http.NewRequest(http.MethodGet, "/debug/pprof/", nil)
if err != nil {
t.Fatal(err)
}
req.Host = "localhost:9050"
resp := httptest.NewRecorder()
newRouter(true).ServeHTTP(resp, req)
if status := resp.Code; status != http.StatusNotFound {
t.Errorf("Response returned wrong status code expected %v got %v", http.StatusNotFound, status)
}
Bot.Config.Profiler.Enabled = true
Bot.Config.Profiler.MutexProfileFraction = 5
req, err = http.NewRequest(http.MethodGet, "/debug/pprof/", nil)
if err != nil {
t.Fatal(err)
}
mutexValue := runtime.SetMutexProfileFraction(10)
if mutexValue != 0 {
t.Fatalf("SetMutexProfileFraction() should be 0 on first set received: %v", mutexValue)
}
resp = httptest.NewRecorder()
newRouter(true).ServeHTTP(resp, req)
mutexValue = runtime.SetMutexProfileFraction(10)
if mutexValue != 5 {
t.Fatalf("SetMutexProfileFraction() should be 5 after setup received: %v", mutexValue)
}
if status := resp.Code; status != http.StatusOK {
t.Errorf("Response returned wrong status code expected %v got %v", http.StatusOK, status)
}
}