# YAML Test Matrix

--- &test-3HFZ
  Title: Invalid content after document end marker
  Tags: [ error, footer ]

YAML

---
key: value
... invalid

Expected Events

+STR
+DOC ---
+MAP
=VAL :key
=VAL :value
-MAP
-DOC ...

Expected JSON



cpp-rapidyaml-event

 invalid_incorrect
+STR
+DOC ---
+MAP
=VAL :key
=VAL :value
-MAP
-DOC
+DOC ---
=VAL :invalid
-DOC
-STR

cpp-yamlcpp-event

 invalid_incorrect
+STR
+DOC
+MAP
=VAL :key
=VAL :value
-MAP
-DOC
+DOC
=VAL :invalid
-DOC
-STR

hs-reference-yeast

 invalid_incorrect
Line  Col Char Byte Token|Content
   1    0    0    0 +DOC |
   1    0    0    0 =HEAD|---
   1    3    3    3 +NODE|
   1    3    3    3 =EOL |\x0a
   2    0    4    4 +MAP |
   2    0    4    4 +PAIR|
   2    0    4    4 +NODE|
   2    0    4    4 +VAL |
   2    0    4    4 =TEXT|key
   2    3    7    7 -VAL |
   2    3    7    7 -NODE|
   2    3    7    7 =SYNX|:
   2    4    8    8 =WSPC|.
   2    5    9    9 +NODE|
   2    5    9    9 +VAL |
   2    5    9    9 =TEXT|value
   2   10   14   14 -VAL |
   2   10   14   14 -NODE|
   2   10   14   14 =EOL |\x0a
   3    0   15   15 -PAIR|
   3    0   15   15 -MAP |
   3    0   15   15 -NODE|
   3    0   15   15 -DOC |
   3    0   15   15 =ERR |Unexpected.'.'

js-jsyaml-json

 invalid_incorrect
{"key":"value"}
"invalid"

perl-syck-json

 invalid_incorrect
{
   "key" : "value"
}
"invalid"

perl-syck-perl

 invalid_incorrect
{
  'key' => 'value'
}
'invalid'

perl-tiny-json

 invalid_incorrect
{
   "key" : "value"
}

perl-tiny-perl

 invalid_incorrect
{
  'key' => 'value'
}

py-ruamel-event

 invalid_incorrect
+STR
+DOC ---
+MAP
=VAL :key
=VAL :value
-MAP
-DOC ...
+DOC
=VAL :invalid
-DOC
-STR

py-ruamel-json

 invalid_incorrect
{
  "key": "value"
}
"invalid"

py-ruamel-py

 invalid_incorrect
{'key': 'value'}
'invalid'

c-libfyaml-event

 invalid_correct
stdin:3:5: error: invalid content after document end marker
... invalid
    ^
+STR
+DOC ---
+MAP
=VAL :key
=VAL :value

c-libfyaml-json

 invalid_correct
stdin:3:5: error: invalid content after document end marker
... invalid
    ^

c-libyaml-event

 invalid_correct
Parse error: did not find expected <document start>
+STR
+DOC ---
+MAP
=VAL :key
=VAL :value
-MAP
-DOC ...

dotnet-yamldotnet-event

 invalid_correct
Unhandled exception. YamlDotNet.Core.SemanticErrorException: (Line: 3, Col: 1, Idx: 15) - (Line: 3, Col: 5, Idx: 19): Did not find expected <document start>.
   at YamlDotNet.Core.Parser.ParseDocumentStart(Boolean isImplicit)
   at YamlDotNet.Core.Parser.StateMachine()
   at YamlDotNet.Core.Parser.MoveNext()
   at YamlDotNet.RepresentationModel.LibYamlEventStream.WriteTo(TextWriter textWriter)
   at Program.Main(String[] commandLineArguments)
Aborted (core dumped)
+STR
+DOC ---
+MAP
=VAL :key
=VAL :value
-MAP
-DOC ...

dotnet-yamldotnet-json

 invalid_correct
Unhandled exception. YamlDotNet.Core.SemanticErrorException: (Line: 3, Col: 1, Idx: 15) - (Line: 3, Col: 5, Idx: 19): Did not find expected <document start>.
   at YamlDotNet.Core.Parser.ParseDocumentStart(Boolean isImplicit)
   at YamlDotNet.Core.Parser.StateMachine()
   at YamlDotNet.Core.Parser.MoveNext()
   at YamlDotNet.Core.ParserExtensions.Consume[T](IParser parser)
   at YamlDotNet.Serialization.Deserializer.Deserialize(IParser parser, Type type)
   at YamlDotNet.Serialization.Deserializer.Deserialize(TextReader input, Type type)
   at YamlDotNet.Serialization.Deserializer.Deserialize(TextReader input)
   at Program.Main(String[] commandLineArguments)
