From 794b0a07483fdae7125f325d34fbea6b40a67885 Mon Sep 17 00:00:00 2001 From: Demi Marie Obenour Date: Tue, 3 Sep 2024 01:33:29 +0000 Subject: [PATCH] encoding/xml: allow ]]> in attribute values This is permitted by the XML specification. Fixes #68387 Change-Id: Ic4ab5520a08a5a997f1c3d13c6d5f80c0521e45c GitHub-Last-Rev: 6d2ac307bbd0ba7d50830ad8b879c00cc3a7242b GitHub-Pull-Request: golang/go#69197 Reviewed-on: https://go-review.googlesource.com/c/go/+/610056 Auto-Submit: Ian Lance Taylor Reviewed-by: Dmitri Shuralyov LUCI-TryBot-Result: Go LUCI Reviewed-by: Ian Lance Taylor --- src/encoding/xml/xml.go | 5 +++-- src/encoding/xml/xml_test.go | 24 ++++++++++++++++++++++++ 2 files changed, 27 insertions(+), 2 deletions(-) diff --git a/src/encoding/xml/xml.go b/src/encoding/xml/xml.go index 0fe323f7c8..951676d403 100644 --- a/src/encoding/xml/xml.go +++ b/src/encoding/xml/xml.go @@ -1004,8 +1004,9 @@ Input: } // . - // It is an error for ]]> to appear in ordinary text. - if b0 == ']' && b1 == ']' && b == '>' { + // It is an error for ]]> to appear in ordinary text, + // but it is allowed in quoted strings. + if quote < 0 && b0 == ']' && b1 == ']' && b == '>' { if cdata { trunc = 2 break Input diff --git a/src/encoding/xml/xml_test.go b/src/encoding/xml/xml_test.go index b2a06a7639..fc3c15eff1 100644 --- a/src/encoding/xml/xml_test.go +++ b/src/encoding/xml/xml_test.go @@ -626,6 +626,30 @@ type item struct { FieldA string } +func TestIssue68387(t *testing.T) { + data := `` + dec := NewDecoder(strings.NewReader(data)) + var tok1, tok2, tok3 Token + var err error + if tok1, err = dec.RawToken(); err != nil { + t.Fatalf("RawToken() failed: %v", err) + } + if tok2, err = dec.RawToken(); err != nil { + t.Fatalf("RawToken() failed: %v", err) + } + if tok3, err = dec.RawToken(); err != io.EOF || tok3 != nil { + t.Fatalf("Missed EOF") + } + s := StartElement{Name{"", "item"}, []Attr{Attr{Name{"","b"}, "]]>"}}} + if !reflect.DeepEqual(tok1.(StartElement), s) { + t.Error("Wrong start element") + } + e := EndElement{Name{"","item"}} + if tok2.(EndElement) != e { + t.Error("Wrong end element") + } +} + func TestIssue569(t *testing.T) { data := `abcd` var i item -- 2.48.1