mirror of
https://github.com/aclindsa/moneygo.git
synced 2024-10-30 15:50:04 -04:00
Aaron Lindsay
8f0f64ae53
Split out common test infrastructure from security_templates_test, make tests HTTPS, use the http.Client provided by httptest
117 lines
2.4 KiB
Go
117 lines
2.4 KiB
Go
package handlers_test
|
|
|
|
import (
|
|
"github.com/aclindsa/moneygo/internal/handlers"
|
|
"io/ioutil"
|
|
"testing"
|
|
)
|
|
|
|
func TestSecurityTemplates(t *testing.T) {
|
|
var sl handlers.SecurityList
|
|
response, err := server.Client().Get(server.URL + "/securitytemplate/?search=USD&type=currency")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if response.StatusCode != 200 {
|
|
t.Fatalf("Unexpected HTTP status code: %d\n", response.StatusCode)
|
|
}
|
|
|
|
body, err := ioutil.ReadAll(response.Body)
|
|
response.Body.Close()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
err = (&sl).Read(string(body))
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
num_usd := 0
|
|
for _, s := range *sl.Securities {
|
|
if s.Type != handlers.Currency {
|
|
t.Fatalf("Requested Currency-only security templates, received a non-Currency template for %s", s.Name)
|
|
}
|
|
|
|
if s.Name == "USD" && s.AlternateId == "840" {
|
|
num_usd++
|
|
}
|
|
}
|
|
|
|
if num_usd != 1 {
|
|
t.Fatalf("Expected one USD security template, found %d\n", num_usd)
|
|
}
|
|
}
|
|
|
|
func TestSecurityTemplateLimit(t *testing.T) {
|
|
var sl handlers.SecurityList
|
|
response, err := server.Client().Get(server.URL + "/securitytemplate/?search=e&limit=5")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
if response.StatusCode != 200 {
|
|
t.Fatalf("Unexpected HTTP status code: %d\n", response.StatusCode)
|
|
}
|
|
|
|
body, err := ioutil.ReadAll(response.Body)
|
|
response.Body.Close()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
err = (&sl).Read(string(body))
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if len(*sl.Securities) > 5 {
|
|
t.Fatalf("Requested only 5 securities, received %d\n", len(*sl.Securities))
|
|
}
|
|
}
|
|
|
|
func TestSecurityTemplateInvalidType(t *testing.T) {
|
|
var e handlers.Error
|
|
response, err := server.Client().Get(server.URL + "/securitytemplate/?search=e&type=blah")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
body, err := ioutil.ReadAll(response.Body)
|
|
response.Body.Close()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
err = (&e).Read(string(body))
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if e.ErrorId != 3 {
|
|
t.Fatal("Expected ErrorId 3, Invalid Request")
|
|
}
|
|
}
|
|
|
|
func TestSecurityTemplateInvalidLimit(t *testing.T) {
|
|
var e handlers.Error
|
|
response, err := server.Client().Get(server.URL + "/securitytemplate/?search=e&type=Currency&limit=foo")
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
body, err := ioutil.ReadAll(response.Body)
|
|
response.Body.Close()
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
err = (&e).Read(string(body))
|
|
if err != nil {
|
|
t.Fatal(err)
|
|
}
|
|
|
|
if e.ErrorId != 3 {
|
|
t.Fatal("Expected ErrorId 3, Invalid Request")
|
|
}
|
|
}
|