Aborted (core dumped)

go-yaml-json

 invalid_correct
yaml: line 2: did not find expected <document start>
{"key":"value"}

hs-hsyaml-event

 invalid_correct
Parsing error near byte offset Pos {posByteOffset = 15, posCharOffset = 15, posLine = 3, posColumn = 0} (Unexpected '.')
+STR
+DOC ---
+MAP
=VAL :key
=VAL :value
-MAP
-DOC

hs-hsyaml-json

 invalid_correct
hsyaml-parser: user error (Unexpected '.')

java-snakeengine-event

 invalid_correct
Exception in thread "main" expected '<document start>', but found '<scalar>'
 in reader, line 3, column 5:
    ... invalid
        ^

	at org.snakeyaml.engine.v2.parser.ParserImpl$ParseDocumentStart.produce(ParserImpl.java:292)
	at org.snakeyaml.engine.v2.parser.ParserImpl.lambda$produce$0(ParserImpl.java:185)
	at java.util.Optional.ifPresent(Optional.java:159)
	at org.snakeyaml.engine.v2.parser.ParserImpl.produce(ParserImpl.java:185)
	at org.snakeyaml.engine.v2.parser.ParserImpl.hasNext(ParserImpl.java:210)
	at org.yaml.editor.SnakeEngine2Events.yamlToEvents(SnakeEngine2Events.java:15)
	at org.yaml.editor.SnakeEngine2Events.main(SnakeEngine2Events.java:23)

java-snakeengine-json

 invalid_correct
Exception in thread "main" expected '<document start>', but found '<scalar>'
 in 'reader', line 3, column 5:
    ... invalid
        ^

	at org.yaml.snakeyaml.parser.ParserImpl$ParseDocumentStart.produce(ParserImpl.java:259)
	at org.yaml.snakeyaml.parser.ParserImpl.peekEvent(ParserImpl.java:166)
	at org.yaml.snakeyaml.parser.ParserImpl.checkEvent(ParserImpl.java:156)
	at org.yaml.snakeyaml.composer.Composer.checkNode(Composer.java:90)
	at org.yaml.snakeyaml.constructor.BaseConstructor.checkData(BaseConstructor.java:124)
	at org.yaml.snakeyaml.Yaml$1.hasNext(Yaml.java:509)
	at org.yaml.editor.Snake2Json.yamlToJson(Snake2Json.java:20)
	at org.yaml.editor.Snake2Json.main(Snake2Json.java:27)
{
  "key": "value"
}

java-snakeyaml-event

 invalid_correct
Exception in thread "main" expected '<document start>', but found '<scalar>'
 in 'reader', line 3, column 5:
    ... invalid
        ^

	at org.yaml.snakeyaml.parser.ParserImpl$ParseDocumentStart.produce(ParserImpl.java:259)
	at org.yaml.snakeyaml.parser.ParserImpl.peekEvent(ParserImpl.java:166)
	at org.yaml.snakeyaml.Yaml$3.hasNext(Yaml.java:677)
	at org.yaml.editor.Snake2Events.yamlToEvents(Snake2Events.java:134)
	at org.yaml.editor.Snake2Events.main(Snake2Events.java:142)

java-snakeyaml-json

 invalid_correct
Exception in thread "main" expected '<document start>', but found '<scalar>'
 in 'reader', line 3, column 5:
    ... invalid
        ^

	at org.yaml.snakeyaml.parser.ParserImpl$ParseDocumentStart.produce(ParserImpl.java:259)
	at org.yaml.snakeyaml.parser.ParserImpl.peekEvent(ParserImpl.java:166)
	at org.yaml.snakeyaml.parser.ParserImpl.checkEvent(ParserImpl.java:156)
	at org.yaml.snakeyaml.composer.Composer.checkNode(Composer.java:90)
	at org.yaml.snakeyaml.constructor.BaseConstructor.checkData(BaseConstructor.java:124)
	at org.yaml.snakeyaml.Yaml$1.hasNext(Yaml.java:509)
	at org.yaml.editor.Snake2Json.yamlToJson(Snake2Json.java:20)
	at org.yaml.editor.Snake2Json.main(Snake2Json.java:27)
{
  "key": "value"
}

