mirror of
https://github.com/willnorris/imageproxy.git
synced 2026-05-02 00:02:39 +02:00
move option parsing tests to data_test.go
This commit is contained in:
parent
9c911bef14
commit
b4ed3507e3
2 changed files with 43 additions and 35 deletions
|
|
@ -14,7 +14,10 @@
|
||||||
|
|
||||||
package proxy
|
package proxy
|
||||||
|
|
||||||
import "testing"
|
import (
|
||||||
|
"reflect"
|
||||||
|
"testing"
|
||||||
|
)
|
||||||
|
|
||||||
func TestOptions_String(t *testing.T) {
|
func TestOptions_String(t *testing.T) {
|
||||||
tests := []struct {
|
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)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
|
||||||
|
|
@ -20,6 +20,10 @@ import (
|
||||||
"testing"
|
"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) {
|
func TestNewRequest(t *testing.T) {
|
||||||
tests := []struct {
|
tests := []struct {
|
||||||
URL string
|
URL string
|
||||||
|
|
@ -64,44 +68,14 @@ func TestNewRequest(t *testing.T) {
|
||||||
"http://localhost//https://example.com/foo",
|
"http://localhost//https://example.com/foo",
|
||||||
"https://example.com/foo", emptyOptions, false,
|
"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://localhost//http://example.com/foo?bar",
|
||||||
"http://example.com/foo?bar", emptyOptions, false,
|
"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 {
|
for i, tt := range tests {
|
||||||
|
|
|
||||||
Loading…
Add table
Add a link
Reference in a new issue