Browse Source

Fix imgur bot tests

pull/158/head
Richard Lewis 8 years ago
parent
commit
0d2593b152
  1. 46
      src/github.com/matrix-org/go-neb/services/imgur/imgur_test.go

46
src/github.com/matrix-org/go-neb/services/imgur/imgur_test.go

@ -15,16 +15,14 @@ import (
"github.com/matrix-org/gomatrix" "github.com/matrix-org/gomatrix"
) )
// TODO: It would be nice to tabularise this test so we can try failing different combinations of responses to make
// sure all cases are handled, rather than just the general case as is here.
func TestCommand(t *testing.T) { func TestCommand(t *testing.T) {
database.SetServiceDB(&database.NopStorage{}) database.SetServiceDB(&database.NopStorage{})
apiKey := "secret" clientID := "My ID"
imgurImageURL := "https://www.imgurapis.com/customsearch/v1" imgurImageURL := "https://api.imgur.com/3/gallery/search"
// Mock the response from imgur // Mock the response from imgur
imgurTrans := testutils.NewRoundTripper(func(req *http.Request) (*http.Response, error) { imgurTrans := testutils.NewRoundTripper(func(req *http.Request) (*http.Response, error) {
imgurURL := "https://www.imgurapis.com/customsearch/v1" imgurURL := "https://api.imgur.com/3/gallery/search"
query := req.URL.Query() query := req.URL.Query()
// Check the base API URL // Check the base API URL
@ -35,26 +33,22 @@ func TestCommand(t *testing.T) {
if req.Method != "GET" { if req.Method != "GET" {
t.Fatalf("Bad method: got %s want GET", req.Method) t.Fatalf("Bad method: got %s want GET", req.Method)
} }
// Check the API key // Check the Client ID
if query.Get("key") != apiKey { authHeader := req.Header.Get("Authorization")
t.Fatalf("Bad apiKey: got %s want %s", query.Get("key"), apiKey) if authHeader != "Client-ID "+clientID {
t.Fatalf("Bad client ID - Expected: %s, got %s", "Client-ID "+clientID, authHeader)
} }
// Check the search query // Check the search query
var searchString = query.Get("q") var searchString = query.Get("q")
var searchStringLength = len(searchString) if !strings.HasPrefix(searchString, "image") {
if searchStringLength > 0 && !strings.HasPrefix(searchString, "image") { t.Fatalf("Bad search string: got \"%s\"", searchString)
t.Fatalf("Bad search string: got \"%s\" (%d characters) ", searchString, searchStringLength)
}
resImage := imgurImage{
Width: 64,
Height: 64,
} }
res := imgurSearchResult{ res := imgurGalleryImage{
Title: "A Cat", Title: "A Cat",
Link: "http://cat.com/cat.jpg", Link: "http://i.imgur.com/cat.jpg",
Mime: "image/jpeg", Type: "image/jpeg",
Image: resImage, Image: resImage,
} }
@ -72,7 +66,9 @@ func TestCommand(t *testing.T) {
// Create the imgur service // Create the imgur service
srv, err := types.CreateService("id", ServiceType, "@imgurbot:hyrule", []byte( srv, err := types.CreateService("id", ServiceType, "@imgurbot:hyrule", []byte(
`{"api_key":"`+apiKey+`"}`, `{
"client_id":"`+clientID+`"
}`,
)) ))
if err != nil { if err != nil {
t.Fatal("Failed to create imgur service: ", err) t.Fatal("Failed to create imgur service: ", err)
@ -103,9 +99,9 @@ func TestCommand(t *testing.T) {
if len(cmds) != 2 { if len(cmds) != 2 {
t.Fatalf("Unexpected number of commands: %d", len(cmds)) t.Fatalf("Unexpected number of commands: %d", len(cmds))
} }
// cmd := cmds[0] cmd := cmds[0]
// _, err = cmd.Command("!someroom:hyrule", "@navi:hyrule", []string{"image", "Czechoslovakian bananna"}) _, err = cmd.Command("!someroom:hyrule", "@navi:hyrule", []string{"image", "Czechoslovakian bananna"})
// if err != nil { if err != nil {
// t.Fatalf("Failed to process command: %s", err.Error()) t.Fatalf("Failed to process command: %s", err.Error())
// } }
} }
|||||||
100:0
Loading…
Cancel
Save