js-yaml-event

 invalid_correct
Unexpected scalar at node end at line 3, column 5:

... invalid
    ^^^^^^^
+STR
+DOC ---
+MAP
=VAL :key
=VAL :value
-MAP
-DOC ...
-STR

js-yaml-json

 invalid_correct
/yaml/bin/js-yaml-json:8
  if (doc.errors.length !== 0) throw doc.errors[0]
                               ^

YAMLParseError: Unexpected scalar at node end at line 3, column 5:

... invalid
    ^^^^^^^

    at Composer.onError (/node/node_modules/yaml/dist/compose/composer.js:71:34)
    at Object.resolveEnd (/node/node_modules/yaml/dist/compose/resolve-end.js:31:21)
    at Composer.next (/node/node_modules/yaml/dist/compose/composer.js:186:40)
    at next (<anonymous>)
    at Composer.compose (/node/node_modules/yaml/dist/compose/composer.js:134:25)
    at compose.next (<anonymous>)
    at Function.from (<anonymous>)
    at Object.parseAllDocuments (/node/node_modules/yaml/dist/public-api.js:28:24)
    at Object.<anonymous> (/yaml/bin/js-yaml-json:7:19)
    at Module._compile (internal/modules/cjs/loader.js:778:30)

lua-lyaml-json

 invalid_correct
luajit: 3:1: did not find expected <document start>
stack traceback:
	[C]: in function 'error'
	/usr/local/share/lua/5.1/lyaml/init.lua:306: in function 'error'
	/usr/local/share/lua/5.1/lyaml/init.lua:325: in function 'parse'
	/usr/local/share/lua/5.1/lyaml/init.lua:496: in function 'load'
	/yaml/bin/lua-lyaml-json:6: in main chunk
	[C]: at 0x5557a4253f97

nim-nimyaml-event

 invalid_correct
/tmp/NimYAML-0.16.0/yaml/stream.nim(134) nimyaml_event
/tmp/NimYAML-0.16.0/yaml/stream.nim(106) next
Error: unhandled exception: Unexpected character (expected line end): "i" [YamlStreamError]
+STR
+DOC ---
+MAP
=VAL :key
=VAL :value
-MAP

perl-pp-event

 invalid_correct
Line      : 3
Column    : 4
Expected  : EOL
Got       : WS
Where     : /perl5/lib/perl5/YAML/PP/Parser.pm line 392
YAML      : " invalid\n"
  at /yaml/bin/perl-pp-event line 25.
+STR
+DOC ---
+MAP
=VAL :key
=VAL :value
-MAP
-DOC ...

perl-pp-json

 invalid_correct
Line      : 3
Column    : 4
Expected  : EOL
Got       : WS
Where     : /perl5/lib/perl5/YAML/PP/Parser.pm line 392
YAML      : " invalid\n"
  at /perl5/lib/perl5/YAML/PP/Loader.pm line 94.

perl-pp-perl

 invalid_correct
Line      : 3
Column    : 4
Expected  : EOL
Got       : WS
Where     : /perl5/lib/perl5/YAML/PP/Parser.pm line 392
YAML      : " invalid\n"
  at /perl5/lib/perl5/YAML/PP/Loader.pm line 94.

perl-pplibyaml-json

 invalid_correct
YAML::PP::LibYAML Error: The problem:

    did not find expected <document start>

was found at , line: 3, column: 5

perl-pplibyaml-perl

 invalid_correct
YAML::PP::LibYAML Error: The problem:

    did not find expected <document start>

was found at , line: 3, column: 5

perl-refparser-event

 invalid_correct
Parser finished before end of input at /perl5/lib/perl5/YAML/Parser.pm line 4056, <> line 1.

perl-xs-json

 invalid_correct
YAML::XS::Load Error: The problem:

    did not find expected <document start>

was found at document: 2, line: 3, column: 5

perl-xs-perl

 invalid_correct
YAML::XS::Load Error: The problem:

    did not find expected <document start>

was found at document: 2, line: 3, column: 5

perl-yaml-json

 invalid_correct
YAML Error: Invalid element in map
   Code: YAML_LOAD_ERR_BAD_MAP_ELEMENT
   Line: 3
   Document: 1
 at /perl5/lib/perl5/YAML/Loader.pm line 360.

perl-yaml-perl

 invalid_correct
