From 2dd4a14d2f82f67d00db267c4e810f624d72146d Mon Sep 17 00:00:00 2001 From: andrewheberle Date: Mon, 24 Jun 2019 10:16:04 +0800 Subject: [PATCH] Add ToURLE tests --- cast_test.go | 28 ++++++++++++++++++++++++++++ 1 file changed, 28 insertions(+) diff --git a/cast_test.go b/cast_test.go index d9a1479..2af9991 100644 --- a/cast_test.go +++ b/cast_test.go @@ -1285,3 +1285,31 @@ func TestToDurationE(t *testing.T) { assert.Equal(t, test.expect, v, errmsg) } } + +func TestToURLE(t *testing.T) { + type args struct { + i interface{} + } + tests := []struct { + name string + args args + wantU *url.URL + wantErr bool + }{ + {"url", args{&url.URL{Scheme: "https", Host: "example.net", Path: "/"}}, &url.URL{Scheme: "https", Host: "example.net", Path: "/"}, false}, + {"string", args{string("https://example.net/")}, &url.URL{Scheme: "https", Host: "example.net", Path: "/"}, false}, + {"invalid", args{int(100)}, nil, true}, + } + for _, tt := range tests { + t.Run(tt.name, func(t *testing.T) { + gotU, err := ToURLE(tt.args.i) + if (err != nil) != tt.wantErr { + t.Errorf("ToURLE() error = %v, wantErr %v", err, tt.wantErr) + return + } + if !reflect.DeepEqual(gotU, tt.wantU) { + t.Errorf("ToURLE() = %v, want %v", gotU, tt.wantU) + } + }) + } +}