Merge pull request #33 from 178inaba/helper_test

Add helper test
This commit is contained in:
mattn 2017-04-21 00:19:34 +09:00 committed by GitHub
commit fc6bfd56fa

View File

@ -1,9 +1,67 @@
package mastodon package mastodon
import ( import (
"io/ioutil"
"net/http"
"os"
"strings"
"testing" "testing"
) )
const wantBase64 = ""
func TestBase64EncodeFileName(t *testing.T) {
// Error in os.Open.
uri, err := Base64EncodeFileName("fail")
if err == nil {
t.Fatalf("should be fail: %v", err)
}
// Success.
uri, err = Base64EncodeFileName("testdata/logo.png")
if err != nil {
t.Fatalf("should not be fail: %v", err)
}
if uri != wantBase64 {
t.Fatalf("want %q but %q", wantBase64, uri)
}
}
func TestBase64Encode(t *testing.T) {
// Error in file.Stat.
uri, err := Base64Encode(nil)
if err == nil {
t.Fatalf("should be fail: %v", err)
}
// Error in file.Read.
logo, err := os.Open("testdata/logo.png")
if err != nil {
t.Fatalf("should not be fail: %v", err)
}
_, err = ioutil.ReadAll(logo)
if err != nil {
t.Fatalf("should not be fail: %v", err)
}
uri, err = Base64Encode(logo)
if err == nil {
t.Fatalf("should be fail: %v", err)
}
// Success.
logo, err = os.Open("testdata/logo.png")
if err != nil {
t.Fatalf("should not be fail: %v", err)
}
uri, err = Base64Encode(logo)
if err != nil {
t.Fatalf("should not be fail: %v", err)
}
if uri != wantBase64 {
t.Fatalf("want %q but %q", wantBase64, uri)
}
}
func TestString(t *testing.T) { func TestString(t *testing.T) {
s := "test" s := "test"
sp := String(s) sp := String(s)
@ -11,3 +69,21 @@ func TestString(t *testing.T) {
t.Fatalf("want %q but %q", s, *sp) t.Fatalf("want %q but %q", s, *sp)
} }
} }
func TestParseAPIError(t *testing.T) {
// No api error.
r := ioutil.NopCloser(strings.NewReader(`<html><head><title>404</title></head></html>`))
err := parseAPIError("bad request", &http.Response{Status: "404 Not Found", Body: r})
want := "bad request: 404 Not Found"
if err.Error() != want {
t.Fatalf("want %q but %q", want, err.Error())
}
// With api error.
r = ioutil.NopCloser(strings.NewReader(`{"error":"Record not found"}`))
err = parseAPIError("bad request", &http.Response{Status: "404 Not Found", Body: r})
want = "bad request: 404 Not Found: Record not found"
if err.Error() != want {
t.Fatalf("want %q but %q", want, err.Error())
}
}