commit
fc6bfd56fa
|
@ -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())
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user