Fix test to not fail when order is different, but slice contents are the same.
authorspf13 <steve.francia@gmail.com>
Wed, 9 Apr 2014 01:57:25 +0000 (21:57 -0400)
committerspf13 <steve.francia@gmail.com>
Wed, 9 Apr 2014 01:57:25 +0000 (21:57 -0400)
hugolib/site_show_plan_test.go

index b10130655c27dcd87b6134e497d6927a47164d35..d4382184834e9a35859c4c500b41725593c49c12 100644 (file)
@@ -2,9 +2,11 @@ package hugolib
 
 import (
        "bytes"
+       "strings"
+       "testing"
+
        "github.com/spf13/hugo/source"
        "github.com/spf13/hugo/target"
-       "testing"
 )
 
 const ALIAS_DOC_1 = "---\ntitle: alias doc\naliases:\n  - \"alias1/\"\n  - \"alias-2/\"\n---\naliases\n"
@@ -24,14 +26,35 @@ var fakeSource = []source.ByteSource{
        },
 }
 
+func stringInSlice(a string, list []string) bool {
+       for _, b := range list {
+               if b == a {
+                       return true
+               }
+       }
+       return false
+}
+
 func checkShowPlanExpected(t *testing.T, s *Site, expected string) {
        out := new(bytes.Buffer)
        if err := s.ShowPlan(out); err != nil {
                t.Fatalf("ShowPlan unexpectedly returned an error: %s", err)
        }
        got := out.String()
-       if got != expected {
-               t.Errorf("ShowPlan expected:\n%q\ngot\n%q", expected, got)
+
+       gotList := strings.Split(got, "\n")
+       expectedList := strings.Split(expected, "\n")
+
+       for _, x := range gotList {
+               if !stringInSlice(x, expectedList) {
+                       t.Errorf("ShowPlan expected:\n%q\ngot\n%q", expected, got)
+               }
+       }
+
+       for _, x := range expectedList {
+               if !stringInSlice(x, gotList) {
+                       t.Errorf("ShowPlan expected:\n%q\ngot\n%q", expected, got)
+               }
        }
 }