0
Fork 0
mirror of https://github.com/willnorris/imageproxy.git synced 2024-12-16 21:56:43 -05:00

move option parsing tests to data_test.go

This commit is contained in:
Will Norris 2013-12-26 13:07:17 -08:00
parent 9c911bef14
commit b4ed3507e3
2 changed files with 43 additions and 35 deletions

View file

@ -14,7 +14,10 @@
package proxy
import "testing"
import (
"reflect"
"testing"
)
func TestOptions_String(t *testing.T) {
tests := []struct {
@ -34,3 +37,34 @@ func TestOptions_String(t *testing.T) {
}
}
}
func TestParseOptions(t *testing.T) {
tests := []struct {
Input string
Options *Options
}{
{"", emptyOptions},
{"x", emptyOptions},
{"0", emptyOptions},
// size variations
{"1x", &Options{Width: 1}},
{"x1", &Options{Height: 1}},
{"1x2", &Options{Width: 1, Height: 2}},
{"0.1x0.2", &Options{Width: 0.1, Height: 0.2}},
// additional flags
{",fit", &Options{Fit: true}},
{",r90", &Options{Rotate: 90}},
{",fv", &Options{FlipVertical: true}},
{",fh", &Options{FlipHorizontal: true}},
{"1x2,fit,r90,fv,fh", &Options{1, 2, true, 90, true, true}},
}
for i, tt := range tests {
if got, want := ParseOptions(tt.Input), tt.Options; !reflect.DeepEqual(got, want) {
t.Errorf("%d. ParseOptions returned %#v, want %#v", i, got, want)
}
}
}

View file

@ -20,6 +20,10 @@ import (
"testing"
)
// Test that request URLs are properly parsed into Options and RemoteURL. This
// test verifies that invalid remote URLs throw errors, and that valid
// combinations of Options and URL are accept. This does not exhaustively test
// the various Options that can be specified; see TestParseOptions for that.
func TestNewRequest(t *testing.T) {
tests := []struct {
URL string
@ -64,44 +68,14 @@ func TestNewRequest(t *testing.T) {
"http://localhost//https://example.com/foo",
"https://example.com/foo", emptyOptions, false,
},
{
"http://localhost/1x2/http://example.com/foo",
"http://example.com/foo", &Options{Width: 1, Height: 2}, false,
},
{
"http://localhost//http://example.com/foo?bar",
"http://example.com/foo?bar", emptyOptions, false,
},
// size variations
{
"http://localhost/x/http://example.com/",
"http://example.com/", emptyOptions, false,
},
{
"http://localhost/0/http://example.com/",
"http://example.com/", emptyOptions, false,
},
{
"http://localhost/1x/http://example.com/",
"http://example.com/", &Options{1, 0, false, 0, false, false}, false,
},
{
"http://localhost/x1/http://example.com/",
"http://example.com/", &Options{0, 1, false, 0, false, false}, false,
},
{
"http://localhost/1x2/http://example.com/",
"http://example.com/", &Options{1, 2, false, 0, false, false}, false,
},
{
"http://localhost/0.1x0.2/http://example.com/",
"http://example.com/", &Options{0.1, 0.2, false, 0, false, false}, false,
},
{
"http://localhost/,fit/http://example.com/",
"http://example.com/", &Options{0, 0, true, 0, false, false}, false,
},
{
"http://localhost/1x2,fit,r90,fv,fh/http://example.com/",
"http://example.com/", &Options{1, 2, true, 90, true, true}, false,
},
}
for i, tt := range tests {