Added the url modules test files.
authorOwen Waller <o.waller@kulawe.com>
Wed, 10 Sep 2014 17:43:02 +0000 (18:43 +0100)
committerspf13 <steve.francia@gmail.com>
Wed, 5 Nov 2014 00:16:07 +0000 (19:16 -0500)
Added the new url module test file. This replaces the original
helpers_test.go file.

The TestUrlPrep test currently fails.

The only minor change to url.go is to add some trace printf's to
UrlPrep.

helpers/url.go
helpers/url_test.go [new file with mode: 0644]

index 94c66139d3ed37df666cfd6f1c0341856d907f26..37c53b6662abdb422847648692cf27d4d6fa8e07 100644 (file)
@@ -81,6 +81,7 @@ func MakePermalink(host, plink string) *url.URL {
 func UrlPrep(ugly bool, in string) string {
        if ugly {
                x := Uglify(SanitizeUrl(in))
+               fmt.Printf("Ugly case. Returning x = %q\n", x)
                return x
        } else {
                x := PrettifyUrl(SanitizeUrl(in))
@@ -89,8 +90,10 @@ func UrlPrep(ugly bool, in string) string {
                }
                url, err := purell.NormalizeURLString(x, purell.FlagAddTrailingSlash)
                if err != nil {
+                       fmt.Printf("ERROR returned by NormalizeURLString. Returning in = %q\n", in)
                        return in
                }
+               fmt.Printf("NO error returning url = %q\n", url)
                return url
        }
 }
diff --git a/helpers/url_test.go b/helpers/url_test.go
new file mode 100644 (file)
index 0000000..2a0223c
--- /dev/null
@@ -0,0 +1,99 @@
+package helpers
+
+import (
+       "testing"
+
+       "github.com/stretchr/testify/assert"
+)
+
+func TestUrlize(t *testing.T) {
+       tests := []struct {
+               input    string
+               expected string
+       }{
+               {"  foo bar  ", "foo-bar"},
+               {"foo.bar/foo_bar-foo", "foo.bar/foo_bar-foo"},
+               {"foo,bar:foo%bar", "foobarfoobar"},
+               {"foo/bar.html", "foo/bar.html"},
+               {"трям/трям", "%D1%82%D1%80%D1%8F%D0%BC/%D1%82%D1%80%D1%8F%D0%BC"},
+       }
+
+       for _, test := range tests {
+               output := Urlize(test.input)
+               if output != test.expected {
+                       t.Errorf("Expected %#v, got %#v\n", test.expected, output)
+               }
+       }
+}
+
+func TestMakePermalink(t *testing.T) {
+       type test struct {
+               host, link, output string
+       }
+
+       data := []test{
+               {"http://abc.com/foo", "post/bar", "http://abc.com/foo/post/bar"},
+               {"http://abc.com/foo/", "post/bar", "http://abc.com/foo/post/bar"},
+               {"http://abc.com", "post/bar", "http://abc.com/post/bar"},
+               {"http://abc.com", "bar", "http://abc.com/bar"},
+               {"http://abc.com/foo/bar", "post/bar", "http://abc.com/foo/bar/post/bar"},
+               {"http://abc.com/foo/bar", "post/bar/", "http://abc.com/foo/bar/post/bar/"},
+       }
+
+       for i, d := range data {
+               output := MakePermalink(d.host, d.link).String()
+               if d.output != output {
+                       t.Errorf("Test #%d failed. Expected %q got %q", i, d.output, output)
+               }
+       }
+}
+
+func TestUrlPrep(t *testing.T) {
+       type test struct {
+               ugly   bool
+               input  string
+               output string
+       }
+
+       data := []test{
+               {false, "/section/name.html", "/section/name/index.html"},
+               {true, "/section/name/index.html", "/section/name.html"},
+       }
+       for i, d := range data {
+               output := UrlPrep(d.ugly, d.input)
+               if d.output != output {
+                       t.Errorf("Test #%d failed. Expected %q got %q", i, d.output, output)
+               }
+       }
+
+}
+
+func TestPretty(t *testing.T) {
+       assert.Equal(t, PrettifyPath("/section/name.html"), "/section/name/index.html")
+       assert.Equal(t, PrettifyPath("/section/sub/name.html"), "/section/sub/name/index.html")
+       assert.Equal(t, PrettifyPath("/section/name/"), "/section/name/index.html")
+       assert.Equal(t, PrettifyPath("/section/name/index.html"), "/section/name/index.html")
+       assert.Equal(t, PrettifyPath("/index.html"), "/index.html")
+       assert.Equal(t, PrettifyPath("/name.xml"), "/name/index.xml")
+       assert.Equal(t, PrettifyPath("/"), "/")
+       assert.Equal(t, PrettifyPath(""), "/")
+       assert.Equal(t, PrettifyUrl("/section/name.html"), "/section/name")
+       assert.Equal(t, PrettifyUrl("/section/sub/name.html"), "/section/sub/name")
+       assert.Equal(t, PrettifyUrl("/section/name/"), "/section/name")
+       assert.Equal(t, PrettifyUrl("/section/name/index.html"), "/section/name")
+       assert.Equal(t, PrettifyUrl("/index.html"), "/")
+       assert.Equal(t, PrettifyUrl("/name.xml"), "/name/index.xml")
+       assert.Equal(t, PrettifyUrl("/"), "/")
+       assert.Equal(t, PrettifyUrl(""), "/")
+}
+
+func TestUgly(t *testing.T) {
+       assert.Equal(t, Uglify("/section/name.html"), "/section/name.html")
+       assert.Equal(t, Uglify("/section/sub/name.html"), "/section/sub/name.html")
+       assert.Equal(t, Uglify("/section/name/"), "/section/name.html")
+       assert.Equal(t, Uglify("/section/name/index.html"), "/section/name.html")
+       assert.Equal(t, Uglify("/index.html"), "/index.html")
+       assert.Equal(t, Uglify("/name.xml"), "/name.xml")
+       assert.Equal(t, Uglify("/"), "/")
+       assert.Equal(t, Uglify(""), "/")
+}