diff options
| author | Ondřej Surý <ondrej@sury.org> | 2011-04-20 15:44:41 +0200 | 
|---|---|---|
| committer | Ondřej Surý <ondrej@sury.org> | 2011-04-20 15:44:41 +0200 | 
| commit | 50104cc32a498f7517a51c8dc93106c51c7a54b4 (patch) | |
| tree | 47af80be259cc7c45d0eaec7d42e61fa38c8e4fb /src/pkg/xml/xml_test.go | |
| parent | c072558b90f1bbedc2022b0f30c8b1ac4712538e (diff) | |
| download | golang-50104cc32a498f7517a51c8dc93106c51c7a54b4.tar.gz | |
Imported Upstream version 2011.03.07.1upstream/2011.03.07.1
Diffstat (limited to 'src/pkg/xml/xml_test.go')
| -rw-r--r-- | src/pkg/xml/xml_test.go | 46 | 
1 files changed, 46 insertions, 0 deletions
| diff --git a/src/pkg/xml/xml_test.go b/src/pkg/xml/xml_test.go index 317ecabd9..887bc3d14 100644 --- a/src/pkg/xml/xml_test.go +++ b/src/pkg/xml/xml_test.go @@ -185,6 +185,52 @@ func TestRawToken(t *testing.T) {  	}  } +// Ensure that directives (specifically !DOCTYPE) include the complete +// text of any nested directives, noting that < and > do not change +// nesting depth if they are in single or double quotes. + +var nestedDirectivesInput = ` +<!DOCTYPE [<!ENTITY rdf "http://www.w3.org/1999/02/22-rdf-syntax-ns#">]> +<!DOCTYPE [<!ENTITY xlt ">">]> +<!DOCTYPE [<!ENTITY xlt "<">]> +<!DOCTYPE [<!ENTITY xlt '>'>]> +<!DOCTYPE [<!ENTITY xlt '<'>]> +<!DOCTYPE [<!ENTITY xlt '">'>]> +<!DOCTYPE [<!ENTITY xlt "'<">]> +` + +var nestedDirectivesTokens = []Token{ +	CharData([]byte("\n")), +	Directive([]byte(`DOCTYPE [<!ENTITY rdf "http://www.w3.org/1999/02/22-rdf-syntax-ns#">]`)), +	CharData([]byte("\n")), +	Directive([]byte(`DOCTYPE [<!ENTITY xlt ">">]`)), +	CharData([]byte("\n")), +	Directive([]byte(`DOCTYPE [<!ENTITY xlt "<">]`)), +	CharData([]byte("\n")), +	Directive([]byte(`DOCTYPE [<!ENTITY xlt '>'>]`)), +	CharData([]byte("\n")), +	Directive([]byte(`DOCTYPE [<!ENTITY xlt '<'>]`)), +	CharData([]byte("\n")), +	Directive([]byte(`DOCTYPE [<!ENTITY xlt '">'>]`)), +	CharData([]byte("\n")), +	Directive([]byte(`DOCTYPE [<!ENTITY xlt "'<">]`)), +	CharData([]byte("\n")), +} + +func TestNestedDirectives(t *testing.T) { +	p := NewParser(StringReader(nestedDirectivesInput)) + +	for i, want := range nestedDirectivesTokens { +		have, err := p.Token() +		if err != nil { +			t.Fatalf("token %d: unexpected error: %s", i, err) +		} +		if !reflect.DeepEqual(have, want) { +			t.Errorf("token %d = %#v want %#v", i, have, want) +		} +	} +} +  func TestToken(t *testing.T) {  	p := NewParser(StringReader(testInput)) | 