YAML Error: Invalid element in map
   Code: YAML_LOAD_ERR_BAD_MAP_ELEMENT
   Line: 3
   Document: 1
 at /perl5/lib/perl5/YAML/Loader.pm line 360.

py-pyyaml-event

 invalid_correct
Traceback (most recent call last):
  File "/yaml/bin/py-pyyaml-event", line 7, in <module>
    for event in yaml.parse(sys.stdin.read()):
  File "/python/lib/python3.7/site-packages/yaml/__init__.py", line 46, in parse
    while loader.check_event():
  File "/python/lib/python3.7/site-packages/yaml/parser.py", line 98, in check_event
    self.current_event = self.state()
  File "/python/lib/python3.7/site-packages/yaml/parser.py", line 174, in parse_document_start
    self.peek_token().start_mark)
yaml.parser.ParserError: expected '<document start>', but found '<scalar>'
  in "<unicode string>", line 3, column 5:
    ... invalid
        ^
+STR
+DOC ---
+MAP
=VAL :key
=VAL :value
-MAP
-DOC ...

py-pyyaml-json

 invalid_correct
Traceback (most recent call last):
  File "/yaml/bin/py-pyyaml-json", line 19, in <module>
    for doc in yaml.load_all(sys.stdin.read(), Loader=yaml.FullLoader):
  File "/python/lib/python3.7/site-packages/yaml/__init__.py", line 92, in load_all
    while loader.check_data():
  File "/python/lib/python3.7/site-packages/yaml/constructor.py", line 32, in check_data
    return self.check_node()
  File "/python/lib/python3.7/site-packages/yaml/composer.py", line 18, in check_node
    if self.check_event(StreamStartEvent):
  File "/python/lib/python3.7/site-packages/yaml/parser.py", line 98, in check_event
    self.current_event = self.state()
  File "/python/lib/python3.7/site-packages/yaml/parser.py", line 174, in parse_document_start
    self.peek_token().start_mark)
yaml.parser.ParserError: expected '<document start>', but found '<scalar>'
  in "<unicode string>", line 3, column 5:
    ... invalid
        ^
{
  "key": "value"
}

py-pyyaml-py

 invalid_correct
Traceback (most recent call last):
  File "/yaml/bin/py-pyyaml-py", line 36, in <module>
    for doc in yaml.load_all(sys.stdin.read(), Loader=yaml.FullLoader):
  File "/python/lib/python3.7/site-packages/yaml/__init__.py", line 92, in load_all
    while loader.check_data():
  File "/python/lib/python3.7/site-packages/yaml/constructor.py", line 32, in check_data
    return self.check_node()
  File "/python/lib/python3.7/site-packages/yaml/composer.py", line 18, in check_node
    if self.check_event(StreamStartEvent):
  File "/python/lib/python3.7/site-packages/yaml/parser.py", line 98, in check_event
    self.current_event = self.state()
  File "/python/lib/python3.7/site-packages/yaml/parser.py", line 174, in parse_document_start
    self.peek_token().start_mark)
yaml.parser.ParserError: expected '<document start>', but found '<scalar>'
  in "<unicode string>", line 3, column 5:
    ... invalid
        ^
{'key': 'value'}

raku-yamlish-json

 invalid_correct
Couldn't parse YAML
  in sub load-yamls at /raku/sources/44795C7AB0F35700F4CA9C3E2CC5C924EE4C608F (YAMLish) line 959
  in block <unit> at /yaml/bin/raku-yamlish-json line 6

raku-yamlish-raku

 invalid_correct
Couldn't parse YAML
  in sub load-yamls at /raku/sources/44795C7AB0F35700F4CA9C3E2CC5C924EE4C608F (YAMLish) line 959
  in block <unit> at /yaml/bin/raku-yamlish-raku line 6

ruby-psych-json

 invalid_correct
/ruby/gems/psych/lib/psych.rb:459:in `parse': (<unknown>): did not find expected <document start> at line 1 column 1 (Psych::SyntaxError)
	from /ruby/gems/psych/lib/psych.rb:459:in `parse_stream'
	from /ruby/gems/psych/lib/psych.rb:565:in `load_stream'
	from /yaml/bin/ruby-psych-json:6:in `<main>'

rust-yamlrust-event

 invalid_correct
Error: ScanError { mark: Marker { index: 19, line: 3, col: 4 }, info: "did not find expected <document start>" }
+STR
+DOC
+MAP
=VAL :key
=VAL :value
-MAP
-DOC