# 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-yamlcpp-event

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

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.SyntaxErrorException: (Line: 3, Col: 1, Idx: 15) - (Line: 3, Col: 5, Idx: 19): While scanning a document end, found invalid content after '...' marker.
   at YamlDotNet.Core.Scanner.FetchDocumentIndicator(Boolean isStartToken)
   at YamlDotNet.Core.Scanner.FetchNextToken()
   at YamlDotNet.Core.Scanner.FetchMoreTokens()
   at YamlDotNet.Core.Scanner.MoveNextWithoutConsuming()
   at YamlDotNet.Core.Parser.GetCurrentToken()
   at YamlDotNet.Core.Parser.ParseBlockMappingKey(Boolean isFirst)
   at YamlDotNet.Core.Parser.StateMachine()
   at YamlDotNet.Core.Parser.MoveNext()
   at Program.ConvertToLibYamlStyleAnnotatedEventStream(TextReader textReader, TextWriter textWriter)
   at Program.Main(String[] commandLineArguments)
Aborted (core dumped)
+STR
+DOC ---
+MAP
=VAL :key
=VAL :value

dotnet-yamldotnet-json

 invalid_correct
Unhandled exception. YamlDotNet.Core.SyntaxErrorException: (Line: 3, Col: 1, Idx: 15) - (Line: 3, Col: 5, Idx: 19): While scanning a document end, found invalid content after '...' marker.
   at YamlDotNet.Core.Scanner.FetchDocumentIndicator(Boolean isStartToken)
   at YamlDotNet.Core.Scanner.FetchNextToken()
   at YamlDotNet.Core.Scanner.FetchMoreTokens()
   at YamlDotNet.Core.Scanner.MoveNextWithoutConsuming()
   at YamlDotNet.Core.Parser.GetCurrentToken()
   at YamlDotNet.Core.Parser.ParseBlockMappingKey(Boolean isFirst)
   at YamlDotNet.Core.Parser.StateMachine()
   at YamlDotNet.Core.Parser.MoveNext()
   at YamlDotNet.Core.ParserExtensions.Allow[T](IParser parser)
   at YamlDotNet.Serialization.NodeDeserializers.ScalarNodeDeserializer.YamlDotNet.Serialization.INodeDeserializer.Deserialize(IParser parser, Type expectedType, Func`3 nestedObjectDeserializer, Object& value)
   at YamlDotNet.Serialization.ValueDeserializers.NodeValueDeserializer.DeserializeValue(IParser parser, Type expectedType, SerializerState state, IValueDeserializer nestedObjectDeserializer)
   at YamlDotNet.Serialization.ValueDeserializers.AliasValueDeserializer.DeserializeValue(IParser parser, Type expectedType, SerializerState state, IValueDeserializer nestedObjectDeserializer)
   at YamlDotNet.Serialization.ValueDeserializers.NodeValueDeserializer.<>c__DisplayClass3_0.<DeserializeValue>b__0(IParser r, Type t)
   at YamlDotNet.Serialization.NodeDeserializers.DictionaryNodeDeserializer.DeserializeHelper(Type tKey, Type tValue, IParser parser, Func`3 nestedObjectDeserializer, IDictionary result)
   at YamlDotNet.Serialization.NodeDeserializers.DictionaryNodeDeserializer.YamlDotNet.Serialization.INodeDeserializer.Deserialize(IParser parser, Type expectedType, Func`3 nestedObjectDeserializer, Object& value)
   at YamlDotNet.Serialization.ValueDeserializers.NodeValueDeserializer.DeserializeValue(IParser parser, Type expectedType, SerializerState state, IValueDeserializer nestedObjectDeserializer)
   at YamlDotNet.Serialization.ValueDeserializers.AliasValueDeserializer.DeserializeValue(IParser parser, Type expectedType, SerializerState state, IValueDeserializer nestedObjectDeserializer)
   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)

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-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:226)
	at org.yaml.snakeyaml.parser.ParserImpl.peekEvent(ParserImpl.java:158)
	at org.yaml.snakeyaml.Yaml$3.hasNext(Yaml.java:654)
	at org.yaml.editor.Snake2Events.yamlToEvents(Snake2Events.java:111)
	at org.yaml.editor.Snake2Events.main(Snake2Events.java:119)

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:226)
	at org.yaml.snakeyaml.parser.ParserImpl.peekEvent(ParserImpl.java:158)
	at org.yaml.snakeyaml.parser.ParserImpl.checkEvent(ParserImpl.java:148)
	at org.yaml.snakeyaml.composer.Composer.checkNode(Composer.java:78)
	at org.yaml.snakeyaml.constructor.BaseConstructor.checkData(BaseConstructor.java:123)
	at org.yaml.snakeyaml.Yaml$1.hasNext(Yaml.java:489)
	at org.yaml.editor.Snake2Json.yamlToJson(Snake2Json.java:18)
	at org.yaml.editor.Snake2Json.main(Snake2Json.java:25)
{
  "key": "value"
}

js-yaml-event

 invalid_correct
Document end marker line cannot have a non-comment suffix
+STR

js-yaml-json

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

YAMLSyntaxError: Document end marker line cannot have a non-comment suffix
    at Document.parseContents (/node/node_modules/yaml/dist/parse-cst.js:662:26)
    at Document.parse (/node/node_modules/yaml/dist/parse-cst.js:685:19)
    at Object.parse (/node/node_modules/yaml/dist/parse-cst.js:1723:18)
    at Object.parseAllDocuments (/node/node_modules/yaml/dist/index.js:32:33)
    at Object.<anonymous> (/yaml/bin/js-yaml-json:7:19)
    at Module._compile (internal/modules/cjs/loader.js:778:30)
    at Object.Module._extensions..js (internal/modules/cjs/loader.js:789:10)
    at Module.load (internal/modules/cjs/loader.js:653:32)
    at tryModuleLoad (internal/modules/cjs/loader.js:593:12)
    at Function.Module._load (internal/modules/cjs/loader.js:585:3)

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:291: in function 'error'
	/usr/local/share/lua/5.1/lyaml/init.lua:310: in function 'parse'
	/usr/local/share/lua/5.1/lyaml/init.lua:481: in function 'load'
	/yaml/bin/lua-lyaml-json:6: in main chunk
	[C]: at 0x5568f996cf97

nim-nimyaml-event

 invalid_correct
/buildutils/nimyaml_event.nim(8) nimyaml_event
/tmp/NimYAML-0.13.1/yaml/stream.nim(223) finished
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 386
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 386
YAML      : " invalid\n"
  at /perl5/lib/perl5/YAML/PP/Loader.pm line 92.

perl-pp-perl

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

perl-pplibyaml-event

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

    did not find expected <document start>

was found at , line: 3, column: 5

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-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 75, 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 129, 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 129, 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'}

ruby-psych-json

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