Add some tests for IgnoreFiles
authorbep <bjorn.erik.pedersen@gmail.com>
Wed, 3 Jun 2015 16:54:30 +0000 (18:54 +0200)
committerbep <bjorn.erik.pedersen@gmail.com>
Wed, 3 Jun 2015 16:54:15 +0000 (18:54 +0200)
And log error on invalid regexp.

See #1189

helpers/general.go
source/content_directory_test.go
source/filesystem.go

index 908751da0e0b01d951949eef397d5591b8a8b71c..540fb43328a847e47cc085d33372d67114ef86c0 100644 (file)
@@ -198,12 +198,12 @@ func NewDistinctErrorLogger() *DistinctErrorLogger {
 }
 
 // Avoid spamming the logs with errors
-var deprecatedLogger = NewDistinctErrorLogger()
+var DistinctErrorLog = NewDistinctErrorLogger()
 
 // Deprecated logs ERROR logs about a deprecation, but only once for a given set of arguments' values.
 func Deprecated(object, item, alternative string) {
        //      deprecatedLogger.Printf("%s's %s is deprecated and will be removed in Hugo %s. Use %s instead.", object, item, NextHugoReleaseVersion(), alternative)
-       deprecatedLogger.Printf("%s's %s is deprecated and will be removed VERY SOON. Use %s instead.", object, item, alternative)
+       DistinctErrorLog.Printf("%s's %s is deprecated and will be removed VERY SOON. Use %s instead.", object, item, alternative)
 
 }
 
index 8f0b21edffefe6719faf7017c1cb106c254455f0..3f1369c334762800fded7a0c81235dfd047e013f 100644 (file)
@@ -1,29 +1,41 @@
 package source
 
 import (
+       "github.com/spf13/viper"
        "testing"
 )
 
 func TestIgnoreDotFilesAndDirectories(t *testing.T) {
+       viper.Reset()
+       defer viper.Reset()
+
        tests := []struct {
-               path   string
-               ignore bool
+               path                string
+               ignore              bool
+               ignoreFilesRegexpes interface{}
        }{
-               {".foobar/", true},
-               {"foobar/.barfoo/", true},
-               {"barfoo.md", false},
-               {"foobar/barfoo.md", false},
-               {"foobar/.barfoo.md", true},
-               {".barfoo.md", true},
-               {".md", true},
-               {"", true},
-               {"foobar/barfoo.md~", true},
-               {".foobar/barfoo.md~", true},
-               {"foobar~/barfoo.md", false},
-               {"foobar/bar~foo.md", false},
+               {".foobar/", true, nil},
+               {"foobar/.barfoo/", true, nil},
+               {"barfoo.md", false, nil},
+               {"foobar/barfoo.md", false, nil},
+               {"foobar/.barfoo.md", true, nil},
+               {".barfoo.md", true, nil},
+               {".md", true, nil},
+               {"", true, nil},
+               {"foobar/barfoo.md~", true, nil},
+               {".foobar/barfoo.md~", true, nil},
+               {"foobar~/barfoo.md", false, nil},
+               {"foobar/bar~foo.md", false, nil},
+               {"foobar/foo.md", true, []string{"\\.md$", "\\.boo$"}},
+               {"foobar/foo.html", false, []string{"\\.md$", "\\.boo$"}},
+               {"foobar/foo.md", true, []string{"^foo"}},
+               {"foobar/foo.md", false, []string{"*", "\\.md$", "\\.boo$"}},
        }
 
        for _, test := range tests {
+
+               viper.Set("ignoreFiles", test.ignoreFilesRegexpes)
+
                if ignored := isNonProcessablePath(test.path); test.ignore != ignored {
                        t.Errorf("File not ignored.  Expected: %t, got: %t", test.ignore, ignored)
                }
index 7242d1dfc5b9af048be7fe3da9ec52f3849caa65..7b7ebb6b7fcac35ce00ea605a7107f532b5555f8 100644 (file)
@@ -151,8 +151,11 @@ func isNonProcessablePath(filePath string) bool {
        ignoreFiles := viper.GetStringSlice("IgnoreFiles")
        if len(ignoreFiles) > 0 {
                for _, ignorePattern := range ignoreFiles {
-                       match, _ := regexp.MatchString(ignorePattern, filePath)
-                       if match {
+                       match, err := regexp.MatchString(ignorePattern, filePath)
+                       if err != nil {
+                               helpers.DistinctErrorLog.Printf("Invalid regexp '%s' in ignoreFiles: %s", ignorePattern, err)
+                               return false
+                       } else if match {
                                return true
                        }
                }