1b7f743892
- Don't assign variables we don't end up using - Added missing error check in test
90 lines
4.1 KiB
Go
90 lines
4.1 KiB
Go
package mastodon
|
|
|
|
import (
|
|
"io/ioutil"
|
|
"net/http"
|
|
"os"
|
|
"strings"
|
|
"testing"
|
|
)
|
|
|
|
const wantBase64 = ""
|
|
|
|
func TestBase64EncodeFileName(t *testing.T) {
|
|
// Error in os.Open.
|
|
_, 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.
|
|
_, 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)
|
|
}
|
|
_, 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) {
|
|
s := "test"
|
|
sp := String(s)
|
|
if *sp != s {
|
|
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())
|
|
}
|
|
}
|