summaryrefslogtreecommitdiff
path: root/vendor/github.com/onsi/gomega/matchers/match_xml_matcher_test.go
diff options
context:
space:
mode:
Diffstat (limited to 'vendor/github.com/onsi/gomega/matchers/match_xml_matcher_test.go')
-rw-r--r--vendor/github.com/onsi/gomega/matchers/match_xml_matcher_test.go97
1 files changed, 97 insertions, 0 deletions
diff --git a/vendor/github.com/onsi/gomega/matchers/match_xml_matcher_test.go b/vendor/github.com/onsi/gomega/matchers/match_xml_matcher_test.go
new file mode 100644
index 000000000..0b559b22e
--- /dev/null
+++ b/vendor/github.com/onsi/gomega/matchers/match_xml_matcher_test.go
@@ -0,0 +1,97 @@
+package matchers_test
+
+import (
+ . "github.com/onsi/ginkgo"
+ . "github.com/onsi/gomega"
+ . "github.com/onsi/gomega/matchers"
+)
+
+var _ = Describe("MatchXMLMatcher", func() {
+
+ var (
+ sample_01 = readFileContents("test_data/xml/sample_01.xml")
+ sample_02 = readFileContents("test_data/xml/sample_02.xml")
+ sample_03 = readFileContents("test_data/xml/sample_03.xml")
+ sample_04 = readFileContents("test_data/xml/sample_04.xml")
+ sample_05 = readFileContents("test_data/xml/sample_05.xml")
+ sample_06 = readFileContents("test_data/xml/sample_06.xml")
+ sample_07 = readFileContents("test_data/xml/sample_07.xml")
+ sample_08 = readFileContents("test_data/xml/sample_08.xml")
+ sample_09 = readFileContents("test_data/xml/sample_09.xml")
+ sample_10 = readFileContents("test_data/xml/sample_10.xml")
+ sample_11 = readFileContents("test_data/xml/sample_11.xml")
+ )
+
+ Context("When passed stringifiables", func() {
+ It("matches documents regardless of the attribute order", func() {
+ a := `<a foo="bar" ka="boom"></a>`
+ b := `<a ka="boom" foo="bar"></a>`
+ Expect(b).Should(MatchXML(a))
+ Expect(a).Should(MatchXML(b))
+ })
+
+ It("should succeed if the XML matches", func() {
+ Expect(sample_01).Should(MatchXML(sample_01)) // same XML
+ Expect(sample_01).Should(MatchXML(sample_02)) // same XML with blank lines
+ Expect(sample_01).Should(MatchXML(sample_03)) // same XML with different formatting
+ Expect(sample_01).ShouldNot(MatchXML(sample_04)) // same structures with different values
+ Expect(sample_01).ShouldNot(MatchXML(sample_05)) // different structures
+ Expect(sample_06).ShouldNot(MatchXML(sample_07)) // same xml names with different namespaces
+ Expect(sample_07).ShouldNot(MatchXML(sample_08)) // same structures with different values
+ Expect(sample_09).ShouldNot(MatchXML(sample_10)) // same structures with different attribute values
+ Expect(sample_11).Should(MatchXML(sample_11)) // with non UTF-8 encoding
+ })
+
+ It("should work with byte arrays", func() {
+ Expect([]byte(sample_01)).Should(MatchXML([]byte(sample_01)))
+ Expect([]byte(sample_01)).Should(MatchXML(sample_01))
+ Expect(sample_01).Should(MatchXML([]byte(sample_01)))
+ })
+ })
+
+ Context("when the expected is not valid XML", func() {
+ It("should error and explain why", func() {
+ success, err := (&MatchXMLMatcher{XMLToMatch: sample_01}).Match(`oops`)
+ Expect(success).Should(BeFalse())
+ Expect(err).Should(HaveOccurred())
+ Expect(err.Error()).Should(ContainSubstring("Actual 'oops' should be valid XML"))
+ })
+ })
+
+ Context("when the actual is not valid XML", func() {
+ It("should error and explain why", func() {
+ success, err := (&MatchXMLMatcher{XMLToMatch: `oops`}).Match(sample_01)
+ Expect(success).Should(BeFalse())
+ Expect(err).Should(HaveOccurred())
+ Expect(err.Error()).Should(ContainSubstring("Expected 'oops' should be valid XML"))
+ })
+ })
+
+ Context("when the expected is neither a string nor a stringer nor a byte array", func() {
+ It("should error", func() {
+ success, err := (&MatchXMLMatcher{XMLToMatch: 2}).Match(sample_01)
+ Expect(success).Should(BeFalse())
+ Expect(err).Should(HaveOccurred())
+ Expect(err.Error()).Should(ContainSubstring("MatchXMLMatcher matcher requires a string, stringer, or []byte. Got expected:\n <int>: 2"))
+
+ success, err = (&MatchXMLMatcher{XMLToMatch: nil}).Match(sample_01)
+ Expect(success).Should(BeFalse())
+ Expect(err).Should(HaveOccurred())
+ Expect(err.Error()).Should(ContainSubstring("MatchXMLMatcher matcher requires a string, stringer, or []byte. Got expected:\n <nil>: nil"))
+ })
+ })
+
+ Context("when the actual is neither a string nor a stringer nor a byte array", func() {
+ It("should error", func() {
+ success, err := (&MatchXMLMatcher{XMLToMatch: sample_01}).Match(2)
+ Expect(success).Should(BeFalse())
+ Expect(err).Should(HaveOccurred())
+ Expect(err.Error()).Should(ContainSubstring("MatchXMLMatcher matcher requires a string, stringer, or []byte. Got actual:\n <int>: 2"))
+
+ success, err = (&MatchXMLMatcher{XMLToMatch: sample_01}).Match(nil)
+ Expect(success).Should(BeFalse())
+ Expect(err).Should(HaveOccurred())
+ Expect(err.Error()).Should(ContainSubstring("MatchXMLMatcher matcher requires a string, stringer, or []byte. Got actual:\n <nil>: nil"))
+ })
+ })
+})