JasonWoof Got questions, comments, patches, etc.? Contact Jason Woofenden
fix most fragment tests, fix tree bugs
authorJason Woofenden <jason@jasonwoof.com>
Wed, 23 Dec 2015 21:05:59 +0000 (16:05 -0500)
committerJason Woofenden <jason@jasonwoof.com>
Wed, 23 Dec 2015 21:05:59 +0000 (16:05 -0500)
parse-html.coffee
test.coffee

index d452803..255892f 100644 (file)
@@ -1395,6 +1395,7 @@ parse_html = (args) ->
                        el = insert_html_element t
                        head_element_pointer = el
                        ins_mode = ins_mode_in_head
+                       return
                if t.type is TYPE_END_TAG
                        if t.name is 'head' or t.name is 'body' or t.name is 'html' or t.name is 'br'
                                # fall through to Anything else below
@@ -3735,7 +3736,7 @@ parse_html = (args) ->
                        return
                # Otherwise
                parse_error()
-               tok_cur_tag = new_comment_token '!' # TODO test ("!" right?)
+               tok_cur_tag = new_comment_token ''
                tok_state = tok_state_bogus_comment
                return
 
@@ -4413,6 +4414,8 @@ parse_html = (args) ->
        # tokenizer initialization
        tok_state = tok_state_data
 
+       if args.name is "one_that_breaks #1"
+               throw "hi" # console.log "hi"
        # proccess input
        # http://www.w3.org/TR/html5/syntax.html#tree-construction
        while flag_parsing
