rewriting guessSection to accurately reflect intent and usage. Update tests.
authorspf13 <steve.francia@gmail.com>
Wed, 5 Nov 2014 01:19:45 +0000 (20:19 -0500)
committerspf13 <steve.francia@gmail.com>
Wed, 5 Nov 2014 01:19:45 +0000 (20:19 -0500)
helpers/path.go
helpers/path_test.go

index c994cce7c9b8bf819e89e6965d46968bb7bf0299..e70304c5e59eaca4e9b7ed21463b997bd05819b0 100644 (file)
@@ -209,36 +209,37 @@ func GetRelativePath(path, base string) (final string, err error) {
 }
 
 // Given a source path, determine the section
+// A section is the part between the root slash and the second slash or before the first slash
 func GuessSection(in string) string {
        parts := strings.Split(in, "/")
+       // This will include an empty entry before and after paths with leading and trailing slashes
+       // eg... /sect/one/ -> ["", "sect", "one", ""]
 
-       if len(parts) == 0 {
+       // Needs to have at least a value and a slash
+       if len(parts) < 2 {
                return ""
        }
 
-       // trim filename
-       if !strings.HasSuffix(in, "/") {
-               parts = parts[:len(parts)-1]
-       }
-
-       if len(parts) == 0 {
+       // If it doesn't have a leading slash and value and file or trailing slash, then return ""
+       if parts[0] == "" && len(parts) < 3 {
                return ""
        }
 
-       // if first directory is "content", return second directory
-       section := ""
-
-       if parts[0] == "content" && len(parts) > 1 {
-               section = parts[1]
-       } else {
-               section = parts[0]
+       // strip leading slash
+       if parts[0] == "" {
+               parts = parts[1:]
        }
 
-       if section == "." {
-               return ""
+       // if first directory is "content", return second directory
+       if parts[0] == "content" {
+               if len(parts) > 2 {
+                       return parts[1]
+               } else {
+                       return ""
+               }
        }
 
-       return section
+       return parts[0]
 }
 
 func PathPrep(ugly bool, in string) string {
index 6079185811a4900646cc3355f377346c65f51dcf..bab1786e2f339c5ec35b2976390b69334a9c3bdd 100644 (file)
@@ -423,17 +423,20 @@ func TestGuessSection(t *testing.T) {
                {"", ""},
                {"/content", ""},
                {"content/", ""},
-               {"/content/", "content"},
+               {"/content/", ""}, // /content/ is a special case. It will never be the section
                {"/blog", ""},
                {"/blog/", "blog"},
                {"blog", ""},
                {"content/blog", ""},
                {"/content/blog/", "blog"},
-               {"/content/blog", "blog"},
-               {"content/blog/", ""},
+               {"/content/blog", ""}, // Lack of trailing slash indicates 'blog' is not a directory.
+               {"content/blog/", "blog"},
                {"/contents/myblog/", "contents"},
                {"/contents/yourblog", "contents"},
                {"/contents/ourblog/", "contents"},
+               {"/content/myblog/", "myblog"},
+               {"/content/yourblog", ""},
+               {"/content/ourblog/", "ourblog"},
        }
 
        for i, d := range data {