diff --git a/helper_test.go b/helper_test.go index a4a6429..7da80b9 100644 --- a/helper_test.go +++ b/helper_test.go @@ -1,9 +1,67 @@ package mastodon import ( + "io/ioutil" + "net/http" + "os" + "strings" "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) { s := "test" sp := String(s) @@ -11,3 +69,21 @@ func TestString(t *testing.T) { t.Fatalf("want %q but %q", s, *sp) } } + +func TestParseAPIError(t *testing.T) { + // No api error. + r := ioutil.NopCloser(strings.NewReader(`