index 289f46d..69fb3f6 100644 (file)
@@ -1120,12 +1120,14 @@ tests = [
        }, {
                name: "foreign-fragment.dat #1"
                html: "<nobr>X"
-               errors: 3,"document-fragment":"svg path"
+               errors: 3
+               fragment: "svg path"
                expected: "| <svg nobr>\n|   \"X\"\n"
        }, {
                name: "foreign-fragment.dat #2"
                html: "<font color></font>X"
-               errors: 1,"document-fragment":"svg path"
+               errors: 1
+               fragment: "svg path"
                expected: "| <svg font>\n|   color=\"\"\n| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #3"
@@ -1135,82 +1137,98 @@ tests = [
        }, {
                name: "foreign-fragment.dat #4"
                html: "<g></path>X"
-               errors: 3,"document-fragment":"svg path"
+               errors: 3
+               fragment: "svg path"
                expected: "| <svg g>\n|   \"X\"\n"
        }, {
                name: "foreign-fragment.dat #5"
                html: "</path>X"
-               errors: 1,"document-fragment":"svg path"
+               errors: 1
+               fragment: "svg path"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #6"
                html: "</foreignObject>X"
-               errors: 1,"document-fragment":"svg foreignObject"
+               errors: 1
+               fragment: "svg foreignObject"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #7"
                html: "</desc>X"
-               errors: 1,"document-fragment":"svg desc"
+               errors: 1
+               fragment: "svg desc"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #8"
                html: "</title>X"
-               errors: 1,"document-fragment":"svg title"
+               errors: 1
+               fragment: "svg title"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #9"
                html: "</svg>X"
-               errors: 1,"document-fragment":"svg svg"
+               errors: 1
+               fragment: "svg svg"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #10"
                html: "</mfenced>X"
-               errors: 1,"document-fragment":"math mfenced"
+               errors: 1
+               fragment: "math mfenced"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #11"
                html: "</malignmark>X"
-               errors: 1,"document-fragment":"math malignmark"
+               errors: 1
+               fragment: "math malignmark"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #12"
                html: "</math>X"
-               errors: 1,"document-fragment":"math math"
+               errors: 1
+               fragment: "math math"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #13"
                html: "</annotation-xml>X"
-               errors: 1,"document-fragment":"math annotation-xml"
+               errors: 1
+               fragment: "math annotation-xml"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #14"
                html: "</mtext>X"
-               errors: 1,"document-fragment":"math mtext"
+               errors: 1
+               fragment: "math mtext"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #15"
                html: "</mi>X"
-               errors: 1,"document-fragment":"math mi"
+               errors: 1
+               fragment: "math mi"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #16"
                html: "</mo>X"
-               errors: 1,"document-fragment":"math mo"
+               errors: 1
+               fragment: "math mo"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #17"
                html: "</mn>X"
-               errors: 1,"document-fragment":"math mn"
+               errors: 1
+               fragment: "math mn"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #18"
                html: "</ms>X"
-               errors: 1,"document-fragment":"math ms"
+               errors: 1
+               fragment: "math ms"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #19"
                html: "<b></b><mglyph/><i></i><malignmark/><u></u><ms/>X"
-               errors: 3,"document-fragment":"math ms"
+               errors: 3
+               fragment: "math ms"
                expected: "| <b>\n| <math mglyph>\n| <i>\n| <math malignmark>\n| <u>\n| <ms>\n|   \"X\"\n"
        }, {
                name: "foreign-fragment.dat #20"
@@ -1230,7 +1248,8 @@ tests = [
        }, {
                name: "foreign-fragment.dat #23"
                html: "<b></b><mglyph/><i></i><malignmark/><u></u><mn/>X"
-               errors: 3,"document-fragment":"math mn"
+               errors: 3
+               fragment: "math mn"
                expected: "| <b>\n| <math mglyph>\n| <i>\n| <math malignmark>\n| <u>\n| <mn>\n|   \"X\"\n"
        }, {
                name: "foreign-fragment.dat #24"
@@ -1250,7 +1269,8 @@ tests = [
        }, {
                name: "foreign-fragment.dat #27"
                html: "<b></b><mglyph/><i></i><malignmark/><u></u><mo/>X"
-               errors: 3,"document-fragment":"math mo"
+               errors: 3
+               fragment: "math mo"
                expected: "| <b>\n| <math mglyph>\n| <i>\n| <math malignmark>\n| <u>\n| <mo>\n|   \"X\"\n"
        }, {
                name: "foreign-fragment.dat #28"
@@ -1270,7 +1290,8 @@ tests = [
        }, {
                name: "foreign-fragment.dat #31"
                html: "<b></b><mglyph/><i></i><malignmark/><u></u><mi/>X"
-               errors: 3,"document-fragment":"math mi"
+               errors: 3
+               fragment: "math mi"
                expected: "| <b>\n| <math mglyph>\n| <i>\n| <math malignmark>\n| <u>\n| <mi>\n|   \"X\"\n"
        }, {
                name: "foreign-fragment.dat #32"
@@ -1290,7 +1311,8 @@ tests = [
        }, {
                name: "foreign-fragment.dat #35"
                html: "<b></b><mglyph/><i></i><malignmark/><u></u><mtext/>X"
-               errors: 3,"document-fragment":"math mtext"
+               errors: 3
+               fragment: "math mtext"
                expected: "| <b>\n| <math mglyph>\n| <i>\n| <math malignmark>\n| <u>\n| <mtext>\n|   \"X\"\n"
        }, {
                name: "foreign-fragment.dat #36"
@@ -1310,7 +1332,8 @@ tests = [
        }, {
                name: "foreign-fragment.dat #39"
                html: "<div></div>"
-               errors: 1,"document-fragment":"math annotation-xml"
+               errors: 1
+               fragment: "math annotation-xml"
                expected: "| <math div>\n"
        }, {
                name: "foreign-fragment.dat #40"
@@ -1320,7 +1343,8 @@ tests = [
        }, {
                name: "foreign-fragment.dat #41"
                html: "<div></div>"
-               errors: 1,"document-fragment":"math math"
+               errors: 1
+               fragment: "math math"
                expected: "| <math div>\n"
        }, {
                name: "foreign-fragment.dat #42"
@@ -1355,12 +1379,14 @@ tests = [
        }, {
                name: "foreign-fragment.dat #48"
                html: "<div><h1>X</h1></div>"
-               errors: 2,"document-fragment":"svg svg"
+               errors: 2
+               fragment: "svg svg"
                expected: "| <svg div>\n|   <svg h1>\n|     \"X\"\n"
        }, {
                name: "foreign-fragment.dat #49"
                html: "<div></div>"
-               errors: 1,"document-fragment":"svg svg"
+               errors: 1
+               fragment: "svg svg"
                expected: "| <svg div>\n"
        }, {
                name: "foreign-fragment.dat #50"
@@ -1375,37 +1401,44 @@ tests = [
        }, {
                name: "foreign-fragment.dat #52"
                html: "<plaintext><foo>"
-               errors: 2,"document-fragment":"svg desc"
+               errors: 2
+               fragment: "svg desc"
                expected: "| <plaintext>\n|   \"<foo>\"\n"
        }, {
                name: "foreign-fragment.dat #53"
                html: "<frameset>X"
-               errors: 1,"document-fragment":"svg desc"
+               errors: 1
+               fragment: "svg desc"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #54"
                html: "<head>X"
-               errors: 1,"document-fragment":"svg desc"
+               errors: 1
+               fragment: "svg desc"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #55"
                html: "<body>X"
-               errors: 1,"document-fragment":"svg desc"
+               errors: 1
+               fragment: "svg desc"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #56"
                html: "<html>X"
-               errors: 1,"document-fragment":"svg desc"
+               errors: 1
+               fragment: "svg desc"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #57"
                html: "<html class=\"foo\">X"
-               errors: 1,"document-fragment":"svg desc"
+               errors: 1
+               fragment: "svg desc"
                expected: "| \"X\"\n"
        }, {
                name: "foreign-fragment.dat #58"
                html: "<body class=\"foo\">X"
-               errors: 1,"document-fragment":"svg desc"
+               errors: 1
+               fragment: "svg desc"
                expected: "| \"X\"\n"
        }, {
                name: "html5test-com.dat #1"
@@ -6441,7 +6474,8 @@ tests = [
        }, {
                name: "tests6.dat #7"
                html: "<body>\n<div>"
-               errors: 2,"document-fragment":"div"
+               errors: 2
+               fragment: "div"
                expected: "| \"\n\"\n| <div>\n"
        }, {
                name: "tests6.dat #8"
@@ -6496,7 +6530,8 @@ tests = [
        }, {
                name: "tests6.dat #18"
                html: "</caption><div>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <div>\n"
        }, {
                name: "tests6.dat #19"
@@ -6511,7 +6546,8 @@ tests = [
        }, {
                name: "tests6.dat #21"
                html: "</table><div>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <div>\n"
        }, {
                name: "tests6.dat #22"
@@ -6531,7 +6567,8 @@ tests = [
        }, {
                name: "tests6.dat #25"
                html: "</table></tbody></tfoot></thead></tr><div>"
-               errors: 6,"document-fragment":"td"
+               errors: 6
+               fragment: "td"
                expected: "| <div>\n"
        }, {
                name: "tests6.dat #26"
@@ -6541,7 +6578,8 @@ tests = [
        }, {
                name: "tests6.dat #27"
                html: "foo<col>"
-               errors: 3,"document-fragment":"colgroup"
+               errors: 3
+               fragment: "colgroup"
                expected: "| <col>\n"
        }, {
                name: "tests6.dat #28"
@@ -6556,7 +6594,8 @@ tests = [
        }, {
                name: "tests6.dat #30"
                html: "</frameset><frame>"
-               errors: 1,"document-fragment":"frameset"
+               errors: 1
+               fragment: "frameset"
                expected: "| <frame>\n"
        }, {
                name: "tests6.dat #31"
@@ -6566,7 +6605,8 @@ tests = [
        }, {
                name: "tests6.dat #32"
                html: "</body><div>"
-               errors: 2,"document-fragment":"body"
+               errors: 2
+               fragment: "body"
                expected: "| <div>\n"
        }, {
                name: "tests6.dat #33"
@@ -6576,12 +6616,14 @@ tests = [
        }, {
                name: "tests6.dat #34"
                html: "</tr><td>"
-               errors: 1,"document-fragment":"tr"
+               errors: 1
+               fragment: "tr"
                expected: "| <td>\n"
        }, {
                name: "tests6.dat #35"
                html: "</tbody></tfoot></thead><td>"
-               errors: 3,"document-fragment":"tr"
+               errors: 3
+               fragment: "tr"
                expected: "| <td>\n"
        }, {
                name: "tests6.dat #36"
@@ -6591,7 +6633,8 @@ tests = [
        }, {
                name: "tests6.dat #37"
                html: "<caption><col><colgroup><tbody><tfoot><thead><tr>"
-               errors: 6,"document-fragment":"tbody"
+               errors: 6
+               fragment: "tbody"
                expected: "| <tr>\n"
        }, {
                name: "tests6.dat #38"
@@ -6601,7 +6644,8 @@ tests = [
        }, {
                name: "tests6.dat #39"
                html: "</table><tr>"
-               errors: 1,"document-fragment":"tbody"
+               errors: 1
+               fragment: "tbody"
                expected: "| <tr>\n"
        }, {
                name: "tests6.dat #40"
@@ -6626,12 +6670,14 @@ tests = [
        }, {
                name: "tests6.dat #44"
                html: "</table><tr>"
-               errors: 1,"document-fragment":"table"
+               errors: 1
+               fragment: "table"
                expected: "| <tbody>\n|   <tr>\n"
        }, {
                name: "tests6.dat #45"
                html: "<body></body></html>"
-               errors: 1,"document-fragment":"html"
+               errors: 1
+               fragment: "html"
                expected: "| <head>\n| <body>\n"
        }, {
                name: "tests6.dat #46"
@@ -6779,7 +6825,8 @@ tests = [
        }, {
                name: "tests7.dat #25"
                html: "<body>X</body></body>"
-               errors: 1,"document-fragment":"html"
+               errors: 1
+               fragment: "html"
                expected: "| <head>\n| <body>\n|   \"X\"\n"
        }, {
                name: "tests7.dat #26"
@@ -6985,302 +7032,362 @@ tests = [
        }, {
                name: "tests_innerHTML_1.dat #1"
                html: "<body><span>"
-               errors: 2,"document-fragment":"body"
+               errors: 2
+               fragment: "body"
                expected: "| <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #2"
                html: "<span><body>"
-               errors: 2,"document-fragment":"body"
+               errors: 2
+               fragment: "body"
                expected: "| <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #3"
                html: "<span><body>"
-               errors: 2,"document-fragment":"div"
+               errors: 2
+               fragment: "div"
                expected: "| <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #4"
                html: "<body><span>"
-               errors: 1,"document-fragment":"html"
+               errors: 1
+               fragment: "html"
                expected: "| <head>\n| <body>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #5"
                html: "<frameset><span>"
-               errors: 2,"document-fragment":"body"
+               errors: 2
+               fragment: "body"
                expected: "| <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #6"
                html: "<span><frameset>"
-               errors: 2,"document-fragment":"body"
+               errors: 2
+               fragment: "body"
                expected: "| <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #7"
                html: "<span><frameset>"
-               errors: 2,"document-fragment":"div"
+               errors: 2
+               fragment: "div"
                expected: "| <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #8"
                html: "<frameset><span>"
-               errors: 2,"document-fragment":"html"
+               errors: 2
+               fragment: "html"
                expected: "| <head>\n| <frameset>\n"
        }, {
                name: "tests_innerHTML_1.dat #9"
                html: "<table><tr>"
-               errors: 1,"document-fragment":"table"
+               errors: 1
+               fragment: "table"
                expected: "| <tbody>\n|   <tr>\n"
        }, {
                name: "tests_innerHTML_1.dat #10"
                html: "</table><tr>"
-               errors: 1,"document-fragment":"table"
+               errors: 1
+               fragment: "table"
                expected: "| <tbody>\n|   <tr>\n"
        }, {
                name: "tests_innerHTML_1.dat #11"
                html: "<a>"
-               errors: 2,"document-fragment":"table"
+               errors: 2
+               fragment: "table"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #12"
                html: "<a>"
-               errors: 2,"document-fragment":"table"
+               errors: 2
+               fragment: "table"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #13"
                html: "<a><caption>a"
-               errors: 2,"document-fragment":"table"
+               errors: 2
+               fragment: "table"
                expected: "| <a>\n| <caption>\n|   \"a\"\n"
        }, {
                name: "tests_innerHTML_1.dat #14"
                html: "<a><colgroup><col>"
-               errors: 2,"document-fragment":"table"
+               errors: 2
+               fragment: "table"
                expected: "| <a>\n| <colgroup>\n|   <col>\n"
        }, {
                name: "tests_innerHTML_1.dat #15"
                html: "<a><tbody><tr>"
-               errors: 1,"document-fragment":"table"
+               errors: 1
+               fragment: "table"
                expected: "| <a>\n| <tbody>\n|   <tr>\n"
        }, {
                name: "tests_innerHTML_1.dat #16"
                html: "<a><tfoot><tr>"
-               errors: 1,"document-fragment":"table"
+               errors: 1
+               fragment: "table"
                expected: "| <a>\n| <tfoot>\n|   <tr>\n"
        }, {
                name: "tests_innerHTML_1.dat #17"
                html: "<a><thead><tr>"
-               errors: 1,"document-fragment":"table"
+               errors: 1
+               fragment: "table"
                expected: "| <a>\n| <thead>\n|   <tr>\n"
        }, {
                name: "tests_innerHTML_1.dat #18"
                html: "<a><tr>"
-               errors: 1,"document-fragment":"table"
+               errors: 1
+               fragment: "table"
                expected: "| <a>\n| <tbody>\n|   <tr>\n"
        }, {
                name: "tests_innerHTML_1.dat #19"
                html: "<a><th>"
-               errors: 2,"document-fragment":"table"
+               errors: 2
+               fragment: "table"
                expected: "| <a>\n| <tbody>\n|   <tr>\n|     <th>\n"
        }, {
                name: "tests_innerHTML_1.dat #20"
                html: "<a><td>"
-               errors: 2,"document-fragment":"table"
+               errors: 2
+               fragment: "table"
                expected: "| <a>\n| <tbody>\n|   <tr>\n|     <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #21"
                html: "<table></table><tbody>"
-               errors: 1,"document-fragment":"caption"
+               errors: 1
+               fragment: "caption"
                expected: "| <table>\n"
        }, {
                name: "tests_innerHTML_1.dat #22"
                html: "</table><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #23"
                html: "<span></table>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #24"
                html: "</caption><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #25"
                html: "<span></caption><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #26"
                html: "<span><caption><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #27"
                html: "<span><col><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #28"
                html: "<span><colgroup><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #29"
                html: "<span><html><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #30"
                html: "<span><tbody><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #31"
                html: "<span><td><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #32"
                html: "<span><tfoot><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #33"
                html: "<span><thead><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #34"
                html: "<span><th><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #35"
                html: "<span><tr><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #36"
                html: "<span></table><span>"
-               errors: 2,"document-fragment":"caption"
+               errors: 2
+               fragment: "caption"
                expected: "| <span>\n|   <span>\n"
        }, {
                name: "tests_innerHTML_1.dat #37"
                html: "</colgroup><col>"
-               errors: 1,"document-fragment":"colgroup"
+               errors: 1
+               fragment: "colgroup"
                expected: "| <col>\n"
        }, {
                name: "tests_innerHTML_1.dat #38"
                html: "<a><col>"
-               errors: 1,"document-fragment":"colgroup"
+               errors: 1
+               fragment: "colgroup"
                expected: "| <col>\n"
        }, {
                name: "tests_innerHTML_1.dat #39"
                html: "<caption><a>"
-               errors: 3,"document-fragment":"tbody"
+               errors: 3
+               fragment: "tbody"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #40"
                html: "<col><a>"
-               errors: 3,"document-fragment":"tbody"
+               errors: 3
+               fragment: "tbody"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #41"
                html: "<colgroup><a>"
-               errors: 3,"document-fragment":"tbody"
+               errors: 3
+               fragment: "tbody"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #42"
                html: "<tbody><a>"
-               errors: 3,"document-fragment":"tbody"
+               errors: 3
+               fragment: "tbody"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #43"
                html: "<tfoot><a>"
-               errors: 3,"document-fragment":"tbody"
+               errors: 3
+               fragment: "tbody"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #44"
                html: "<thead><a>"
-               errors: 3,"document-fragment":"tbody"
+               errors: 3
+               fragment: "tbody"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #45"
                html: "</table><a>"
-               errors: 3,"document-fragment":"tbody"
+               errors: 3
+               fragment: "tbody"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #46"
                html: "<a><tr>"
-               errors: 1,"document-fragment":"tbody"
+               errors: 1
+               fragment: "tbody"
                expected: "| <a>\n| <tr>\n"
        }, {
                name: "tests_innerHTML_1.dat #47"
                html: "<a><td>"
-               errors: 2,"document-fragment":"tbody"
+               errors: 2
+               fragment: "tbody"
                expected: "| <a>\n| <tr>\n|   <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #48"
                html: "<a><td>"
-               errors: 2,"document-fragment":"tbody"
+               errors: 2
+               fragment: "tbody"
                expected: "| <a>\n| <tr>\n|   <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #49"
                html: "<a><td>"
-               errors: 2,"document-fragment":"tbody"
+               errors: 2
+               fragment: "tbody"
                expected: "| <a>\n| <tr>\n|   <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #50"
                html: "<td><table><tbody><a><tr>"
-               errors: 3,"document-fragment":"tbody"
+               errors: 3
+               fragment: "tbody"
                expected: "| <tr>\n|   <td>\n|     <a>\n|     <table>\n|       <tbody>\n|         <tr>\n"
        }, {
                name: "tests_innerHTML_1.dat #51"
                html: "</tr><td>"
-               errors: 1,"document-fragment":"tr"
+               errors: 1
+               fragment: "tr"
                expected: "| <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #52"
                html: "<td><table><a><tr></tr><tr>"
-               errors: 2,"document-fragment":"tr"
+               errors: 2
+               fragment: "tr"
                expected: "| <td>\n|   <a>\n|   <table>\n|     <tbody>\n|       <tr>\n|       <tr>\n"
        }, {
                name: "tests_innerHTML_1.dat #53"
                html: "<caption><td>"
-               errors: 1,"document-fragment":"tr"
+               errors: 1
+               fragment: "tr"
                expected: "| <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #54"
                html: "<col><td>"
-               errors: 1,"document-fragment":"tr"
+               errors: 1
+               fragment: "tr"
                expected: "| <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #55"
                html: "<colgroup><td>"
-               errors: 1,"document-fragment":"tr"
+               errors: 1
+               fragment: "tr"
                expected: "| <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #56"
                html: "<tbody><td>"
-               errors: 1,"document-fragment":"tr"
+               errors: 1
+               fragment: "tr"
                expected: "| <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #57"
                html: "<tfoot><td>"
-               errors: 1,"document-fragment":"tr"
+               errors: 1
+               fragment: "tr"
                expected: "| <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #58"
                html: "<thead><td>"
-               errors: 1,"document-fragment":"tr"
+               errors: 1
+               fragment: "tr"
                expected: "| <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #59"
                html: "<tr><td>"
-               errors: 1,"document-fragment":"tr"
+               errors: 1
+               fragment: "tr"
                expected: "| <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #60"
                html: "</table><td>"
-               errors: 1,"document-fragment":"tr"
+               errors: 1
+               fragment: "tr"
                expected: "| <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #61"
@@ -7295,112 +7402,134 @@ tests = [
        }, {
                name: "tests_innerHTML_1.dat #63"
                html: "<caption><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #64"
                html: "<col><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #65"
                html: "<colgroup><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #66"
                html: "<tbody><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #67"
                html: "<tfoot><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #68"
                html: "<th><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #69"
                html: "<thead><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #70"
                html: "<tr><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #71"
                html: "</table><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #72"
                html: "</tbody><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #73"
                html: "</td><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #74"
                html: "</tfoot><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #75"
                html: "</thead><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #76"
                html: "</th><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #77"
                html: "</tr><a>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <a>\n"
        }, {
                name: "tests_innerHTML_1.dat #78"
                html: "<table><td><td>"
-               errors: 2,"document-fragment":"td"
+               errors: 2
+               fragment: "td"
                expected: "| <table>\n|   <tbody>\n|     <tr>\n|       <td>\n|       <td>\n"
        }, {
                name: "tests_innerHTML_1.dat #79"
                html: "</select><option>"
-               errors: 2,"document-fragment":"select"
+               errors: 2
+               fragment: "select"
                expected: "| <option>\n"
        }, {
                name: "tests_innerHTML_1.dat #80"
                html: "<input><option>"
-               errors: 2,"document-fragment":"select"
+               errors: 2
+               fragment: "select"
                expected: "| <option>\n"
        }, {
                name: "tests_innerHTML_1.dat #81"
                html: "<keygen><option>"
-               errors: 2,"document-fragment":"select"
+               errors: 2
+               fragment: "select"
                expected: "| <option>\n"
        }, {
                name: "tests_innerHTML_1.dat #82"
                html: "<textarea><option>"
-               errors: 2,"document-fragment":"select"
+               errors: 2
+               fragment: "select"
                expected: "| <option>\n"
        }, {
                name: "tests_innerHTML_1.dat #83"
                html: "</html><!--abc-->"
-               errors: 1,"document-fragment":"html"
+               errors: 1
+               fragment: "html"
                expected: "| <head>\n| <body>\n| <!-- abc -->\n"
        }, {
                name: "tests_innerHTML_1.dat #84"
                html: "</frameset><frame>"
-               errors: 1,"document-fragment":"frameset"
+               errors: 1
+               fragment: "frameset"
                expected: "| <frame>\n"
        }, {
                name: "tests_innerHTML_1.dat #85"
@@ -7856,22 +7985,23 @@ test_parser = (args) ->
        parsed = wheic.parse_html args
        serialized = serialize_els parsed
        if serialized isnt args.expected
-               #wheic.debug_log_each (str) ->
-               #       console.log str
-               console.log "FAILED: \"#{args.name}\""
-               console.log "      Input: #{args.html}"
-               if args.fragment?
-                       console.log "   Fragment: #{args.fragment}"
-               console.log "    Correct: #{args.expected}"
-               console.log "     Output: #{serialized}"
-               if parse_errors.length > 0
-                       console.log " parse errs: #{JSON.stringify parse_errors}"
-               else
-                       console.log "   No parse errors"
                test_results.failed += 1
+               if test_results.failed is 1
+                       wheic.debug_log_each (str) ->
+                               console.log str
+                       console.log "FAILED: \"#{args.name}\""
+                       console.log "      Input: #{args.html}"
+                       if args.fragment?
+                               console.log "   Fragment: #{args.fragment}"
+                       console.log "    Correct: #{args.expected}"
+                       console.log "     Output: #{serialized}"
+                       if parse_errors.length > 0
+                               console.log " parse errs: #{JSON.stringify parse_errors}"
+                       else
+                               console.log "   No parse errors"
        else
-               console.log "passed \"#{args.name}\""
                test_results.passed += 1
+               # console.log "passed \"#{args.name}\""
 test_summary = ->
        console.log "Tests passed: #{test_results.passed}, Failed: #{test_results.failed}, ignored: #{test_results.fragment}"