From 6b7e5d77471631d193745d167970de888c75e84a Mon Sep 17 00:00:00 2001
From: Sam Mikes <smikes@cubane.com>
Date: Fri, 1 Aug 2014 12:35:15 +0100
Subject: [PATCH] bestPractice: supply error names to negative

pilot directory for replacing flags: [negative] with
negative: errorname

ch07-7.2,7.3: add error names
ch07-rest: insert error names rest of ch07
ch08: add expected error name
ch11: add error name to negative
ch12: put error name in negative

ch13: add error name to negative
only one test, did it manually

ch15: add error name to negative:

ch07: add error name to negative

these tests used flags: \n - negative and so
were not caught by the earlier naive grep for flags: [negative]

--- changes suggested by @anba

bestPractice - remove added NotEarlyError
ch07,ch11 - expect ReferenceError (req'd by ES6)
correct test descriptions to expect ReferenceError only
enforce parsing as block statement by adding `;`
remove needless include of $FAIL.js

effectively, a rebase of all changes onto master

    Merge branch 'negative-addErrorName-work' into negative-addErrorName-bestPractice

    Merge branch 'saved-bestPractice-negative' into negative-addErrorName-work

    Conflicts:
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T2.js
    	test/suite/ch12/12.1/S12.1_A4_T1.js
    	test/suite/ch12/12.5/S12.5_A2.js

    incorporate changes made on PR branch

    re-remove added NotEarlyError

    Merge branch 'negative-addErrorName-work' into negative-addErrorName-bestPractice

    Conflicts:
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T2.js
    	test/suite/ch12/12.1/S12.1_A4_T1.js
    	test/suite/ch12/12.5/S12.5_A2.js

    ch15: correct negative regexes

    ch10: avoid use of not-NotEarlyError regex

    ch14 error regexps

    ch13 error regexps

    ch12: negative error matching

    Merge branch 'console-runner-checkError' into negative-addErrorName-work

    test262.py: check negative tests with regex

    implement checking of negative tests =>

    negative: SyntaxError

    means that /SyntaxError/ must match stderr
    or test is reported as failure

    Fixes #78

    expect real errors

    bestPractice: supply error names to negative

    pilot directory for replacing flags: [negative] with
    negative: errorname

    ch07-7.2,7.3: add error names
    ch07-rest: insert error names rest of ch07
    ch08: add expected error name
    ch11: add error name to negative
    ch12: put error name in negative

    ch13: add error name to negative
    only one test, did it manually

    ch15: add error name to negative:

    ch07: add error name to negative

    these tests used flags: \n - negative and so
    were not caught by the earlier naive grep for flags: [negative]

    --- changes suggested by @anba

    bestPractice - remove added NotEarlyError
    ch07,ch11 - expect ReferenceError (req'd by ES6)
    correct test descriptions to expect ReferenceError only
    enforce parsing as block statement by adding `;`
    remove needless include of $FAIL.js

    Merge branch 'negative-addErrorName-work' into negative-addErrorName-bestPractice

    resolved Conflicts:
    	test/suite/ch07/7.9/S7.9_A5.7_T1.js
    	test/suite/ch11/11.13/11.13.1/S11.13.1_A2.1_T3.js
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T1.js
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T10.js
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T11.js
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T2.js
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T3.js
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T4.js
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T5.js
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T6.js
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T7.js
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T8.js
    	test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T9.js
    	test/suite/ch11/11.3/11.3.1/S11.3.1_A2.1_T3.js
    	test/suite/ch11/11.3/11.3.2/S11.3.2_A2.1_T3.js
    	test/suite/ch11/11.4/11.4.4/S11.4.4_A2.1_T3.js
    	test/suite/ch11/11.4/11.4.5/S11.4.5_A2.1_T3.js
    	test/suite/ch12/12.5/S12.5_A2.js
    	test/suite/ch12/12.6/12.6.3/S12.6.3_A4_T2.js

    negative: second half of @anba notes

    correct test descriptions to expect ReferenceError only
    enforce parse as block statement by adding `;`
    remove needless include of $FAIL.js

    ch12: specify type

    negative: @anba fixes

    bestPractice - remove added NotEarlyError
    ch07,ch11 - expect ReferenceError (req'd by ES6)

    bestPractice: supply error names to negative

    pilot directory for replacing flags: [negative] with
    negative: errorname

    ch07-7.2,7.3: add error names
    ch07-rest: insert error names rest of ch07
    ch08: add expected error name
    ch11: add error name to negative
    ch12: put error name in negative

    ch13: add error name to negative
    only one test, did it manually

    ch15: add error name to negative:

    ch07: add error name to negative

    these tests used flags: \n - negative and so
    were not caught by the earlier naive grep for flags: [negative]

    expect a SyntaxError

    ch07: add error name to negative

    these tests used flags: \n - negative and so
    were not caught by the earlier naive grep for flags: [negative]

    ch15: add error name to negative:

    ch13: add error name to negative

    only one test, did it manually

    ch12: put error name in negative

    ch11: add error name to negative

    ch08: add expected error name
    ch07-rest: insert error names rest of ch07

    ch07-7.2,7.3: add error names

    negative-errorname: pilot

    pilot directory for replacing flags: [negative] with
    negative: errorname

    bestPractice: supply error names to negative

bestPractice: supply error names to negative

pilot directory for replacing flags: [negative] with
negative: errorname

ch07-7.2,7.3: add error names
ch07-rest: insert error names rest of ch07
ch08: add expected error name
ch11: add error name to negative
ch12: put error name in negative

ch13: add error name to negative
only one test, did it manually

ch15: add error name to negative:

ch07: add error name to negative

these tests used flags: \n - negative and so
were not caught by the earlier naive grep for flags: [negative]

bestPractice: supply error names to negative

negative-errorname: pilot

pilot directory for replacing flags: [negative] with
negative: errorname

ch07-7.2,7.3: add error names

ch07-rest: insert error names rest of ch07

ch08: add expected error name

ch11: add error name to negative

ch12: put error name in negative

ch13: add error name to negative

only one test, did it manually

ch15: add error name to negative:

ch07: add error name to negative

these tests used flags: \n - negative and so
were not caught by the earlier naive grep for flags: [negative]

expect a SyntaxError

negative: @anba fixes

bestPractice - remove added NotEarlyError
ch07,ch11 - expect ReferenceError (req'd by ES6)

ch12: specify type

negative: second half of @anba notes

correct test descriptions to expect ReferenceError only
enforce parse as block statement by adding `;`
remove needless include of $FAIL.js

expect real errors

ch12: negative error matching

ch13 error regexps

ch14 error regexps

add "description" header back

remove now-unused includes

remove needless include
---
 test/suite/bestPractice/Sbp_12.5_A9_T3.js     |  2 +-
 test/suite/bestPractice/Sbp_12.6.1_A13_T3.js  |  2 +-
 test/suite/bestPractice/Sbp_12.6.2_A13_T3.js  |  2 +-
 test/suite/bestPractice/Sbp_12.6.4_A13_T3.js  |  2 +-
 test/suite/bestPractice/Sbp_7.8.4_A6.1_T4.js  |  2 +-
 test/suite/bestPractice/Sbp_7.8.4_A6.2_T1.js  |  2 +-
 test/suite/bestPractice/Sbp_7.8.4_A6.2_T2.js  |  2 +-
 test/suite/ch07/7.2/S7.2_A5_T1.js             |  2 +-
 test/suite/ch07/7.2/S7.2_A5_T2.js             |  2 +-
 test/suite/ch07/7.2/S7.2_A5_T3.js             |  2 +-
 test/suite/ch07/7.2/S7.2_A5_T4.js             |  2 +-
 test/suite/ch07/7.2/S7.2_A5_T5.js             |  2 +-
 test/suite/ch07/7.3/S7.3_A2.1_T1.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A2.1_T2.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A2.2_T1.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A2.2_T2.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A2.3.js              |  2 +-
 test/suite/ch07/7.3/S7.3_A2.4.js              |  2 +-
 test/suite/ch07/7.3/S7.3_A3.1_T1.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A3.1_T2.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A3.1_T3.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A3.2_T1.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A3.2_T2.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A3.2_T3.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A3.3_T1.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A3.3_T2.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A3.4_T1.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A3.4_T2.js           |  2 +-
 test/suite/ch07/7.3/S7.3_A6_T1.js             |  2 +-
 test/suite/ch07/7.3/S7.3_A6_T2.js             |  2 +-
 test/suite/ch07/7.3/S7.3_A6_T3.js             |  2 +-
 test/suite/ch07/7.3/S7.3_A6_T4.js             |  2 +-
 test/suite/ch07/7.4/S7.4_A2_T2.js             |  2 +-
 test/suite/ch07/7.4/S7.4_A3.js                |  2 +-
 test/suite/ch07/7.4/S7.4_A4_T1.js             |  2 +-
 test/suite/ch07/7.4/S7.4_A4_T4.js             |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.1.js   |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.10.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.11.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.12.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.13.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.14.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.15.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.16.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.17.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.18.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.19.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.2.js   |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.20.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.21.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.22.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.23.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.24.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.25.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.3.js   |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.4.js   |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.5.js   |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.6.js   |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.7.js   |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.8.js   |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.9.js   |  2 +-
 test/suite/ch07/7.6/7.6.1/7.6.1.2-1gs.js      |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.10.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.11.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.15.js  |  5 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.16.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.18.js  |  5 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.21.js  |  5 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.22.js  |  5 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.23.js  |  5 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.24.js  |  5 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.26.js  |  5 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.27.js  |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.5.js   |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.6.js   |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.7.js   |  2 +-
 .../ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.9.js   |  2 +-
 test/suite/ch07/7.6/7.6.1/S7.6.1_A1.1.js      |  2 +-
 test/suite/ch07/7.6/7.6.1/S7.6.1_A1.2.js      |  2 +-
 test/suite/ch07/7.6/7.6.1/S7.6.1_A1.3.js      |  2 +-
 test/suite/ch07/7.7/S7.7_A2_T1.js             |  2 +-
 test/suite/ch07/7.7/S7.7_A2_T10.js            |  2 +-
 test/suite/ch07/7.7/S7.7_A2_T2.js             |  2 +-
 test/suite/ch07/7.7/S7.7_A2_T3.js             |  2 +-
 test/suite/ch07/7.7/S7.7_A2_T4.js             |  2 +-
 test/suite/ch07/7.7/S7.7_A2_T5.js             |  2 +-
 test/suite/ch07/7.7/S7.7_A2_T6.js             |  2 +-
 test/suite/ch07/7.7/S7.7_A2_T7.js             |  2 +-
 test/suite/ch07/7.7/S7.7_A2_T8.js             |  2 +-
 test/suite/ch07/7.7/S7.7_A2_T9.js             |  2 +-
 test/suite/ch07/7.8/7.8.3/7.8.3-1gs.js        |  2 +-
 test/suite/ch07/7.8/7.8.3/7.8.3-2gs.js        |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T2.js   |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T3.js   |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T4.js   |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T5.js   |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T6.js   |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T7.js   |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T8.js   |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A6.1_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A6.1_T2.js   |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A6.2_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.3/S7.8.3_A6.2_T2.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/7.8.4-1gs.js        |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A1.1_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A1.1_T2.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A1.2_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A1.2_T2.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A3.1_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A3.1_T2.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A3.2_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A3.2_T2.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A4.3_T1.js   |  5 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A4.3_T2.js   |  5 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A7.1_T4.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T2.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T3.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T4.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T5.js   |  2 +-
 test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T6.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/7.8.5-1gs.js        | 26 +++++-----
 test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T2.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T3.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T4.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A1.3_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A1.3_T3.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A1.5_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A1.5_T3.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A2.2_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A2.2_T2.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A2.3_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A2.3_T3.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A2.5_T1.js   |  2 +-
 test/suite/ch07/7.8/7.8.5/S7.8.5_A2.5_T3.js   |  2 +-
 test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T1.js     |  2 +-
 test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T3.js     |  2 +-
 test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T6.js     |  2 +-
 test/suite/ch07/7.9/S7.9_A10_T2.js            |  2 +-
 test/suite/ch07/7.9/S7.9_A10_T4.js            |  2 +-
 test/suite/ch07/7.9/S7.9_A10_T6.js            |  2 +-
 test/suite/ch07/7.9/S7.9_A10_T8.js            |  2 +-
 test/suite/ch07/7.9/S7.9_A11_T4.js            |  2 +-
 test/suite/ch07/7.9/S7.9_A11_T8.js            |  2 +-
 test/suite/ch07/7.9/S7.9_A4.js                |  2 +-
 test/suite/ch07/7.9/S7.9_A5.1_T1.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A5.3_T1.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A5.7_T1.js           | 11 +++--
 test/suite/ch07/7.9/S7.9_A6.2_T1.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.2_T10.js          |  2 +-
 test/suite/ch07/7.9/S7.9_A6.2_T2.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.2_T3.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.2_T4.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.2_T5.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.2_T6.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.2_T7.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.2_T8.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.2_T9.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.3_T1.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.3_T2.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.3_T3.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.3_T4.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.3_T5.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.3_T6.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.3_T7.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.4_T1.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A6.4_T2.js           |  2 +-
 test/suite/ch07/7.9/S7.9_A7_T7.js             |  2 +-
 test/suite/ch07/7.9/S7.9_A9_T6.js             |  2 +-
 test/suite/ch07/7.9/S7.9_A9_T7.js             |  2 +-
 test/suite/ch07/7.9/S7.9_A9_T8.js             |  2 +-
 test/suite/ch08/8.2/S8.2_A2.js                |  2 +-
 test/suite/ch08/8.3/S8.3_A2.1.js              |  2 +-
 test/suite/ch08/8.3/S8.3_A2.2.js              |  2 +-
 test/suite/ch08/8.4/S8.4_A13_T1.js            |  2 +-
 test/suite/ch08/8.4/S8.4_A13_T2.js            |  2 +-
 test/suite/ch08/8.4/S8.4_A13_T3.js            |  2 +-
 test/suite/ch08/8.4/S8.4_A14_T1.js            |  2 +-
 test/suite/ch08/8.4/S8.4_A14_T2.js            |  2 +-
 test/suite/ch08/8.4/S8.4_A14_T3.js            |  2 +-
 test/suite/ch08/8.4/S8.4_A7.1.js              |  2 +-
 test/suite/ch08/8.4/S8.4_A7.2.js              |  2 +-
 test/suite/ch08/8.4/S8.4_A7.3.js              |  2 +-
 test/suite/ch08/8.4/S8.4_A7.4.js              |  2 +-
 test/suite/ch08/8.6/8.6.2/S8.6.2_A7.js        |  2 +-
 test/suite/ch08/8.7/S8.7.2_A1_T1.js           |  2 +-
 test/suite/ch08/8.7/S8.7.2_A1_T2.js           |  2 +-
 test/suite/ch10/10.1/10.1.1/10.1.1-2gs.js     |  2 +-
 test/suite/ch10/10.1/10.1.1/10.1.1-5gs.js     |  2 +-
 test/suite/ch10/10.1/10.1.1/10.1.1-8gs.js     |  2 +-
 test/suite/ch10/10.4/10.4.2/10.4.2.1-1gs.js   |  2 +-
 test/suite/ch10/10.5/10.5-1gs.js              |  2 +-
 test/suite/ch11/11.1/11.1.1/S11.1.1_A1.js     |  2 +-
 test/suite/ch11/11.1/11.1.5/11.1.5-1gs.js     |  2 +-
 test/suite/ch11/11.1/11.1.5/11.1.5-2gs.js     |  2 +-
 .../ch11/11.13/11.13.1/11.13.1-4-28gs.js      |  6 +--
 .../ch11/11.13/11.13.1/S11.13.1_A2.1_T3.js    |  8 ++--
 .../suite/ch11/11.13/11.13.2/11.13.2-6-1gs.js |  3 +-
 .../ch11/11.13/11.13.2/S11.13.2_A2.2_T1.js    |  8 ++--
 .../ch11/11.13/11.13.2/S11.13.2_A2.2_T10.js   |  8 ++--
 .../ch11/11.13/11.13.2/S11.13.2_A2.2_T11.js   |  8 ++--
 .../ch11/11.13/11.13.2/S11.13.2_A2.2_T2.js    |  8 ++--
 .../ch11/11.13/11.13.2/S11.13.2_A2.2_T3.js    |  8 ++--
 .../ch11/11.13/11.13.2/S11.13.2_A2.2_T4.js    |  8 ++--
 .../ch11/11.13/11.13.2/S11.13.2_A2.2_T5.js    |  8 ++--
 .../ch11/11.13/11.13.2/S11.13.2_A2.2_T6.js    |  8 ++--
 .../ch11/11.13/11.13.2/S11.13.2_A2.2_T7.js    |  8 ++--
 .../ch11/11.13/11.13.2/S11.13.2_A2.2_T8.js    |  8 ++--
 .../ch11/11.13/11.13.2/S11.13.2_A2.2_T9.js    |  8 ++--
 .../suite/ch11/11.2/11.2.4/S11.2.4_A1.3_T1.js |  2 +-
 test/suite/ch11/11.3/11.3.1/11.3.1-2-1gs.js   |  2 +-
 .../suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T1.js |  2 +-
 .../suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T2.js |  2 +-
 .../suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T3.js |  2 +-
 .../suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T4.js |  2 +-
 .../suite/ch11/11.3/11.3.1/S11.3.1_A2.1_T3.js | 12 +++--
 .../suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T1.js |  2 +-
 .../suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T2.js |  2 +-
 .../suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T3.js |  2 +-
 .../suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T4.js |  2 +-
 .../suite/ch11/11.3/11.3.2/S11.3.2_A2.1_T3.js | 12 +++--
 test/suite/ch11/11.4/11.4.1/11.4.1-5-a-5gs.js |  2 +-
 test/suite/ch11/11.4/11.4.2/S11.4.2_A2_T2.js  |  2 +-
 .../suite/ch11/11.4/11.4.4/S11.4.4_A2.1_T3.js | 12 +++--
 test/suite/ch11/11.4/11.4.5/11.4.5-2-2gs.js   |  2 +-
 .../suite/ch11/11.4/11.4.5/S11.4.5_A2.1_T3.js | 12 +++--
 test/suite/ch12/12.1/S12.1_A4_T1.js           |  4 +-
 test/suite/ch12/12.1/S12.1_A4_T2.js           |  4 +-
 test/suite/ch12/12.10/12.10.1/12.10.1-11gs.js |  2 +-
 test/suite/ch12/12.11/S12.11_A2_T1.js         |  2 +-
 test/suite/ch12/12.11/S12.11_A3_T1.js         |  2 +-
 test/suite/ch12/12.11/S12.11_A3_T2.js         |  2 +-
 test/suite/ch12/12.11/S12.11_A3_T3.js         |  2 +-
 test/suite/ch12/12.11/S12.11_A3_T4.js         |  2 +-
 test/suite/ch12/12.11/S12.11_A3_T5.js         |  2 +-
 test/suite/ch12/12.13/S12.13_A1.js            |  4 +-
 test/suite/ch12/12.14/12.14.1/12.14.1-1gs.js  |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T1.js        |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T10.js       |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T11.js       |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T12.js       |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T13.js       |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T14.js       |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T15.js       |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T2.js        |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T3.js        |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T4.js        |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T5.js        |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T6.js        |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T7.js        |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T8.js        |  2 +-
 test/suite/ch12/12.14/S12.14_A16_T9.js        |  2 +-
 test/suite/ch12/12.2/12.2.1/12.2.1-1gs.js     |  2 +-
 test/suite/ch12/12.2/12.2.1/12.2.1-4gs.js     |  2 +-
 test/suite/ch12/12.2/S12.2_A8_T1.js           |  2 +-
 test/suite/ch12/12.2/S12.2_A8_T2.js           |  2 +-
 test/suite/ch12/12.2/S12.2_A8_T3.js           |  2 +-
 test/suite/ch12/12.2/S12.2_A8_T4.js           |  2 +-
 test/suite/ch12/12.2/S12.2_A8_T5.js           |  2 +-
 test/suite/ch12/12.2/S12.2_A8_T6.js           |  2 +-
 test/suite/ch12/12.2/S12.2_A8_T7.js           |  2 +-
 test/suite/ch12/12.2/S12.2_A8_T8.js           |  2 +-
 test/suite/ch12/12.4/S12.4_A1.js              |  2 +-
 test/suite/ch12/12.5/S12.5_A11.js             |  2 +-
 test/suite/ch12/12.5/S12.5_A2.js              |  7 +--
 test/suite/ch12/12.5/S12.5_A6_T1.js           |  2 +-
 test/suite/ch12/12.5/S12.5_A6_T2.js           |  2 +-
 test/suite/ch12/12.5/S12.5_A8.js              |  2 +-
 test/suite/ch12/12.6/12.6.1/S12.6.1_A12.js    |  2 +-
 test/suite/ch12/12.6/12.6.1/S12.6.1_A15.js    |  2 +-
 test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T1.js  |  2 +-
 test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T2.js  |  2 +-
 test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T3.js  |  2 +-
 test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T4.js  |  2 +-
 test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T5.js  |  2 +-
 test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T6.js  |  2 +-
 test/suite/ch12/12.6/12.6.2/S12.6.2_A15.js    |  2 +-
 test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T1.js  |  2 +-
 test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T2.js  |  2 +-
 test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T3.js  |  2 +-
 test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T4.js  |  2 +-
 test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T5.js  |  2 +-
 test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T6.js  |  2 +-
 .../ch12/12.6/12.6.3/S12.6.3_A11.1_T3.js      |  2 +-
 test/suite/ch12/12.6/12.6.3/S12.6.3_A11_T3.js |  2 +-
 .../ch12/12.6/12.6.3/S12.6.3_A12.1_T3.js      |  2 +-
 test/suite/ch12/12.6/12.6.3/S12.6.3_A12_T3.js |  2 +-
 test/suite/ch12/12.6/12.6.3/S12.6.3_A4.1.js   |  2 +-
 test/suite/ch12/12.6/12.6.3/S12.6.3_A4_T1.js  |  2 +-
 test/suite/ch12/12.6/12.6.3/S12.6.3_A4_T2.js  |  2 +-
 .../suite/ch12/12.6/12.6.3/S12.6.3_A7.1_T1.js |  2 +-
 .../suite/ch12/12.6/12.6.3/S12.6.3_A7.1_T2.js |  2 +-
 test/suite/ch12/12.6/12.6.3/S12.6.3_A7_T1.js  |  2 +-
 test/suite/ch12/12.6/12.6.3/S12.6.3_A7_T2.js  |  2 +-
 .../suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T1.js |  2 +-
 .../suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T2.js |  2 +-
 .../suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T3.js |  2 +-
 test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T1.js  |  2 +-
 test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T2.js  |  2 +-
 test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T3.js  |  2 +-
 test/suite/ch12/12.6/12.6.4/S12.6.4_A15.js    |  4 +-
 test/suite/ch12/12.7/S12.7_A1_T1.js           |  2 +-
 test/suite/ch12/12.7/S12.7_A1_T2.js           |  2 +-
 test/suite/ch12/12.7/S12.7_A1_T3.js           |  2 +-
 test/suite/ch12/12.7/S12.7_A1_T4.js           |  2 +-
 test/suite/ch12/12.7/S12.7_A5_T1.js           |  2 +-
 test/suite/ch12/12.7/S12.7_A5_T2.js           |  2 +-
 test/suite/ch12/12.7/S12.7_A5_T3.js           |  2 +-
 test/suite/ch12/12.7/S12.7_A6.js              |  2 +-
 test/suite/ch12/12.7/S12.7_A8_T1.js           |  2 +-
 test/suite/ch12/12.7/S12.7_A8_T2.js           |  2 +-
 test/suite/ch12/12.8/S12.8_A1_T1.js           |  2 +-
 test/suite/ch12/12.8/S12.8_A1_T2.js           |  2 +-
 test/suite/ch12/12.8/S12.8_A1_T3.js           |  2 +-
 test/suite/ch12/12.8/S12.8_A1_T4.js           |  2 +-
 test/suite/ch12/12.8/S12.8_A5_T1.js           |  2 +-
 test/suite/ch12/12.8/S12.8_A5_T2.js           |  2 +-
 test/suite/ch12/12.8/S12.8_A5_T3.js           |  2 +-
 test/suite/ch12/12.8/S12.8_A6.js              |  2 +-
 test/suite/ch12/12.8/S12.8_A8_T1.js           |  2 +-
 test/suite/ch12/12.8/S12.8_A8_T2.js           |  2 +-
 test/suite/ch12/12.9/S12.9_A1_T1.js           |  2 +-
 test/suite/ch12/12.9/S12.9_A1_T10.js          |  2 +-
 test/suite/ch12/12.9/S12.9_A1_T2.js           |  2 +-
 test/suite/ch12/12.9/S12.9_A1_T3.js           |  2 +-
 test/suite/ch12/12.9/S12.9_A1_T4.js           |  2 +-
 test/suite/ch12/12.9/S12.9_A1_T5.js           |  2 +-
 test/suite/ch12/12.9/S12.9_A1_T6.js           |  2 +-
 test/suite/ch12/12.9/S12.9_A1_T7.js           |  2 +-
 test/suite/ch12/12.9/S12.9_A1_T8.js           |  2 +-
 test/suite/ch12/12.9/S12.9_A1_T9.js           |  2 +-
 test/suite/ch13/13.0/13.0_4-17gs.js           |  3 --
 test/suite/ch13/13.0/13.0_4-5gs.js            |  2 +-
 test/suite/ch13/13.0/S13_A7_T3.js             |  2 +-
 test/suite/ch13/13.1/13.1-13gs.js             |  2 +-
 test/suite/ch13/13.1/13.1-1gs.js              |  2 +-
 test/suite/ch13/13.1/13.1-4gs.js              |  2 +-
 test/suite/ch13/13.1/13.1-5gs.js              |  2 +-
 test/suite/ch13/13.1/13.1-8gs.js              |  2 +-
 test/suite/ch13/13.2/13.2-19-b-3gs.js         |  4 +-
 test/suite/ch14/14.1/14.1-4gs.js              |  2 +-
 test/suite/ch14/14.1/14.1-5gs.js              |  2 +-
 .../15.1/15.1.2/15.1.2.1/S15.1.2.1_A2_T2.js   |  2 +-
 test/suite/ch15/15.1/S15.1_A1_T1.js           |  2 +-
 test/suite/ch15/15.1/S15.1_A1_T2.js           |  2 +-
 test/suite/ch15/15.1/S15.1_A2_T1.js           |  2 +-
 .../15.11/15.11.4/15.11.4.4/15.11.4.4-8-2.js  | 15 +++---
 .../ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1-4.js | 14 ++----
 .../ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1-5.js | 14 ++----
 .../ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1.js   | 16 ++-----
 .../15.2/15.2.4/15.2.4.3/S15.2.4.3_A12.js     |  2 +-
 .../15.2/15.2.4/15.2.4.3/S15.2.4.3_A13.js     |  2 +-
 .../15.2/15.2.4/15.2.4.4/S15.2.4.4_A12.js     |  2 +-
 .../15.2/15.2.4/15.2.4.4/S15.2.4.4_A13.js     |  2 +-
 .../15.2/15.2.4/15.2.4.4/S15.2.4.4_A14.js     |  2 +-
 .../15.2/15.2.4/15.2.4.4/S15.2.4.4_A15.js     |  2 +-
 .../15.2/15.2.4/15.2.4.5/S15.2.4.5_A12.js     |  2 +-
 .../15.2/15.2.4/15.2.4.5/S15.2.4.5_A13.js     |  2 +-
 .../15.2/15.2.4/15.2.4.6/S15.2.4.6_A12.js     |  2 +-
 .../15.2/15.2.4/15.2.4.6/S15.2.4.6_A13.js     |  2 +-
 .../15.2/15.2.4/15.2.4.7/S15.2.4.7_A12.js     |  2 +-
 .../15.2/15.2.4/15.2.4.7/S15.2.4.7_A13.js     |  2 +-
 test/suite/ch15/15.3/15.3.5/15.3.5-2gs.js     |  2 +-
 tools/packaging/test262.py                    | 48 +++++++++++--------
 366 files changed, 503 insertions(+), 519 deletions(-)

diff --git a/test/suite/bestPractice/Sbp_12.5_A9_T3.js b/test/suite/bestPractice/Sbp_12.5_A9_T3.js
index b66b91d74f..cb00f3ea47 100644
--- a/test/suite/bestPractice/Sbp_12.5_A9_T3.js
+++ b/test/suite/bestPractice/Sbp_12.5_A9_T3.js
@@ -6,7 +6,7 @@ info: Function declaration within an "if" statement is not allowed
 description: >
     Declaring function within an "if" statement that is declared
     within the function declaration
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function(){
diff --git a/test/suite/bestPractice/Sbp_12.6.1_A13_T3.js b/test/suite/bestPractice/Sbp_12.6.1_A13_T3.js
index 65cb3331b1..2891ce6094 100644
--- a/test/suite/bestPractice/Sbp_12.6.1_A13_T3.js
+++ b/test/suite/bestPractice/Sbp_12.6.1_A13_T3.js
@@ -6,7 +6,7 @@ info: FunctionDeclaration within a "do-while" Block is not allowed
 description: >
     Declaring a function within a "do-while" loop that is within a
     function declaration itself
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function(){
diff --git a/test/suite/bestPractice/Sbp_12.6.2_A13_T3.js b/test/suite/bestPractice/Sbp_12.6.2_A13_T3.js
index cc6a2e1c78..790a46cc99 100644
--- a/test/suite/bestPractice/Sbp_12.6.2_A13_T3.js
+++ b/test/suite/bestPractice/Sbp_12.6.2_A13_T3.js
@@ -6,7 +6,7 @@ info: FunctionDeclaration within a "while" Statement is not allowed
 description: >
     Checking if declaring a function within a "while" Statement that
     is in a function body leads to an exception
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function(){
diff --git a/test/suite/bestPractice/Sbp_12.6.4_A13_T3.js b/test/suite/bestPractice/Sbp_12.6.4_A13_T3.js
index 1da0487f61..0a934ad548 100644
--- a/test/suite/bestPractice/Sbp_12.6.4_A13_T3.js
+++ b/test/suite/bestPractice/Sbp_12.6.4_A13_T3.js
@@ -6,7 +6,7 @@ info: FunctionDeclaration within a "for-in" Statement is not allowed
 description: >
     Declaring function within a "for-in" Statement that is within
     function declaration
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function(){
diff --git a/test/suite/bestPractice/Sbp_7.8.4_A6.1_T4.js b/test/suite/bestPractice/Sbp_7.8.4_A6.1_T4.js
index ec504c5032..33061648af 100644
--- a/test/suite/bestPractice/Sbp_7.8.4_A6.1_T4.js
+++ b/test/suite/bestPractice/Sbp_7.8.4_A6.1_T4.js
@@ -4,7 +4,7 @@
 /*---
 info: "EscapeSequence :: HexEscapeSequence :: x HexDigit HexDigit"
 description: "HexEscapeSequence :: x0G is incorrect"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#
diff --git a/test/suite/bestPractice/Sbp_7.8.4_A6.2_T1.js b/test/suite/bestPractice/Sbp_7.8.4_A6.2_T1.js
index 517eb00938..a44677357f 100644
--- a/test/suite/bestPractice/Sbp_7.8.4_A6.2_T1.js
+++ b/test/suite/bestPractice/Sbp_7.8.4_A6.2_T1.js
@@ -4,7 +4,7 @@
 /*---
 info: "HexEscapeSequence :: x HexDigit is incorrect"
 description: "HexDigit :: 1"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/bestPractice/Sbp_7.8.4_A6.2_T2.js b/test/suite/bestPractice/Sbp_7.8.4_A6.2_T2.js
index f8193f2a48..1c3165a73a 100644
--- a/test/suite/bestPractice/Sbp_7.8.4_A6.2_T2.js
+++ b/test/suite/bestPractice/Sbp_7.8.4_A6.2_T2.js
@@ -4,7 +4,7 @@
 /*---
 info: "HexEscapeSequence :: x HexDigit is incorrect"
 description: "HexDigit :: A"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.2/S7.2_A5_T1.js b/test/suite/ch07/7.2/S7.2_A5_T1.js
index 2886621759..957767e8a0 100644
--- a/test/suite/ch07/7.2/S7.2_A5_T1.js
+++ b/test/suite/ch07/7.2/S7.2_A5_T1.js
@@ -7,7 +7,7 @@ info: >
     of six characters, namely \u plus four hexadecimal digits
 es5id: 7.2_A5_T1
 description: Use TAB (U+0009)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var\u0009x;
diff --git a/test/suite/ch07/7.2/S7.2_A5_T2.js b/test/suite/ch07/7.2/S7.2_A5_T2.js
index 66f6064757..bd60773b27 100644
--- a/test/suite/ch07/7.2/S7.2_A5_T2.js
+++ b/test/suite/ch07/7.2/S7.2_A5_T2.js
@@ -7,7 +7,7 @@ info: >
     of six characters, namely \u plus four hexadecimal digits
 es5id: 7.2_A5_T2
 description: Use VERTICAL TAB (U+000B)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var\u000Bx;
diff --git a/test/suite/ch07/7.2/S7.2_A5_T3.js b/test/suite/ch07/7.2/S7.2_A5_T3.js
index 67da9023a3..fa3a23620d 100644
--- a/test/suite/ch07/7.2/S7.2_A5_T3.js
+++ b/test/suite/ch07/7.2/S7.2_A5_T3.js
@@ -7,7 +7,7 @@ info: >
     of six characters, namely \u plus four hexadecimal digits
 es5id: 7.2_A5_T3
 description: Use FORM FEED (U+000C)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var\u000Cx;
diff --git a/test/suite/ch07/7.2/S7.2_A5_T4.js b/test/suite/ch07/7.2/S7.2_A5_T4.js
index cffd17512b..4ff6bbad43 100644
--- a/test/suite/ch07/7.2/S7.2_A5_T4.js
+++ b/test/suite/ch07/7.2/S7.2_A5_T4.js
@@ -7,7 +7,7 @@ info: >
     of six characters, namely \u plus four hexadecimal digits
 es5id: 7.2_A5_T4
 description: Use SPACE (U+0020)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var\u0020x;
diff --git a/test/suite/ch07/7.2/S7.2_A5_T5.js b/test/suite/ch07/7.2/S7.2_A5_T5.js
index f35d220f40..956341d913 100644
--- a/test/suite/ch07/7.2/S7.2_A5_T5.js
+++ b/test/suite/ch07/7.2/S7.2_A5_T5.js
@@ -7,7 +7,7 @@ info: >
     of six characters, namely \u plus four hexadecimal digits
 es5id: 7.2_A5_T5
 description: Use NO-BREAK SPACE (U+00A0)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var\u00A0x;
diff --git a/test/suite/ch07/7.3/S7.3_A2.1_T1.js b/test/suite/ch07/7.3/S7.3_A2.1_T1.js
index 3fc7f84230..3e8cad14ae 100644
--- a/test/suite/ch07/7.3/S7.3_A2.1_T1.js
+++ b/test/suite/ch07/7.3/S7.3_A2.1_T1.js
@@ -5,7 +5,7 @@
 info: LINE FEED (U+000A) within strings is not allowed
 es5id: 7.3_A2.1_T1
 description: Insert LINE FEED (\u000A) into string
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A2.1_T2.js b/test/suite/ch07/7.3/S7.3_A2.1_T2.js
index 41a3694c64..00c7a1d4b4 100644
--- a/test/suite/ch07/7.3/S7.3_A2.1_T2.js
+++ b/test/suite/ch07/7.3/S7.3_A2.1_T2.js
@@ -5,7 +5,7 @@
 info: LINE FEED (U+000A) within strings is not allowed
 es5id: 7.3_A2.1_T2
 description: Use real LINE FEED into string
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A2.2_T1.js b/test/suite/ch07/7.3/S7.3_A2.2_T1.js
index 64199e91f9..bb50b71a30 100644
--- a/test/suite/ch07/7.3/S7.3_A2.2_T1.js
+++ b/test/suite/ch07/7.3/S7.3_A2.2_T1.js
@@ -5,7 +5,7 @@
 info: CARRIAGE RETURN (U+000D) within strings is not allowed
 es5id: 7.3_A2.2_T1
 description: Insert CARRIAGE RETURN (\u000D) into string
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A2.2_T2.js b/test/suite/ch07/7.3/S7.3_A2.2_T2.js
index a556aa4143..dce4f2a2b9 100644
--- a/test/suite/ch07/7.3/S7.3_A2.2_T2.js
+++ b/test/suite/ch07/7.3/S7.3_A2.2_T2.js
@@ -5,7 +5,7 @@
 info: CARRIAGE RETURN (U+000D) within strings is not allowed
 es5id: 7.3_A2.2_T2
 description: Insert real CARRIAGE RETURN into string
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A2.3.js b/test/suite/ch07/7.3/S7.3_A2.3.js
index dd811410c6..439140a558 100644
--- a/test/suite/ch07/7.3/S7.3_A2.3.js
+++ b/test/suite/ch07/7.3/S7.3_A2.3.js
@@ -5,7 +5,7 @@
 info: LINE SEPARATOR (U+2028) within strings is not allowed
 es5id: 7.3_A2.3
 description: Insert LINE SEPARATOR (\u2028) into string
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A2.4.js b/test/suite/ch07/7.3/S7.3_A2.4.js
index debb208959..9db6e42e8b 100644
--- a/test/suite/ch07/7.3/S7.3_A2.4.js
+++ b/test/suite/ch07/7.3/S7.3_A2.4.js
@@ -5,7 +5,7 @@
 info: PARAGRAPH SEPARATOR (U+2029) within strings is not allowed
 es5id: 7.3_A2.4
 description: Insert PARAGRAPH SEPARATOR (\u2029) into string
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A3.1_T1.js b/test/suite/ch07/7.3/S7.3_A3.1_T1.js
index 84532006e4..fa3ef486f8 100644
--- a/test/suite/ch07/7.3/S7.3_A3.1_T1.js
+++ b/test/suite/ch07/7.3/S7.3_A3.1_T1.js
@@ -5,7 +5,7 @@
 info: Single line comments can not contain LINE FEED (U+000A) inside
 es5id: 7.3_A3.1_T1
 description: Insert LINE FEED (\u000A) into single line comment
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A3.1_T2.js b/test/suite/ch07/7.3/S7.3_A3.1_T2.js
index b0e74af980..61d2bbbaa3 100644
--- a/test/suite/ch07/7.3/S7.3_A3.1_T2.js
+++ b/test/suite/ch07/7.3/S7.3_A3.1_T2.js
@@ -5,7 +5,7 @@
 info: Single line comments can not contain LINE FEED (U+000A) inside
 es5id: 7.3_A3.1_T2
 description: Insert LINE FEED (\u000A) into begin of single line comment
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A3.1_T3.js b/test/suite/ch07/7.3/S7.3_A3.1_T3.js
index 41f3d5c5b2..68c5a90626 100644
--- a/test/suite/ch07/7.3/S7.3_A3.1_T3.js
+++ b/test/suite/ch07/7.3/S7.3_A3.1_T3.js
@@ -5,7 +5,7 @@
 info: Single line comments can not contain LINE FEED (U+000A) inside
 es5id: 7.3_A3.1_T3
 description: Insert real LINE FEED into single line comment
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A3.2_T1.js b/test/suite/ch07/7.3/S7.3_A3.2_T1.js
index 5bde268897..11f0b00956 100644
--- a/test/suite/ch07/7.3/S7.3_A3.2_T1.js
+++ b/test/suite/ch07/7.3/S7.3_A3.2_T1.js
@@ -5,7 +5,7 @@
 info: Single line comments can not contain CARRIAGE RETURN (U+000D) inside
 es5id: 7.3_A3.2_T1
 description: Insert CARRIAGE RETURN (\u000D) into single line comment
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A3.2_T2.js b/test/suite/ch07/7.3/S7.3_A3.2_T2.js
index 7c34bcd0df..04cde82e4e 100644
--- a/test/suite/ch07/7.3/S7.3_A3.2_T2.js
+++ b/test/suite/ch07/7.3/S7.3_A3.2_T2.js
@@ -5,7 +5,7 @@
 info: Single line comments can not contain CARRIAGE RETURN (U+000D) inside
 es5id: 7.3_A3.2_T2
 description: Insert CARRIAGE RETURN (\u000D) into begin of single line comment
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A3.2_T3.js b/test/suite/ch07/7.3/S7.3_A3.2_T3.js
index b610bd50ad..02b123410f 100644
--- a/test/suite/ch07/7.3/S7.3_A3.2_T3.js
+++ b/test/suite/ch07/7.3/S7.3_A3.2_T3.js
@@ -5,7 +5,7 @@
 info: Single line comments can not contain CARRIAGE RETURN (U+000D) inside
 es5id: 7.3_A3.2_T3
 description: Insert real CARRIAGE RETURN into single line comment
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A3.3_T1.js b/test/suite/ch07/7.3/S7.3_A3.3_T1.js
index 033ed8984d..26076de507 100644
--- a/test/suite/ch07/7.3/S7.3_A3.3_T1.js
+++ b/test/suite/ch07/7.3/S7.3_A3.3_T1.js
@@ -5,7 +5,7 @@
 info: Single line comments can not contain LINE SEPARATOR (U+2028) inside
 es5id: 7.3_A3.3_T1
 description: Insert LINE SEPARATOR (\u2028) into single line comment
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A3.3_T2.js b/test/suite/ch07/7.3/S7.3_A3.3_T2.js
index d9b9a3a0cf..07d3f855a2 100644
--- a/test/suite/ch07/7.3/S7.3_A3.3_T2.js
+++ b/test/suite/ch07/7.3/S7.3_A3.3_T2.js
@@ -5,7 +5,7 @@
 info: Single line comments can not contain LINE SEPARATOR (U+2028) inside
 es5id: 7.3_A3.3_T2
 description: Insert LINE SEPARATOR (\u2028) into begin of single line comment
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A3.4_T1.js b/test/suite/ch07/7.3/S7.3_A3.4_T1.js
index 2a0b7c8251..d7d7b1b929 100644
--- a/test/suite/ch07/7.3/S7.3_A3.4_T1.js
+++ b/test/suite/ch07/7.3/S7.3_A3.4_T1.js
@@ -5,7 +5,7 @@
 info: Single line comments can not contain PARAGRAPH SEPARATOR (U+2029) inside
 es5id: 7.3_A3.4_T1
 description: Insert PARAGRAPH SEPARATOR (\u2029) into single line comment
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A3.4_T2.js b/test/suite/ch07/7.3/S7.3_A3.4_T2.js
index d483a972a9..6393ba801a 100644
--- a/test/suite/ch07/7.3/S7.3_A3.4_T2.js
+++ b/test/suite/ch07/7.3/S7.3_A3.4_T2.js
@@ -7,7 +7,7 @@ es5id: 7.3_A3.4_T2
 description: >
     Insert PARAGRAPH SEPARATOR (\u2029) into begin of single line
     comment
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch07/7.3/S7.3_A6_T1.js b/test/suite/ch07/7.3/S7.3_A6_T1.js
index fba455c4f7..bc16811d39 100644
--- a/test/suite/ch07/7.3/S7.3_A6_T1.js
+++ b/test/suite/ch07/7.3/S7.3_A6_T1.js
@@ -7,7 +7,7 @@ info: >
     consisting of six characters, namely \u plus four hexadecimal digits
 es5id: 7.3_A6_T1
 description: Insert LINE FEED (U+000A) in var x
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var\u000Ax;
diff --git a/test/suite/ch07/7.3/S7.3_A6_T2.js b/test/suite/ch07/7.3/S7.3_A6_T2.js
index 2fa68cf2a8..ed3acaa456 100644
--- a/test/suite/ch07/7.3/S7.3_A6_T2.js
+++ b/test/suite/ch07/7.3/S7.3_A6_T2.js
@@ -7,7 +7,7 @@ info: >
     consisting of six characters, namely \u plus four hexadecimal digits
 es5id: 7.3_A6_T2
 description: Insert CARRIAGE RETURN (U+000D) in var x
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var\u000Dx;
diff --git a/test/suite/ch07/7.3/S7.3_A6_T3.js b/test/suite/ch07/7.3/S7.3_A6_T3.js
index c288088b0e..ea10ae1583 100644
--- a/test/suite/ch07/7.3/S7.3_A6_T3.js
+++ b/test/suite/ch07/7.3/S7.3_A6_T3.js
@@ -7,7 +7,7 @@ info: >
     consisting of six characters, namely \u plus four hexadecimal digits
 es5id: 7.3_A6_T3
 description: Insert LINE SEPARATOR (U+2028) in var x
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var\u2028x;
diff --git a/test/suite/ch07/7.3/S7.3_A6_T4.js b/test/suite/ch07/7.3/S7.3_A6_T4.js
index 9f679d5f4a..daa1ad396b 100644
--- a/test/suite/ch07/7.3/S7.3_A6_T4.js
+++ b/test/suite/ch07/7.3/S7.3_A6_T4.js
@@ -7,7 +7,7 @@ info: >
     consisting of six characters, namely \u plus four hexadecimal digits
 es5id: 7.3_A6_T4
 description: Insert PARAGRAPH SEPARATOR (U+2029) in var x
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var\u2029x;
diff --git a/test/suite/ch07/7.4/S7.4_A2_T2.js b/test/suite/ch07/7.4/S7.4_A2_T2.js
index 2d4103f0a0..e46e9ef731 100644
--- a/test/suite/ch07/7.4/S7.4_A2_T2.js
+++ b/test/suite/ch07/7.4/S7.4_A2_T2.js
@@ -5,7 +5,7 @@
 info: Correct interpretation of multi line comments
 es5id: 7.4_A2_T2
 description: Try use /*CHECK#1/. This is not closed multi line comment
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 /*CHECK#1/
diff --git a/test/suite/ch07/7.4/S7.4_A3.js b/test/suite/ch07/7.4/S7.4_A3.js
index 98d090bcdd..422bc3d9c0 100644
--- a/test/suite/ch07/7.4/S7.4_A3.js
+++ b/test/suite/ch07/7.4/S7.4_A3.js
@@ -5,7 +5,7 @@
 info: Multi line comments cannot nest
 es5id: 7.4_A3
 description: Try use nested comments
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 /*CHECK#1*/
diff --git a/test/suite/ch07/7.4/S7.4_A4_T1.js b/test/suite/ch07/7.4/S7.4_A4_T1.js
index 52b4f5b66b..ea6281a671 100644
--- a/test/suite/ch07/7.4/S7.4_A4_T1.js
+++ b/test/suite/ch07/7.4/S7.4_A4_T1.js
@@ -5,7 +5,7 @@
 info: Single and Multi line comments are used together
 es5id: 7.4_A4_T1
 description: Try use 2 close comment tags
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 /*CHECK#1*/
diff --git a/test/suite/ch07/7.4/S7.4_A4_T4.js b/test/suite/ch07/7.4/S7.4_A4_T4.js
index 4ba143789a..a6913e7d02 100644
--- a/test/suite/ch07/7.4/S7.4_A4_T4.js
+++ b/test/suite/ch07/7.4/S7.4_A4_T4.js
@@ -5,7 +5,7 @@
 info: Single and Multi line comments are used together
 es5id: 7.4_A4_T4
 description: Try to open Multi line comment at the end of Single comment
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 /*CHECK#1*/
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.1.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.1.js
index f9e5ffb782..a254c92662 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.1.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.1.js
@@ -5,7 +5,7 @@
 info: The "break" token can not be used as identifier
 es5id: 7.6.1.1_A1.1
 description: Checking if execution of "break=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 break = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.10.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.10.js
index 247cff6c71..053e0faca6 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.10.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.10.js
@@ -5,7 +5,7 @@
 info: The "for" token can not be used as identifier
 es5id: 7.6.1.1_A1.10
 description: Checking if execution of "for=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 for = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.11.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.11.js
index bca8904815..96652e2b10 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.11.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.11.js
@@ -5,7 +5,7 @@
 info: The "function" token can not be used as identifier
 es5id: 7.6.1.1_A1.11
 description: Checking if execution of "function=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.12.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.12.js
index 5fc1157bc1..603ecbe133 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.12.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.12.js
@@ -5,7 +5,7 @@
 info: The "if" token can not be used as identifier
 es5id: 7.6.1.1_A1.12
 description: Checking if execution of "if=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 if = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.13.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.13.js
index bf2c822373..d7da9537db 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.13.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.13.js
@@ -5,7 +5,7 @@
 info: The "in" token can not be used as identifier
 es5id: 7.6.1.1_A1.13
 description: Checking if execution of "in=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 in = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.14.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.14.js
index 34e64144c3..d504419944 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.14.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.14.js
@@ -5,7 +5,7 @@
 info: The "instanceof" token can not be used as identifier
 es5id: 7.6.1.1_A1.14
 description: Checking if execution of "instanceof=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 instanceof = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.15.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.15.js
index 57df440349..e623b1a0be 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.15.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.15.js
@@ -5,7 +5,7 @@
 info: The "new" token can not be used as identifier
 es5id: 7.6.1.1_A1.15
 description: Checking if execution of "new=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 new = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.16.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.16.js
index f73677136a..add73e9f27 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.16.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.16.js
@@ -5,7 +5,7 @@
 info: The "return" token can not be used as identifier
 es5id: 7.6.1.1_A1.16
 description: Checking if execution of "return=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 return = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.17.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.17.js
index 68bbcf7447..ae8dbae8e0 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.17.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.17.js
@@ -5,7 +5,7 @@
 info: The "switch" token can not be used as identifier
 es5id: 7.6.1.1_A1.17
 description: Checking if execution of "switch=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 switch = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.18.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.18.js
index 3f531cd410..6c9fa99f7d 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.18.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.18.js
@@ -5,7 +5,7 @@
 info: The "this" token can not be used as identifier
 es5id: 7.6.1.1_A1.18
 description: Checking if execution of "this=1" fails
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 this = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.19.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.19.js
index a898256018..16418ccb0f 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.19.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.19.js
@@ -5,7 +5,7 @@
 info: The "throw" token can not be used as identifier
 es5id: 7.6.1.1_A1.19
 description: Checking if execution of "throw=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 throw = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.2.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.2.js
index 9916fa0f1e..a973527c4d 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.2.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.2.js
@@ -5,7 +5,7 @@
 info: The "case" token can not be used as identifier
 es5id: 7.6.1.1_A1.2
 description: Checking if execution of "case=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 case = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.20.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.20.js
index fea685b816..a72a7ae35a 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.20.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.20.js
@@ -5,7 +5,7 @@
 info: The "try" token can not be used as identifier
 es5id: 7.6.1.1_A1.20
 description: Checking if execution of "try=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 try = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.21.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.21.js
index 91535f9f29..6a3b03a0b2 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.21.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.21.js
@@ -5,7 +5,7 @@
 info: The "typeof" token can not be used as identifier
 es5id: 7.6.1.1_A1.21
 description: Checking if execution of "typeof=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 typeof = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.22.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.22.js
index a9c6eb3bed..3192d857ab 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.22.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.22.js
@@ -5,7 +5,7 @@
 info: The "var" token can not be used as identifier
 es5id: 7.6.1.1_A1.22
 description: Checking if execution of "var=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.23.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.23.js
index 0bbce995e4..b6cded9f36 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.23.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.23.js
@@ -5,7 +5,7 @@
 info: The "void" token can not be used as identifier
 es5id: 7.6.1.1_A1.23
 description: Checking if execution of "void=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 void = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.24.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.24.js
index 8d3aa5e2bf..6cbfa08e98 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.24.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.24.js
@@ -5,7 +5,7 @@
 info: The "while" token can not be used as identifier
 es5id: 7.6.1.1_A1.24
 description: Checking if execution of "while=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 while = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.25.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.25.js
index c71a36033e..693163b6dd 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.25.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.25.js
@@ -5,7 +5,7 @@
 info: The "with" token can not be used as identifier
 es5id: 7.6.1.1_A1.25
 description: Checking if execution of "with=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 with = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.3.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.3.js
index 8f2bbad205..e896e65557 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.3.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.3.js
@@ -5,7 +5,7 @@
 info: The "catch" token can not be used as identifier
 es5id: 7.6.1.1_A1.3
 description: Checking if execution of "catch=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 catch = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.4.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.4.js
index ee61da986f..f9215dcdcc 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.4.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.4.js
@@ -5,7 +5,7 @@
 info: The "continue" token can not be used as identifier
 es5id: 7.6.1.1_A1.4
 description: Checking if execution of "contunue=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 continue = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.5.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.5.js
index 376ca18090..35425610c5 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.5.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.5.js
@@ -5,7 +5,7 @@
 info: The "default" token can not be used as identifier
 es5id: 7.6.1.1_A1.5
 description: Checking if execution of "default=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 default = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.6.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.6.js
index cc1f1aec5b..e4330159ac 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.6.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.6.js
@@ -5,7 +5,7 @@
 info: The "delete" token can not be used as identifier
 es5id: 7.6.1.1_A1.6
 description: Checking if execution of "delete=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 delete = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.7.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.7.js
index 857f0ed41f..b9428377a6 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.7.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.7.js
@@ -5,7 +5,7 @@
 info: The "do" token can not be used as identifier
 es5id: 7.6.1.1_A1.7
 description: Checking if execution of "do=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 do = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.8.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.8.js
index 14197fc756..bf4409e315 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.8.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.8.js
@@ -5,7 +5,7 @@
 info: The "else" token can not be used as identifier
 es5id: 7.6.1.1_A1.8
 description: Checking if execution of "else=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 else = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.9.js b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.9.js
index 8ea4a785b2..50af87b024 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.9.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.1/S7.6.1.1_A1.9.js
@@ -5,7 +5,7 @@
 info: The "finally" token can not be used as identifier
 es5id: 7.6.1.1_A1.9
 description: Checking if execution of "finally=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 finally = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2-1gs.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2-1gs.js
index bfa17e26c1..63c34a8811 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2-1gs.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2-1gs.js
@@ -9,7 +9,7 @@ es5id: 7.6.1.2-1gs
 description: >
     Strict Mode - SyntaxError is thrown when FutureReservedWord
     'implements' occurs in strict mode code
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.10.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.10.js
index 627eef99e1..183fd99090 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.10.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.10.js
@@ -5,7 +5,7 @@
 info: The "export" token can not be used as identifier
 es5id: 7.6.1.2_A1.10
 description: Checking if execution of "export=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var export = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.11.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.11.js
index 8ed1aca792..5d5d6237c4 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.11.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.11.js
@@ -5,7 +5,7 @@
 info: The "extends" token can not be used as identifier
 es5id: 7.6.1.2_A1.11
 description: Checking if execution of "extends=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var extends = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.15.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.15.js
index b2c41f50ac..abe941d4ef 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.15.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.15.js
@@ -5,9 +5,8 @@
 info: The "implements" token can not be used as identifier in strict code
 es5id: 7.6.1.2_A1.15
 description: Checking if execution of "implements=1" fails in strict code
-flags:
-    - onlyStrict
-    - negative
+negative: SyntaxError
+flags: [onlyStrict]
 ---*/
 
 "use strict";
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.16.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.16.js
index fd5126cd45..b7c078dd63 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.16.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.16.js
@@ -5,7 +5,7 @@
 info: The "import" token can not be used as identifier
 es5id: 7.6.1.2_A1.16
 description: Checking if execution of "import=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var import = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.18.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.18.js
index a7364bf19c..abe69cfc8b 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.18.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.18.js
@@ -5,9 +5,8 @@
 info: The "interface" token can not be used as identifier in strict code
 es5id: 7.6.1.2_A1.18
 description: Checking if execution of "interface = 1" fails in  strict code
-flags:
-    - onlyStrict
-    - negative
+negative: SyntaxError
+flags: [onlyStrict]
 ---*/
 
 "use strict";
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.21.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.21.js
index 123bb38ff1..2462ba6e35 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.21.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.21.js
@@ -5,9 +5,8 @@
 info: The "package" token can not be used as identifier in strict code
 es5id: 7.6.1.2_A1.21
 description: Checking if execution of "package=1" fails in strict code
-flags:
-    - onlyStrict
-    - negative
+negative: SyntaxError
+flags: [onlyStrict]
 ---*/
 
 "use strict";
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.22.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.22.js
index 7ff0542122..ef7e7b3350 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.22.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.22.js
@@ -5,9 +5,8 @@
 info: The "private" token can not be used as identifier in strict code
 es5id: 7.6.1.2_A1.22
 description: Checking if execution of "private=1" fails in strict code
-flags:
-    - onlyStrict
-    - negative
+negative: SyntaxError
+flags: [onlyStrict]
 ---*/
 
 "use strict";
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.23.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.23.js
index 519543a9e8..8b527aabcf 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.23.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.23.js
@@ -5,9 +5,8 @@
 info: The "protected" token can not be used as identifier in strict code
 es5id: 7.6.1.2_A1.23
 description: Checking if execution of "protected=1" fails in  strict code
-flags:
-    - onlyStrict
-    - negative
+negative: SyntaxError
+flags: [onlyStrict]
 ---*/
 
 "use strict";
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.24.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.24.js
index 117263714a..7382f31aa5 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.24.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.24.js
@@ -5,9 +5,8 @@
 info: The "public" token can not be used as identifier in strict code
 es5id: 7.6.1.2_A1.24
 description: Checking if execution of "public=1" fails in strict code
-flags:
-    - onlyStrict
-    - negative
+negative: SyntaxError
+flags: [onlyStrict]
 ---*/
 
 "use strict";
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.26.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.26.js
index 5debcde9fb..b5b9e431c9 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.26.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.26.js
@@ -5,9 +5,8 @@
 info: The "static" token can not be used as identifier in strict code
 es5id: 7.6.1.2_A1.26
 description: Checking if execution of "static=1" fails in strict code
-flags:
-    - onlyStrict
-    - negative
+negative: SyntaxError
+flags: [onlyStrict]
 ---*/
 
 "use strict";
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.27.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.27.js
index cb7c70b8d8..8011fb1833 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.27.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.27.js
@@ -5,7 +5,7 @@
 info: The "super" token can not be used as identifier
 es5id: 7.6.1.2_A1.27
 description: Checking if execution of "super=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var super = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.5.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.5.js
index 98aefffa98..b1c184f444 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.5.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.5.js
@@ -5,7 +5,7 @@
 info: The "class" token can not be used as identifier
 es5id: 7.6.1.2_A1.5
 description: Checking if execution of "class=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var class = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.6.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.6.js
index 4e9f3746d5..af899166d5 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.6.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.6.js
@@ -5,7 +5,7 @@
 info: The "const" token can not be used as identifier
 es5id: 7.6.1.2_A1.6
 description: Checking if execution of "const=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var const = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.7.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.7.js
index f089ca5ebd..b5217a3f50 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.7.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.7.js
@@ -5,7 +5,7 @@
 info: The "debugger" token can not be used as identifier
 es5id: 7.6.1.2_A1.7
 description: Checking if execution of "debugger=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var debugger = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.9.js b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.9.js
index c1ed82611e..78fc962f88 100644
--- a/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.9.js
+++ b/test/suite/ch07/7.6/7.6.1/7.6.1.2/S7.6.1.2_A1.9.js
@@ -5,7 +5,7 @@
 info: The "enum" token can not be used as identifier
 es5id: 7.6.1.2_A1.9
 description: Checking if execution of "enum=1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var enum = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.1.js b/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.1.js
index cd3c57059e..76b1803b0f 100644
--- a/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.1.js
+++ b/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.1.js
@@ -5,7 +5,7 @@
 info: The "null" token can not be used as identifier
 es5id: 7.6.1_A1.1
 description: Checking if execution of "null = 1" fails
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 null = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.2.js b/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.2.js
index 1f5a74942c..e593fd56c1 100644
--- a/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.2.js
+++ b/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.2.js
@@ -5,7 +5,7 @@
 info: The "true" token can not be used as identifier
 es5id: 7.6.1_A1.2
 description: Checking if execution of "true=1" fails
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 true = 1;
diff --git a/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.3.js b/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.3.js
index 7e7340424c..1c94158bde 100644
--- a/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.3.js
+++ b/test/suite/ch07/7.6/7.6.1/S7.6.1_A1.3.js
@@ -5,7 +5,7 @@
 info: The "false" token can not be used as identifier
 es5id: 7.6.1_A1.3
 description: Checking if execution of "false=1" fails
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 false = 1;
diff --git a/test/suite/ch07/7.7/S7.7_A2_T1.js b/test/suite/ch07/7.7/S7.7_A2_T1.js
index c9b44f5b27..1e955d54b6 100644
--- a/test/suite/ch07/7.7/S7.7_A2_T1.js
+++ b/test/suite/ch07/7.7/S7.7_A2_T1.js
@@ -7,7 +7,7 @@ info: >
     six characters, namely \u plus four hexadecimal digits
 es5id: 7.7_A2_T1
 description: Try to use {} as a Unicode \u007B\u007D
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 \u007B\u007D;
diff --git a/test/suite/ch07/7.7/S7.7_A2_T10.js b/test/suite/ch07/7.7/S7.7_A2_T10.js
index 8077691216..2fcdf86b4a 100644
--- a/test/suite/ch07/7.7/S7.7_A2_T10.js
+++ b/test/suite/ch07/7.7/S7.7_A2_T10.js
@@ -7,7 +7,7 @@ info: >
     six characters, namely \u plus four hexadecimal digits
 es5id: 7.7_A2_T10
 description: Try to use / as a Unicode \u002F
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 1\u002F2;
diff --git a/test/suite/ch07/7.7/S7.7_A2_T2.js b/test/suite/ch07/7.7/S7.7_A2_T2.js
index 29933c497e..665b242978 100644
--- a/test/suite/ch07/7.7/S7.7_A2_T2.js
+++ b/test/suite/ch07/7.7/S7.7_A2_T2.js
@@ -7,7 +7,7 @@ info: >
     six characters, namely \u plus four hexadecimal digits
 es5id: 7.7_A2_T2
 description: Try to use () as Unicode \u00281\u0029
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 \u00281\u0029;
diff --git a/test/suite/ch07/7.7/S7.7_A2_T3.js b/test/suite/ch07/7.7/S7.7_A2_T3.js
index 28dce54839..a38c8f2924 100644
--- a/test/suite/ch07/7.7/S7.7_A2_T3.js
+++ b/test/suite/ch07/7.7/S7.7_A2_T3.js
@@ -7,7 +7,7 @@ info: >
     six characters, namely \u plus four hexadecimal digits
 es5id: 7.7_A2_T3
 description: Try to use [] as a Unicode \u005B\u005D
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 \u005B\u005D;
diff --git a/test/suite/ch07/7.7/S7.7_A2_T4.js b/test/suite/ch07/7.7/S7.7_A2_T4.js
index 30cb76d784..a6f1f305b8 100644
--- a/test/suite/ch07/7.7/S7.7_A2_T4.js
+++ b/test/suite/ch07/7.7/S7.7_A2_T4.js
@@ -7,7 +7,7 @@ info: >
     six characters, namely \u plus four hexadecimal digits
 es5id: 7.7_A2_T4
 description: Try to use ; as a Unicode \u003B
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 \u003B;
diff --git a/test/suite/ch07/7.7/S7.7_A2_T5.js b/test/suite/ch07/7.7/S7.7_A2_T5.js
index 13d4f5d4b4..59135976d3 100644
--- a/test/suite/ch07/7.7/S7.7_A2_T5.js
+++ b/test/suite/ch07/7.7/S7.7_A2_T5.js
@@ -7,7 +7,7 @@ info: >
     six characters, namely \u plus four hexadecimal digits
 es5id: 7.7_A2_T5
 description: Try to use . as a Unicode \u002E
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 x = 1;
diff --git a/test/suite/ch07/7.7/S7.7_A2_T6.js b/test/suite/ch07/7.7/S7.7_A2_T6.js
index 45455c1d64..db832e0fa9 100644
--- a/test/suite/ch07/7.7/S7.7_A2_T6.js
+++ b/test/suite/ch07/7.7/S7.7_A2_T6.js
@@ -7,7 +7,7 @@ info: >
     six characters, namely \u plus four hexadecimal digits
 es5id: 7.7_A2_T6
 description: Try to use , as a Unicode \u002C
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 1\u002C2;
diff --git a/test/suite/ch07/7.7/S7.7_A2_T7.js b/test/suite/ch07/7.7/S7.7_A2_T7.js
index fdf78e26d8..685311c3fe 100644
--- a/test/suite/ch07/7.7/S7.7_A2_T7.js
+++ b/test/suite/ch07/7.7/S7.7_A2_T7.js
@@ -7,7 +7,7 @@ info: >
     six characters, namely \u plus four hexadecimal digits
 es5id: 7.7_A2_T7
 description: Try to use + as a Unicode \u002B
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 1\u002B2;
diff --git a/test/suite/ch07/7.7/S7.7_A2_T8.js b/test/suite/ch07/7.7/S7.7_A2_T8.js
index a39e6a6fb7..7fd346dabb 100644
--- a/test/suite/ch07/7.7/S7.7_A2_T8.js
+++ b/test/suite/ch07/7.7/S7.7_A2_T8.js
@@ -7,7 +7,7 @@ info: >
     six characters, namely \u plus four hexadecimal digits
 es5id: 7.7_A2_T8
 description: Try to use -  as a Unicode \u002D
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 1\u002D2;
diff --git a/test/suite/ch07/7.7/S7.7_A2_T9.js b/test/suite/ch07/7.7/S7.7_A2_T9.js
index e625cfb99f..789a7d1e0e 100644
--- a/test/suite/ch07/7.7/S7.7_A2_T9.js
+++ b/test/suite/ch07/7.7/S7.7_A2_T9.js
@@ -7,7 +7,7 @@ info: >
     six characters, namely \u plus four hexadecimal digits
 es5id: 7.7_A2_T9
 description: Try to use * as a Unicode \u002A
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 1\u002A2;
diff --git a/test/suite/ch07/7.8/7.8.3/7.8.3-1gs.js b/test/suite/ch07/7.8/7.8.3/7.8.3-1gs.js
index 313736c5a7..9c080b8d9d 100644
--- a/test/suite/ch07/7.8/7.8.3/7.8.3-1gs.js
+++ b/test/suite/ch07/7.8/7.8.3/7.8.3-1gs.js
@@ -7,7 +7,7 @@
 /*---
 es5id: 7.8.3-1gs
 description: Strict Mode - octal extension(010) is forbidden in strict mode
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch07/7.8/7.8.3/7.8.3-2gs.js b/test/suite/ch07/7.8/7.8.3/7.8.3-2gs.js
index 40e5d4eca6..3c64a0c192 100644
--- a/test/suite/ch07/7.8/7.8.3/7.8.3-2gs.js
+++ b/test/suite/ch07/7.8/7.8.3/7.8.3-2gs.js
@@ -9,7 +9,7 @@ es5id: 7.8.3-2gs
 description: >
     Strict Mode - octal extension is forbidden in strict mode (after a
     hex number is assigned to a variable)
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T1.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T1.js
index 000dce748e..e1db008cb1 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T1.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T1.js
@@ -5,7 +5,7 @@
 info: "DecimalLiteral :: ExponentPart is incorrect"
 es5id: 7.8.3_A4.1_T1
 description: "ExponentPart :: e DecimalDigits"
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T2.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T2.js
index 6625ffdf27..5e65f18eac 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T2.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T2.js
@@ -5,7 +5,7 @@
 info: "DecimalLiteral :: ExponentPart is incorrect"
 es5id: 7.8.3_A4.1_T2
 description: "ExponentPart :: E DecimalDigits"
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T3.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T3.js
index 1d299cb344..c9c9a631bd 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T3.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T3.js
@@ -5,7 +5,7 @@
 info: "DecimalLiteral :: ExponentPart is incorrect"
 es5id: 7.8.3_A4.1_T3
 description: "ExponentPart :: e DecimalDigits"
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T4.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T4.js
index b8324463fb..c99ba6d18c 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T4.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T4.js
@@ -5,7 +5,7 @@
 info: "DecimalLiteral :: ExponentPart is incorrect"
 es5id: 7.8.3_A4.1_T4
 description: "ExponentPart :: E DecimalDigits"
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T5.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T5.js
index ece71ed0fa..3b26c5b4f0 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T5.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T5.js
@@ -5,7 +5,7 @@
 info: "DecimalLiteral :: ExponentPart is incorrect"
 es5id: 7.8.3_A4.1_T5
 description: "ExponentPart :: e DecimalDigits"
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T6.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T6.js
index f4c2710492..c3cf5e7cc0 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T6.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T6.js
@@ -5,7 +5,7 @@
 info: "DecimalLiteral :: ExponentPart is incorrect"
 es5id: 7.8.3_A4.1_T6
 description: "ExponentPart :: E DecimalDigits"
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T7.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T7.js
index b65398adce..5ae2cf0ace 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T7.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T7.js
@@ -5,7 +5,7 @@
 info: "DecimalLiteral :: ExponentPart is incorrect"
 es5id: 7.8.3_A4.1_T7
 description: "ExponentPart :: e 0"
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T8.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T8.js
index 7e56e0b129..9adcd08376 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T8.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A4.1_T8.js
@@ -5,7 +5,7 @@
 info: "DecimalLiteral :: ExponentPart is incorrect"
 es5id: 7.8.3_A4.1_T8
 description: "ExponentPart :: E 0"
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.1_T1.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.1_T1.js
index ece509cfca..23be70d68d 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.1_T1.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.1_T1.js
@@ -5,7 +5,7 @@
 info: "HexIntegerLiteral :: 0(x/X) is incorrect"
 es5id: 7.8.3_A6.1_T1
 description: Checking if execution of "0x" passes
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.1_T2.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.1_T2.js
index c99ba95879..ab511578fa 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.1_T2.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.1_T2.js
@@ -5,7 +5,7 @@
 info: "HexIntegerLiteral :: 0(x/X) is incorrect"
 es5id: 7.8.3_A6.1_T2
 description: Checking if execution of "0X" passes
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.2_T1.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.2_T1.js
index c5283e76dc..bb9870aa2e 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.2_T1.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.2_T1.js
@@ -5,7 +5,7 @@
 info: 0xG is incorrect
 es5id: 7.8.3_A6.2_T1
 description: Checking if execution of "0xG" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.2_T2.js b/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.2_T2.js
index 6fdd49ea23..db0ae747f4 100644
--- a/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.2_T2.js
+++ b/test/suite/ch07/7.8/7.8.3/S7.8.3_A6.2_T2.js
@@ -5,7 +5,7 @@
 info: 0xG is incorrect
 es5id: 7.8.3_A6.2_T2
 description: Checking if execution of "0xg" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/7.8.4-1gs.js b/test/suite/ch07/7.8/7.8.4/7.8.4-1gs.js
index e0cbd6d5a4..976e77bd8b 100644
--- a/test/suite/ch07/7.8/7.8.4/7.8.4-1gs.js
+++ b/test/suite/ch07/7.8/7.8.4/7.8.4-1gs.js
@@ -9,7 +9,7 @@ es5id: 7.8.4-1gs
 description: >
     Strict Mode - OctalEscapeSequence(\0110) is forbidden in strict
     mode
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.1_T1.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.1_T1.js
index 26e9ff8e6e..25e7947d1b 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.1_T1.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.1_T1.js
@@ -7,7 +7,7 @@ es5id: 7.8.4_A1.1_T1
 description: >
     DoubleStringCharacter :: SourceCharacter but not double-quote " or
     LineTerminator
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.1_T2.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.1_T2.js
index e9f19686d0..bd503769e8 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.1_T2.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.1_T2.js
@@ -7,7 +7,7 @@ es5id: 7.8.4_A1.1_T2
 description: >
     DoubleStringCharacter :: SourceCharacter but not double-quote " or
     LineTerminator
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.2_T1.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.2_T1.js
index 6d42906ef4..890a6b58e2 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.2_T1.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.2_T1.js
@@ -7,7 +7,7 @@ es5id: 7.8.4_A1.2_T1
 description: >
     SingleStringCharacter :: SourceCharacter but not single-quote ' or
     LineTerminator
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.2_T2.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.2_T2.js
index 2fee0e8d03..cd300d10f8 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.2_T2.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A1.2_T2.js
@@ -7,7 +7,7 @@ es5id: 7.8.4_A1.2_T2
 description: >
     SingleStringCharacter :: SourceCharacter but not single-quote ' or
     LineTerminator
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.1_T1.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.1_T1.js
index 7833281e1d..d575515300 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.1_T1.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.1_T1.js
@@ -5,7 +5,7 @@
 info: "StringLiteral :: \"\\\" or '\\' is not correct"
 es5id: 7.8.4_A3.1_T1
 description: Checking if execution of "\" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.1_T2.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.1_T2.js
index 41d611118d..eadb8d72b9 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.1_T2.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.1_T2.js
@@ -5,7 +5,7 @@
 info: "StringLiteral :: \"\\\" or '\\' is not correct"
 es5id: 7.8.4_A3.1_T2
 description: Checking if execution of "'\'" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.2_T1.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.2_T1.js
index 4e06f85249..4890f99acc 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.2_T1.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.2_T1.js
@@ -5,7 +5,7 @@
 info: "StringLiteral :: \"\\\\\\\" or '\\\\\\' is not correct"
 es5id: 7.8.4_A3.2_T1
 description: Checking if execution of "\\\" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.2_T2.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.2_T2.js
index a97f65464a..2f76790dcd 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.2_T2.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A3.2_T2.js
@@ -5,7 +5,7 @@
 info: "StringLiteral :: \"\\\\\\\" or '\\\\\\' is not correct"
 es5id: 7.8.4_A3.2_T2
 description: Checking if execution of '\\\' fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A4.3_T1.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A4.3_T1.js
index b0f5f43b1a..5d2e606528 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A4.3_T1.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A4.3_T1.js
@@ -5,9 +5,8 @@
 info: NonEscapeSequence is not EscapeCharacter
 es5id: 7.8.4_A4.3_T1
 description: "EscapeCharacter :: DecimalDigits :: 1"
-flags:
-    - onlyStrict
-    - negative
+negative: SyntaxError
+flags: [onlyStrict]
 ---*/
 
 "use strict";
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A4.3_T2.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A4.3_T2.js
index bf7cdd3f0d..5b55f54770 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A4.3_T2.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A4.3_T2.js
@@ -5,9 +5,8 @@
 info: NonEscapeSequence is not EscapeCharacter
 es5id: 7.8.4_A4.3_T2
 description: "EscapeCharacter :: DecimalDigits :: 7"
-flags:
-    - onlyStrict
-    - negative
+negative: SyntaxError
+flags: [onlyStrict]
 ---*/
 
 "use strict";
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.1_T4.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.1_T4.js
index 119d49822e..dc6d28dd51 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.1_T4.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.1_T4.js
@@ -7,7 +7,7 @@ info: >
     HexDigit
 es5id: 7.8.4_A7.1_T4
 description: "UnicodeEscapeSequence :: u000G is incorrect"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T1.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T1.js
index 5ead748858..59ce6a0423 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T1.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T1.js
@@ -5,7 +5,7 @@
 info: "UnicodeEscapeSequence :: u HexDigit (one, two or three time) is incorrect"
 es5id: 7.8.4_A7.2_T1
 description: ":: HexDigit :: 1"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T2.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T2.js
index 58cea9c898..df4f0582d1 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T2.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T2.js
@@ -5,7 +5,7 @@
 info: "UnicodeEscapeSequence :: u HexDigit (one, two or three time) is incorrect"
 es5id: 7.8.4_A7.2_T2
 description: ":: HexDigit :: A"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T3.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T3.js
index 37a53be1dd..a6ca9c6ec0 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T3.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T3.js
@@ -5,7 +5,7 @@
 info: "UnicodeEscapeSequence :: u HexDigit (one, two or three time) is incorrect"
 es5id: 7.8.4_A7.2_T3
 description: ":: HexDigit :: 1"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T4.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T4.js
index 791a7c9d4a..6a02030dca 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T4.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T4.js
@@ -5,7 +5,7 @@
 info: "UnicodeEscapeSequence :: u HexDigit (one, two or three time) is incorrect"
 es5id: 7.8.4_A7.2_T4
 description: ":: HexDigit :: A"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T5.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T5.js
index 7d25bb2c32..42d0aca8a5 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T5.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T5.js
@@ -5,7 +5,7 @@
 info: "UnicodeEscapeSequence :: u HexDigit (one, two or three time) is incorrect"
 es5id: 7.8.4_A7.2_T5
 description: ":: HexDigit :: 1"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T6.js b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T6.js
index a140caed84..462748fac7 100644
--- a/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T6.js
+++ b/test/suite/ch07/7.8/7.8.4/S7.8.4_A7.2_T6.js
@@ -5,7 +5,7 @@
 info: "UnicodeEscapeSequence :: u HexDigit (one, two or three time) is incorrect"
 es5id: 7.8.4_A7.2_T6
 description: ":: HexDigit :: A"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/7.8.5-1gs.js b/test/suite/ch07/7.8/7.8.5/7.8.5-1gs.js
index 6cad8ce678..4caa0b6083 100644
--- a/test/suite/ch07/7.8/7.8.5/7.8.5-1gs.js
+++ b/test/suite/ch07/7.8/7.8.5/7.8.5-1gs.js
@@ -1,14 +1,14 @@
-// Copyright (c) 2012 Ecma International.  All rights reserved.
-// Ecma International makes this code available under the terms and conditions set
-// forth on http://hg.ecmascript.org/tests/test262/raw-file/tip/LICENSE (the
-// "Use Terms").   Any redistribution of this code must retain the above
-// copyright and this notice and otherwise comply with the Use Terms.
-
-/*---
-es5id: 7.8.5-1gs
-description: Empty literal RegExp should result in a SyntaxError
-negative: ^((?!NotEarlyError).)*$
----*/
-
+// Copyright (c) 2012 Ecma International.  All rights reserved.
+// Ecma International makes this code available under the terms and conditions set
+// forth on http://hg.ecmascript.org/tests/test262/raw-file/tip/LICENSE (the
+// "Use Terms").   Any redistribution of this code must retain the above
+// copyright and this notice and otherwise comply with the Use Terms.
+
+/*---
+es5id: 7.8.5-1gs
+description: Empty literal RegExp should result in a SyntaxError
+negative: SyntaxError
+---*/
+
 throw NotEarlyError;
-var re = //;
+var re = //;
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T1.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T1.js
index 4f285a3323..0d75cd4821 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T1.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T1.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionFirstChar :: * or \\ or / or [empty] is incorrect"
 es5id: 7.8.5_A1.2_T1
 description: "*"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T2.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T2.js
index f5788af9ac..fec6db97ca 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T2.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T2.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionFirstChar :: * or \\ or / or [empty] is incorrect"
 es5id: 7.8.5_A1.2_T2
 description: \
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T3.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T3.js
index 1f83641ebc..ea5a41b552 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T3.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T3.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionFirstChar :: * or \\ or / or [empty] is incorrect"
 es5id: 7.8.5_A1.2_T3
 description: /
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T4.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T4.js
index c8e613b474..599c6fdc9f 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T4.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.2_T4.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionFirstChar :: * or \\ or / or [empty] is incorrect"
 es5id: 7.8.5_A1.2_T4
 description: "[empty]"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.3_T1.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.3_T1.js
index 03a40762f7..7b49ef35a7 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.3_T1.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.3_T1.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionFirstChar :: LineTerminator is incorrect"
 es5id: 7.8.5_A1.3_T1
 description: Line Feed, without eval
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.3_T3.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.3_T3.js
index eb6727ff3b..e7c78e764d 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.3_T3.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.3_T3.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionFirstChar :: LineTerminator is incorrect"
 es5id: 7.8.5_A1.3_T3
 description: Carriage Return, without eval
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.5_T1.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.5_T1.js
index d691a51e3f..b5f81b0736 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.5_T1.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.5_T1.js
@@ -7,7 +7,7 @@ info: >
     incorrect
 es5id: 7.8.5_A1.5_T1
 description: Line Feed, without eval
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.5_T3.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.5_T3.js
index fd05081ab6..03a4bf320d 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.5_T3.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A1.5_T3.js
@@ -7,7 +7,7 @@ info: >
     incorrect
 es5id: 7.8.5_A1.5_T3
 description: Carriage Return, without eval
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.2_T1.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.2_T1.js
index a177c10296..602269b52e 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.2_T1.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.2_T1.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionChar :: \\ or / is incorrect"
 es5id: 7.8.5_A2.2_T1
 description: \
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.2_T2.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.2_T2.js
index 4c6b4235c5..e9d02eedc1 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.2_T2.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.2_T2.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionChar :: \\ or / is incorrect"
 es5id: 7.8.5_A2.2_T2
 description: /
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.3_T1.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.3_T1.js
index 508d99009e..667e771cec 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.3_T1.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.3_T1.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionChar :: LineTerminator is incorrect"
 es5id: 7.8.5_A2.3_T1
 description: Line Feed, without eval
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.3_T3.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.3_T3.js
index 437b6737ad..2cc2cda825 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.3_T3.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.3_T3.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionChar :: LineTerminator is incorrect"
 es5id: 7.8.5_A2.3_T3
 description: Carriage Return, without eval
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.5_T1.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.5_T1.js
index 6c901c6e1b..44bd5da499 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.5_T1.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.5_T1.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionChar :: BackslashSequence :: \\LineTerminator is incorrect"
 es5id: 7.8.5_A2.5_T1
 description: Line Feed, without eval
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.5_T3.js b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.5_T3.js
index 414da68fba..64afbad549 100644
--- a/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.5_T3.js
+++ b/test/suite/ch07/7.8/7.8.5/S7.8.5_A2.5_T3.js
@@ -5,7 +5,7 @@
 info: "RegularExpressionChar :: BackslashSequence :: \\LineTerminator is incorrect"
 es5id: 7.8.5_A2.5_T3
 description: Carriage Return, without eval
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T1.js b/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T1.js
index 873318739a..5a7921e8de 100644
--- a/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T1.js
+++ b/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T1.js
@@ -5,7 +5,7 @@
 info: Check examples for automatic semicolon insertion from the Standart
 es5id: 7.9.2_A1_T1
 description: "{ 1 2 } 3 is not a valid sentence in the ECMAScript grammar"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T3.js b/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T3.js
index 96ada674c9..5cb51f5d0f 100644
--- a/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T3.js
+++ b/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T3.js
@@ -5,7 +5,7 @@
 info: Check examples for automatic semicolon insertion from the Standart
 es5id: 7.9.2_A1_T3
 description: for( a ; b \n ) is not a valid sentence in the ECMAScript grammar
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T6.js b/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T6.js
index 1873d39921..c7eeea2c76 100644
--- a/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T6.js
+++ b/test/suite/ch07/7.9/7.9.2/S7.9.2_A1_T6.js
@@ -7,7 +7,7 @@ es5id: 7.9.2_A1_T6
 description: >
     if(a>b) \n else c=d is not a valid sentence in the ECMAScript
     grammar
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A10_T2.js b/test/suite/ch07/7.9/S7.9_A10_T2.js
index b028e20fbf..b99ed68c42 100644
--- a/test/suite/ch07/7.9/S7.9_A10_T2.js
+++ b/test/suite/ch07/7.9/S7.9_A10_T2.js
@@ -5,7 +5,7 @@
 info: Check {} for automatic semicolon insertion
 es5id: 7.9_A10_T2
 description: Checking if execution of "{}*1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A10_T4.js b/test/suite/ch07/7.9/S7.9_A10_T4.js
index 80ee69fa1f..bf2a59e98f 100644
--- a/test/suite/ch07/7.9/S7.9_A10_T4.js
+++ b/test/suite/ch07/7.9/S7.9_A10_T4.js
@@ -5,7 +5,7 @@
 info: Check {} for automatic semicolon insertion
 es5id: 7.9_A10_T4
 description: Checking if execution of "({};)*1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A10_T6.js b/test/suite/ch07/7.9/S7.9_A10_T6.js
index e4b4e6826a..36f462f9ac 100644
--- a/test/suite/ch07/7.9/S7.9_A10_T6.js
+++ b/test/suite/ch07/7.9/S7.9_A10_T6.js
@@ -5,7 +5,7 @@
 info: Check {} for automatic semicolon insertion
 es5id: 7.9_A10_T6
 description: Checking if execution of "{} \n * 1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A10_T8.js b/test/suite/ch07/7.9/S7.9_A10_T8.js
index 27ca52fff2..c439b1599d 100644
--- a/test/suite/ch07/7.9/S7.9_A10_T8.js
+++ b/test/suite/ch07/7.9/S7.9_A10_T8.js
@@ -5,7 +5,7 @@
 info: Check {} for automatic semicolon insertion
 es5id: 7.9_A10_T8
 description: Checking if execution of "{1 2} 3" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A11_T4.js b/test/suite/ch07/7.9/S7.9_A11_T4.js
index e2a63e8cc0..45663bcee8 100644
--- a/test/suite/ch07/7.9/S7.9_A11_T4.js
+++ b/test/suite/ch07/7.9/S7.9_A11_T4.js
@@ -5,7 +5,7 @@
 info: Check If Statement for automatic semicolon insertion
 es5id: 7.9_A11_T4
 description: Checking if execution of "if (false) x = 1 else x = -1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A11_T8.js b/test/suite/ch07/7.9/S7.9_A11_T8.js
index 3356f1f3cf..314d52781e 100644
--- a/test/suite/ch07/7.9/S7.9_A11_T8.js
+++ b/test/suite/ch07/7.9/S7.9_A11_T8.js
@@ -5,7 +5,7 @@
 info: Check If Statement for automatic semicolon insertion
 es5id: 7.9_A11_T8
 description: Use if (false) {x = 1}; \n else x=-1 and check x
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A4.js b/test/suite/ch07/7.9/S7.9_A4.js
index 73cb507c47..35a0143525 100644
--- a/test/suite/ch07/7.9/S7.9_A4.js
+++ b/test/suite/ch07/7.9/S7.9_A4.js
@@ -5,7 +5,7 @@
 info: Check Throw Statement for automatic semicolon insertion
 es5id: 7.9_A4
 description: Try use Throw \n Expression construction
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A5.1_T1.js b/test/suite/ch07/7.9/S7.9_A5.1_T1.js
index 022c45fe5a..e8d2d9e782 100644
--- a/test/suite/ch07/7.9/S7.9_A5.1_T1.js
+++ b/test/suite/ch07/7.9/S7.9_A5.1_T1.js
@@ -5,7 +5,7 @@
 info: Check Postfix Increment Operator for automatic semicolon insertion
 es5id: 7.9_A5.1_T1
 description: Try use Variable \n ++ construction
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A5.3_T1.js b/test/suite/ch07/7.9/S7.9_A5.3_T1.js
index e075106956..402f82b610 100644
--- a/test/suite/ch07/7.9/S7.9_A5.3_T1.js
+++ b/test/suite/ch07/7.9/S7.9_A5.3_T1.js
@@ -5,7 +5,7 @@
 info: Check Postfix Decrement Operator for automatic semicolon insertion
 es5id: 7.9_A5.3_T1
 description: Try use Variable \n -- construction
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A5.7_T1.js b/test/suite/ch07/7.9/S7.9_A5.7_T1.js
index ccaddcc05e..d61fc10158 100644
--- a/test/suite/ch07/7.9/S7.9_A5.7_T1.js
+++ b/test/suite/ch07/7.9/S7.9_A5.7_T1.js
@@ -3,11 +3,16 @@
 
 /*---
 info: >
-    Since LineTerminator(LT) between Postfix Increment/Decrement Operator(I/DO) and operand is not allowed, two IO(just as two DO and their combination)
-    between two references separated by [LT] after automatic semicolon insertion lead to syntax error
+
+    Since LineTerminator(LT) between Postfix Increment/Decrement
+    Operator(I/DO) and operand is not allowed, two IO(just as two DO
+    and their combination) between two references separated by [LT]
+    after automatic semicolon insertion lead to syntax error
+    ES6 specifies this as `ReferenceError`
+
 es5id: 7.9_A5.7_T1
 description: Try use Variable1 \n ++ \n ++ \n Variable2 construction
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 var x=0, y=0;
diff --git a/test/suite/ch07/7.9/S7.9_A6.2_T1.js b/test/suite/ch07/7.9/S7.9_A6.2_T1.js
index b7d11f8df1..7134816e22 100644
--- a/test/suite/ch07/7.9/S7.9_A6.2_T1.js
+++ b/test/suite/ch07/7.9/S7.9_A6.2_T1.js
@@ -8,7 +8,7 @@ info: >
     Use one semicolon
 es5id: 7.9_A6.2_T1
 description: For header is (semicolon \n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.2_T10.js b/test/suite/ch07/7.9/S7.9_A6.2_T10.js
index c86136d070..201d739552 100644
--- a/test/suite/ch07/7.9/S7.9_A6.2_T10.js
+++ b/test/suite/ch07/7.9/S7.9_A6.2_T10.js
@@ -8,7 +8,7 @@ info: >
     Use one semicolon
 es5id: 7.9_A6.2_T10
 description: For header is (\n false \n semicolon)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.2_T2.js b/test/suite/ch07/7.9/S7.9_A6.2_T2.js
index 8a9a3f16dc..8ada9e295b 100644
--- a/test/suite/ch07/7.9/S7.9_A6.2_T2.js
+++ b/test/suite/ch07/7.9/S7.9_A6.2_T2.js
@@ -8,7 +8,7 @@ info: >
     Use one semicolon
 es5id: 7.9_A6.2_T2
 description: For header is (\n semicolon \n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.2_T3.js b/test/suite/ch07/7.9/S7.9_A6.2_T3.js
index ff6df09530..c6e8e6e478 100644
--- a/test/suite/ch07/7.9/S7.9_A6.2_T3.js
+++ b/test/suite/ch07/7.9/S7.9_A6.2_T3.js
@@ -8,7 +8,7 @@ info: >
     Use one semicolon
 es5id: 7.9_A6.2_T3
 description: For header is (\n semicolon)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.2_T4.js b/test/suite/ch07/7.9/S7.9_A6.2_T4.js
index 6e938b54b6..5daf51dc7a 100644
--- a/test/suite/ch07/7.9/S7.9_A6.2_T4.js
+++ b/test/suite/ch07/7.9/S7.9_A6.2_T4.js
@@ -8,7 +8,7 @@ info: >
     Use one semicolon
 es5id: 7.9_A6.2_T4
 description: For header is (\n \n semicolon)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.2_T5.js b/test/suite/ch07/7.9/S7.9_A6.2_T5.js
index 5a736005c2..27ffc7c287 100644
--- a/test/suite/ch07/7.9/S7.9_A6.2_T5.js
+++ b/test/suite/ch07/7.9/S7.9_A6.2_T5.js
@@ -8,7 +8,7 @@ info: >
     Use one semicolon
 es5id: 7.9_A6.2_T5
 description: For header is (false semicolon false\n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.2_T6.js b/test/suite/ch07/7.9/S7.9_A6.2_T6.js
index 7c9f03e5c9..2cb7e7b3cc 100644
--- a/test/suite/ch07/7.9/S7.9_A6.2_T6.js
+++ b/test/suite/ch07/7.9/S7.9_A6.2_T6.js
@@ -8,7 +8,7 @@ info: >
     Use one semicolon
 es5id: 7.9_A6.2_T6
 description: For header is (false semicolon \n false)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.2_T7.js b/test/suite/ch07/7.9/S7.9_A6.2_T7.js
index a96ad0b0b9..98e1c25342 100644
--- a/test/suite/ch07/7.9/S7.9_A6.2_T7.js
+++ b/test/suite/ch07/7.9/S7.9_A6.2_T7.js
@@ -8,7 +8,7 @@ info: >
     Use one semicolon
 es5id: 7.9_A6.2_T7
 description: For header is (false \n semicolon \n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.2_T8.js b/test/suite/ch07/7.9/S7.9_A6.2_T8.js
index 5f8a513619..622bcae489 100644
--- a/test/suite/ch07/7.9/S7.9_A6.2_T8.js
+++ b/test/suite/ch07/7.9/S7.9_A6.2_T8.js
@@ -8,7 +8,7 @@ info: >
     Use one semicolon
 es5id: 7.9_A6.2_T8
 description: For header is (false \n semicolon false \n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.2_T9.js b/test/suite/ch07/7.9/S7.9_A6.2_T9.js
index ea04419767..67588f2c04 100644
--- a/test/suite/ch07/7.9/S7.9_A6.2_T9.js
+++ b/test/suite/ch07/7.9/S7.9_A6.2_T9.js
@@ -8,7 +8,7 @@ info: >
     Use one semicolon
 es5id: 7.9_A6.2_T9
 description: For header is (\n semicolon false)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.3_T1.js b/test/suite/ch07/7.9/S7.9_A6.3_T1.js
index 8b774ddb20..84a1e927ff 100644
--- a/test/suite/ch07/7.9/S7.9_A6.3_T1.js
+++ b/test/suite/ch07/7.9/S7.9_A6.3_T1.js
@@ -8,7 +8,7 @@ info: >
     Don`t use semicolons
 es5id: 7.9_A6.3_T1
 description: For header is (\n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.3_T2.js b/test/suite/ch07/7.9/S7.9_A6.3_T2.js
index 0b3b703570..73c9ae4dc2 100644
--- a/test/suite/ch07/7.9/S7.9_A6.3_T2.js
+++ b/test/suite/ch07/7.9/S7.9_A6.3_T2.js
@@ -8,7 +8,7 @@ info: >
     Don`t use semicolons
 es5id: 7.9_A6.3_T2
 description: For header is (\n \n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.3_T3.js b/test/suite/ch07/7.9/S7.9_A6.3_T3.js
index 8d39015d5b..ed7bc7c148 100644
--- a/test/suite/ch07/7.9/S7.9_A6.3_T3.js
+++ b/test/suite/ch07/7.9/S7.9_A6.3_T3.js
@@ -8,7 +8,7 @@ info: >
     Don`t use semicolons
 es5id: 7.9_A6.3_T3
 description: For header is (\n \n \n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.3_T4.js b/test/suite/ch07/7.9/S7.9_A6.3_T4.js
index acbd8dc15c..334cffb1c7 100644
--- a/test/suite/ch07/7.9/S7.9_A6.3_T4.js
+++ b/test/suite/ch07/7.9/S7.9_A6.3_T4.js
@@ -8,7 +8,7 @@ info: >
     Don`t use semicolons
 es5id: 7.9_A6.3_T4
 description: For header is (\n false \n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.3_T5.js b/test/suite/ch07/7.9/S7.9_A6.3_T5.js
index fb291d5000..da20591fff 100644
--- a/test/suite/ch07/7.9/S7.9_A6.3_T5.js
+++ b/test/suite/ch07/7.9/S7.9_A6.3_T5.js
@@ -8,7 +8,7 @@ info: >
     Don`t use semicolons
 es5id: 7.9_A6.3_T5
 description: For header is (false \n false \n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.3_T6.js b/test/suite/ch07/7.9/S7.9_A6.3_T6.js
index 5f185b600b..a456b4907a 100644
--- a/test/suite/ch07/7.9/S7.9_A6.3_T6.js
+++ b/test/suite/ch07/7.9/S7.9_A6.3_T6.js
@@ -8,7 +8,7 @@ info: >
     Don`t use semicolons
 es5id: 7.9_A6.3_T6
 description: For header is (\n false \n false \n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.3_T7.js b/test/suite/ch07/7.9/S7.9_A6.3_T7.js
index 3fd1a1fd56..4289645a1c 100644
--- a/test/suite/ch07/7.9/S7.9_A6.3_T7.js
+++ b/test/suite/ch07/7.9/S7.9_A6.3_T7.js
@@ -8,7 +8,7 @@ info: >
     Don`t use semicolons
 es5id: 7.9_A6.3_T7
 description: For header is (\n false \n false \n false \n)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.4_T1.js b/test/suite/ch07/7.9/S7.9_A6.4_T1.js
index d41d81e28a..1d58d7249f 100644
--- a/test/suite/ch07/7.9/S7.9_A6.4_T1.js
+++ b/test/suite/ch07/7.9/S7.9_A6.4_T1.js
@@ -7,7 +7,7 @@ es5id: 7.9_A6.4_T1
 description: >
     Three semicolons. For header is (false semicolon false semicolon
     false semicolon)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A6.4_T2.js b/test/suite/ch07/7.9/S7.9_A6.4_T2.js
index d89eeb5980..7eb567287c 100644
--- a/test/suite/ch07/7.9/S7.9_A6.4_T2.js
+++ b/test/suite/ch07/7.9/S7.9_A6.4_T2.js
@@ -7,7 +7,7 @@ es5id: 7.9_A6.4_T2
 description: >
     Three semicolons. For header is (false semicolon false two
     semicolons false)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A7_T7.js b/test/suite/ch07/7.9/S7.9_A7_T7.js
index fc314abc50..bc570566f2 100644
--- a/test/suite/ch07/7.9/S7.9_A7_T7.js
+++ b/test/suite/ch07/7.9/S7.9_A7_T7.js
@@ -5,7 +5,7 @@
 info: Check Var Statement for automatic semicolon insertion
 es5id: 7.9_A7_T7
 description: Checking if execution of "var x \n y" passes
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A9_T6.js b/test/suite/ch07/7.9/S7.9_A9_T6.js
index 95119d67f3..0457fe3911 100644
--- a/test/suite/ch07/7.9/S7.9_A9_T6.js
+++ b/test/suite/ch07/7.9/S7.9_A9_T6.js
@@ -5,7 +5,7 @@
 info: Check Do-While Statement for automatic semicolon insertion
 es5id: 7.9_A9_T6
 description: Execute do \n while(false)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A9_T7.js b/test/suite/ch07/7.9/S7.9_A9_T7.js
index 70264d0d47..3d2fe4aefa 100644
--- a/test/suite/ch07/7.9/S7.9_A9_T7.js
+++ b/test/suite/ch07/7.9/S7.9_A9_T7.js
@@ -5,7 +5,7 @@
 info: Check Do-While Statement for automatic semicolon insertion
 es5id: 7.9_A9_T7
 description: Execute do \n\n while(false)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch07/7.9/S7.9_A9_T8.js b/test/suite/ch07/7.9/S7.9_A9_T8.js
index 847f2ac099..70f5d851f5 100644
--- a/test/suite/ch07/7.9/S7.9_A9_T8.js
+++ b/test/suite/ch07/7.9/S7.9_A9_T8.js
@@ -5,7 +5,7 @@
 info: Check Do-While Statement for automatic semicolon insertion
 es5id: 7.9_A9_T8
 description: Execute do {}; \n while(false)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch08/8.2/S8.2_A2.js b/test/suite/ch08/8.2/S8.2_A2.js
index fbd42c6760..620e1ea06b 100644
--- a/test/suite/ch08/8.2/S8.2_A2.js
+++ b/test/suite/ch08/8.2/S8.2_A2.js
@@ -5,7 +5,7 @@
 info: The null is resrved word
 es5id: 8.2_A2
 description: Checking if execution of "var null" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var null;
diff --git a/test/suite/ch08/8.3/S8.3_A2.1.js b/test/suite/ch08/8.3/S8.3_A2.1.js
index 55f2f83cc1..1a15285385 100644
--- a/test/suite/ch08/8.3/S8.3_A2.1.js
+++ b/test/suite/ch08/8.3/S8.3_A2.1.js
@@ -5,7 +5,7 @@
 info: The true is reserved word
 es5id: 8.3_A2.1
 description: Checking if execution of "true=1" fails
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 true = 1;
diff --git a/test/suite/ch08/8.3/S8.3_A2.2.js b/test/suite/ch08/8.3/S8.3_A2.2.js
index 9258a21810..8a254e3390 100644
--- a/test/suite/ch08/8.3/S8.3_A2.2.js
+++ b/test/suite/ch08/8.3/S8.3_A2.2.js
@@ -5,7 +5,7 @@
 info: The false is reserved word
 es5id: 8.3_A2.2
 description: Checking if execution of "false=0" fails
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 false = 0;
diff --git a/test/suite/ch08/8.4/S8.4_A13_T1.js b/test/suite/ch08/8.4/S8.4_A13_T1.js
index 46841c4a5d..60d047be9f 100644
--- a/test/suite/ch08/8.4/S8.4_A13_T1.js
+++ b/test/suite/ch08/8.4/S8.4_A13_T1.js
@@ -5,7 +5,7 @@
 info: When appears not closed single-quote program failes
 es5id: 8.4_A13_T1
 description: Try to create variable using 3 single-quote
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var str = ''';
diff --git a/test/suite/ch08/8.4/S8.4_A13_T2.js b/test/suite/ch08/8.4/S8.4_A13_T2.js
index e13fabf743..c4912bd52b 100644
--- a/test/suite/ch08/8.4/S8.4_A13_T2.js
+++ b/test/suite/ch08/8.4/S8.4_A13_T2.js
@@ -5,7 +5,7 @@
 info: When appears not closed single-quote program failes
 es5id: 8.4_A13_T2
 description: Try to create variable using 1 single-quote
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var str = ';
diff --git a/test/suite/ch08/8.4/S8.4_A13_T3.js b/test/suite/ch08/8.4/S8.4_A13_T3.js
index 444e34f243..7a028d6fb4 100644
--- a/test/suite/ch08/8.4/S8.4_A13_T3.js
+++ b/test/suite/ch08/8.4/S8.4_A13_T3.js
@@ -5,7 +5,7 @@
 info: When appears not closed single-quote program failes
 es5id: 8.4_A13_T3
 description: Try to create variable using 4 single-quote
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var str = '''';
diff --git a/test/suite/ch08/8.4/S8.4_A14_T1.js b/test/suite/ch08/8.4/S8.4_A14_T1.js
index 802e3fa28b..80def88b06 100644
--- a/test/suite/ch08/8.4/S8.4_A14_T1.js
+++ b/test/suite/ch08/8.4/S8.4_A14_T1.js
@@ -5,7 +5,7 @@
 info: When appears not closed double-quote program failes
 es5id: 8.4_A14_T1
 description: Try to create variable using 1 double-quote
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var str = ";
diff --git a/test/suite/ch08/8.4/S8.4_A14_T2.js b/test/suite/ch08/8.4/S8.4_A14_T2.js
index fa07f66622..21a9804214 100644
--- a/test/suite/ch08/8.4/S8.4_A14_T2.js
+++ b/test/suite/ch08/8.4/S8.4_A14_T2.js
@@ -5,7 +5,7 @@
 info: When appears not closed double-quote program failes
 es5id: 8.4_A14_T2
 description: Try to create variable using 3 double-quote
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var str = """;
diff --git a/test/suite/ch08/8.4/S8.4_A14_T3.js b/test/suite/ch08/8.4/S8.4_A14_T3.js
index bd3d8919bf..40d8743acd 100644
--- a/test/suite/ch08/8.4/S8.4_A14_T3.js
+++ b/test/suite/ch08/8.4/S8.4_A14_T3.js
@@ -5,7 +5,7 @@
 info: When appears not closed double-quote program failes
 es5id: 8.4_A14_T3
 description: Try to create variable using 4 double-quote
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var str = """";
diff --git a/test/suite/ch08/8.4/S8.4_A7.1.js b/test/suite/ch08/8.4/S8.4_A7.1.js
index 9249c0e060..5479cf8b33 100644
--- a/test/suite/ch08/8.4/S8.4_A7.1.js
+++ b/test/suite/ch08/8.4/S8.4_A7.1.js
@@ -5,7 +5,7 @@
 info: <LF> between chunks of one string not allowed
 es5id: 8.4_A7.1
 description: Insert <LF> between chunks of one string
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 eval("var x = asdf\u000Aghjk");
diff --git a/test/suite/ch08/8.4/S8.4_A7.2.js b/test/suite/ch08/8.4/S8.4_A7.2.js
index fa0187002c..fa50f85693 100644
--- a/test/suite/ch08/8.4/S8.4_A7.2.js
+++ b/test/suite/ch08/8.4/S8.4_A7.2.js
@@ -5,7 +5,7 @@
 info: <CR> between chunks of one string not allowed
 es5id: 8.4_A7.2
 description: Insert <CR> between chunks of one string
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 eval("var x = asdf\u000Dghjk");
diff --git a/test/suite/ch08/8.4/S8.4_A7.3.js b/test/suite/ch08/8.4/S8.4_A7.3.js
index 70a746e932..2320a56a32 100644
--- a/test/suite/ch08/8.4/S8.4_A7.3.js
+++ b/test/suite/ch08/8.4/S8.4_A7.3.js
@@ -5,7 +5,7 @@
 info: <PS> between chunks of one string not allowed
 es5id: 8.4_A7.3
 description: Insert <PS> between chunks of one string
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 eval("var x = asdf\u2028ghjk");
diff --git a/test/suite/ch08/8.4/S8.4_A7.4.js b/test/suite/ch08/8.4/S8.4_A7.4.js
index 32ea695bb7..82c79bb5b5 100644
--- a/test/suite/ch08/8.4/S8.4_A7.4.js
+++ b/test/suite/ch08/8.4/S8.4_A7.4.js
@@ -5,7 +5,7 @@
 info: <LS> between chunks of one string not allowed
 es5id: 8.4_A7.4
 description: Insert <LS> between chunks of one string
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 eval("var x = asdf\u2029ghjk");
diff --git a/test/suite/ch08/8.6/8.6.2/S8.6.2_A7.js b/test/suite/ch08/8.6/8.6.2/S8.6.2_A7.js
index eee46c1815..a75b9ef0e5 100644
--- a/test/suite/ch08/8.6/8.6.2/S8.6.2_A7.js
+++ b/test/suite/ch08/8.6/8.6.2/S8.6.2_A7.js
@@ -7,7 +7,7 @@ info: >
     constructors. Math object is NOT constructor
 es5id: 8.6.2_A7
 description: Checking if execution of "var objMath=new Math" passes
-flags: [negative]
+negative: TypeError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch08/8.7/S8.7.2_A1_T1.js b/test/suite/ch08/8.7/S8.7.2_A1_T1.js
index d6a75cf5bd..e023f355d4 100644
--- a/test/suite/ch08/8.7/S8.7.2_A1_T1.js
+++ b/test/suite/ch08/8.7/S8.7.2_A1_T1.js
@@ -5,7 +5,7 @@
 info: GetValue(V) mast fail
 es5id: 8.7.2_A1_T1
 description: Checking if execution of "'litera'=1;" fails
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 'litera'=1;
diff --git a/test/suite/ch08/8.7/S8.7.2_A1_T2.js b/test/suite/ch08/8.7/S8.7.2_A1_T2.js
index a26bf80d8a..b59fda7b41 100644
--- a/test/suite/ch08/8.7/S8.7.2_A1_T2.js
+++ b/test/suite/ch08/8.7/S8.7.2_A1_T2.js
@@ -5,7 +5,7 @@
 info: GetValue(V) mast fail
 es5id: 8.7.2_A1_T2
 description: Checking if execution of "1=1" fails
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 1=1;
diff --git a/test/suite/ch10/10.1/10.1.1/10.1.1-2gs.js b/test/suite/ch10/10.1/10.1.1/10.1.1-2gs.js
index 0c2dbe840e..da0a123e97 100644
--- a/test/suite/ch10/10.1/10.1.1/10.1.1-2gs.js
+++ b/test/suite/ch10/10.1/10.1.1/10.1.1-2gs.js
@@ -9,7 +9,7 @@ es5id: 10.1.1-2gs
 description: >
     Strict Mode - Use Strict Directive Prologue is ''use strict''
     which lost the last character ';'
-negative: ^((?!NotEarlyError).)*$
+negative: NotEarlyError
 flags: [noStrict]
 ---*/
 
diff --git a/test/suite/ch10/10.1/10.1.1/10.1.1-5gs.js b/test/suite/ch10/10.1/10.1.1/10.1.1-5gs.js
index 3b0c23dcfc..5b31cfe11a 100644
--- a/test/suite/ch10/10.1/10.1.1/10.1.1-5gs.js
+++ b/test/suite/ch10/10.1/10.1.1/10.1.1-5gs.js
@@ -9,7 +9,7 @@ es5id: 10.1.1-5gs
 description: >
     Strict Mode - Use Strict Directive Prologue is ''use strict';'
     which appears at the start of the code
-negative: ^((?!NotEarlyError).)*$
+negative: NotEarlyError
 flags: [noStrict]
 ---*/
 
diff --git a/test/suite/ch10/10.1/10.1.1/10.1.1-8gs.js b/test/suite/ch10/10.1/10.1.1/10.1.1-8gs.js
index 518b4e9464..5d141ad06a 100644
--- a/test/suite/ch10/10.1/10.1.1/10.1.1-8gs.js
+++ b/test/suite/ch10/10.1/10.1.1/10.1.1-8gs.js
@@ -9,7 +9,7 @@ es5id: 10.1.1-8gs
 description: >
     Strict Mode - Use Strict Directive Prologue is ''use strict';'
     which appears twice in the code
-negative: ^((?!NotEarlyError).)*$
+negative: NotEarlyError
 flags: [noStrict]
 ---*/
 
diff --git a/test/suite/ch10/10.4/10.4.2/10.4.2.1-1gs.js b/test/suite/ch10/10.4/10.4.2/10.4.2.1-1gs.js
index b786bdb839..75f49ccbb5 100644
--- a/test/suite/ch10/10.4/10.4.2/10.4.2.1-1gs.js
+++ b/test/suite/ch10/10.4/10.4.2/10.4.2.1-1gs.js
@@ -10,7 +10,7 @@ description: >
     Strict Mode - eval code cannot instantiate variable in the
     variable environment of the calling context that invoked the eval
     if the code of the calling context is strict code
-negative: ^((?!NotEarlyError).)*$
+negative: ReferenceError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch10/10.5/10.5-1gs.js b/test/suite/ch10/10.5/10.5-1gs.js
index 7e94a44c28..b7be54878e 100644
--- a/test/suite/ch10/10.5/10.5-1gs.js
+++ b/test/suite/ch10/10.5/10.5-1gs.js
@@ -7,7 +7,7 @@
 /*---
 es5id: 10.5-1gs
 description: Strict Mode - arguments cannot be assigned to in a strict function
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch11/11.1/11.1.1/S11.1.1_A1.js b/test/suite/ch11/11.1/11.1.1/S11.1.1_A1.js
index 3932674f57..922253a167 100644
--- a/test/suite/ch11/11.1/11.1.1/S11.1.1_A1.js
+++ b/test/suite/ch11/11.1/11.1.1/S11.1.1_A1.js
@@ -5,7 +5,7 @@
 info: The "this" is reserved word
 es5id: 11.1.1_A1
 description: Checking if execution of "this=1" fails
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 this = 1;
diff --git a/test/suite/ch11/11.1/11.1.5/11.1.5-1gs.js b/test/suite/ch11/11.1/11.1.5/11.1.5-1gs.js
index d05c3479fe..8cb4d4762f 100644
--- a/test/suite/ch11/11.1/11.1.5/11.1.5-1gs.js
+++ b/test/suite/ch11/11.1/11.1.5/11.1.5-1gs.js
@@ -10,7 +10,7 @@ description: >
     Strict Mode - SyntaxError is thrown when 'eval' occurs as the
     Identifier in a PropertySetParameterList of a PropertyAssignment
     that is contained in strict code
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch11/11.1/11.1.5/11.1.5-2gs.js b/test/suite/ch11/11.1/11.1.5/11.1.5-2gs.js
index 19d13b794b..a64847246e 100644
--- a/test/suite/ch11/11.1/11.1.5/11.1.5-2gs.js
+++ b/test/suite/ch11/11.1/11.1.5/11.1.5-2gs.js
@@ -9,7 +9,7 @@ es5id: 11.1.5-2gs
 description: >
     Strict Mode - SyntaxError is thrown when eval code contains an
     ObjectLiteral with more than one definition of any data property
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch11/11.13/11.13.1/11.13.1-4-28gs.js b/test/suite/ch11/11.13/11.13.1/11.13.1-4-28gs.js
index fa6945babb..5f9873637a 100644
--- a/test/suite/ch11/11.13/11.13.1/11.13.1-4-28gs.js
+++ b/test/suite/ch11/11.13/11.13.1/11.13.1-4-28gs.js
@@ -7,13 +7,11 @@
 /*---
 es5id: 11.13.1-4-28gs
 description: >
-    Strict Mode - SyntaxError is thrown if the identifier 'Math.PI'
+    Strict Mode - TypeError is thrown if the identifier 'Math.PI'
     appears as the LeftHandSideExpression of simple assignment(=)
-negative: Test262Error
+negative: TypeError
 flags: [onlyStrict]
-includes: [Test262Error.js]
 ---*/
 
 "use strict";
-throw new Test262Error();
 Math.PI = 20;
diff --git a/test/suite/ch11/11.13/11.13.1/S11.13.1_A2.1_T3.js b/test/suite/ch11/11.13/11.13.1/S11.13.1_A2.1_T3.js
index d0eab54201..17eef53cf5 100644
--- a/test/suite/ch11/11.13/11.13.1/S11.13.1_A2.1_T3.js
+++ b/test/suite/ch11/11.13/11.13.1/S11.13.1_A2.1_T3.js
@@ -6,18 +6,18 @@ info: Operator x = y uses GetValue and PutValue
 es5id: 11.13.1_A2.1_T3
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError)
-flags: [negative]
+    ReferenceError
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   1 = 1;
-  $ERROR('#1.1: 1 = 1 throw ReferenceError (or SyntaxError). Actual: ' + (1 = 1));  
+  $ERROR('#1.1: 1 = 1 throw ReferenceError. Actual: ' + (1 = 1));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 = 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 = 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     1 = 1;
   }
diff --git a/test/suite/ch11/11.13/11.13.2/11.13.2-6-1gs.js b/test/suite/ch11/11.13/11.13.2/11.13.2-6-1gs.js
index 92393573f1..d6b746f8ac 100644
--- a/test/suite/ch11/11.13/11.13.2/11.13.2-6-1gs.js
+++ b/test/suite/ch11/11.13/11.13.2/11.13.2-6-1gs.js
@@ -9,10 +9,9 @@ es5id: 11.13.2-6-1gs
 description: >
     Strict Mode - SyntaxError is throw if the identifier eval appears
     as the LeftHandSideExpression of a Compound Assignment operator(*=)
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
 "use strict";
-throw NotEarlyError;
 eval *= 20;
diff --git a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T1.js b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T1.js
index a09ee7f06b..0d2f2da613 100644
--- a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T1.js
+++ b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T1.js
@@ -6,18 +6,18 @@ info: Operator uses PutValue
 es5id: 11.13.2_A2.2_T1
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError). Check operator is "x *= y"
-flags: [negative]
+    ReferenceError. Check operator is "x *= y"
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   var z = (1 *= 1);
-  $ERROR('#1.1: 1 *= 1 throw ReferenceError (or SyntaxError). Actual: ' + (z));  
+  $ERROR('#1.1: 1 *= 1 throw ReferenceError. Actual: ' + (z));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 *= 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 *= 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     var z = (1 *= 1);
   }
diff --git a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T10.js b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T10.js
index 04f3935fd6..82b6c7646c 100644
--- a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T10.js
+++ b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T10.js
@@ -6,18 +6,18 @@ info: Operator uses PutValue
 es5id: 11.13.2_A2.2_T10
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError). Check operator is "x ^= y"
-flags: [negative]
+    ReferenceError. Check operator is "x ^= y"
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   var z = (1 ^= 1);
-  $ERROR('#1.1: 1 ^= 1 throw ReferenceError (or SyntaxError). Actual: ' + (z));  
+  $ERROR('#1.1: 1 ^= 1 throw ReferenceError. Actual: ' + (z));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 ^= 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 ^= 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     var z = (1 ^= 1);
   }
diff --git a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T11.js b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T11.js
index 023a1867bf..082e26e3d6 100644
--- a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T11.js
+++ b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T11.js
@@ -6,18 +6,18 @@ info: Operator uses PutValue
 es5id: 11.13.2_A2.2_T11
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError). Check operator is "x |= y"
-flags: [negative]
+    ReferenceError. Check operator is "x |= y"
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   var z = (1 |= 1);
-  $ERROR('#1.1: 1 |= 1 throw ReferenceError (or SyntaxError). Actual: ' + (z));  
+  $ERROR('#1.1: 1 |= 1 throw ReferenceError. Actual: ' + (z));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 |= 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 |= 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     var z = (1 |= 1);
   }
diff --git a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T2.js b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T2.js
index 3c909bd996..7d88d53dc2 100644
--- a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T2.js
+++ b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T2.js
@@ -6,18 +6,18 @@ info: Operator uses PutValue
 es5id: 11.13.2_A2.2_T2
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError). Check operator is "x /= y"
-flags: [negative]
+    ReferenceError. Check operator is "x /= y"
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   var z = (1 /= 1);
-  $ERROR('#1.1: 1 /= 1 throw ReferenceError (or SyntaxError). Actual: ' + (z));  
+  $ERROR('#1.1: 1 /= 1 throw ReferenceError. Actual: ' + (z));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 /= 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 /= 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     var z = (1 /= 1);
   }
diff --git a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T3.js b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T3.js
index a00a9f96ce..b6295420a3 100644
--- a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T3.js
+++ b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T3.js
@@ -6,18 +6,18 @@ info: Operator uses PutValue
 es5id: 11.13.2_A2.2_T3
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError). Check operator is "x %= y"
-flags: [negative]
+    ReferenceError. Check operator is "x %= y"
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   var z = (1 %= 1);
-  $ERROR('#1.1: 1 %= 1 throw ReferenceError (or SyntaxError). Actual: ' + (z));  
+  $ERROR('#1.1: 1 %= 1 throw ReferenceError. Actual: ' + (z));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 %= 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 %= 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     var z = (1 %= 1);
   }
diff --git a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T4.js b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T4.js
index 4cc5b03a86..f0453f600b 100644
--- a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T4.js
+++ b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T4.js
@@ -6,18 +6,18 @@ info: Operator uses PutValue
 es5id: 11.13.2_A2.2_T4
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError). Check operator is "x += y"
-flags: [negative]
+    ReferenceError. Check operator is "x += y"
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   var z = (1 += 1);
-  $ERROR('#1.1: 1 += 1 throw ReferenceError (or SyntaxError). Actual: ' + (z));  
+  $ERROR('#1.1: 1 += 1 throw ReferenceError. Actual: ' + (z));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 += 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 += 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     var z = (1 += 1);
   }
diff --git a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T5.js b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T5.js
index 091193e0e0..7a47e877a8 100644
--- a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T5.js
+++ b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T5.js
@@ -6,18 +6,18 @@ info: Operator uses PutValue
 es5id: 11.13.2_A2.2_T5
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError). Check operator is "x -= y"
-flags: [negative]
+    ReferenceError. Check operator is "x -= y"
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   var z = (1 -= 1);
-  $ERROR('#1.1: 1 -= 1 throw ReferenceError (or SyntaxError). Actual: ' + (z));  
+  $ERROR('#1.1: 1 -= 1 throw ReferenceError. Actual: ' + (z));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 -= 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 -= 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     var z = (1 -= 1);
   }
diff --git a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T6.js b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T6.js
index 1970c9f0ae..447256afeb 100644
--- a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T6.js
+++ b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T6.js
@@ -6,18 +6,18 @@ info: Operator uses PutValue
 es5id: 11.13.2_A2.2_T6
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError). Check operator is "x <<= y"
-flags: [negative]
+    ReferenceError. Check operator is "x <<= y"
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   var z = (1 <<= 1);
-  $ERROR('#1.1: 1 <<= 1 throw ReferenceError (or SyntaxError). Actual: ' + (z));  
+  $ERROR('#1.1: 1 <<= 1 throw ReferenceError. Actual: ' + (z));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 <<= 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 <<= 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     var z = (1 <<= 1);
   }
diff --git a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T7.js b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T7.js
index c75b2655e5..53f90d34fa 100644
--- a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T7.js
+++ b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T7.js
@@ -6,18 +6,18 @@ info: Operator uses PutValue
 es5id: 11.13.2_A2.2_T7
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError). Check operator is "x >>= y"
-flags: [negative]
+    ReferenceError. Check operator is "x >>= y"
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   var z = (1 >>= 1);
-  $ERROR('#1.1: 1 >>= 1 throw ReferenceError (or SyntaxError). Actual: ' + (z));  
+  $ERROR('#1.1: 1 >>= 1 throw ReferenceError. Actual: ' + (z));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 >>= 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 >>= 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     var z = (1 >>= 1);
   }
diff --git a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T8.js b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T8.js
index 3ab2d96308..60f928e96c 100644
--- a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T8.js
+++ b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T8.js
@@ -6,18 +6,18 @@ info: Operator uses PutValue
 es5id: 11.13.2_A2.2_T8
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError). Check operator is "x >>>= y"
-flags: [negative]
+    ReferenceError. Check operator is "x >>>= y"
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   var z = (1 >>>= 1);
-  $ERROR('#1.1: 1 >>>= 1 throw ReferenceError (or SyntaxError). Actual: ' + (z));  
+  $ERROR('#1.1: 1 >>>= 1 throw ReferenceError. Actual: ' + (z));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 >>>= 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 >>>= 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     var z = (1 >>>= 1);
   }
diff --git a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T9.js b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T9.js
index 1e9a3263da..378932d68e 100644
--- a/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T9.js
+++ b/test/suite/ch11/11.13/11.13.2/S11.13.2_A2.2_T9.js
@@ -6,18 +6,18 @@ info: Operator uses PutValue
 es5id: 11.13.2_A2.2_T9
 description: >
     If Type(LeftHandSideExpression) is not Reference, throw
-    ReferenceError (or SyntaxError). Check operator is "x &= y"
-flags: [negative]
+    ReferenceError. Check operator is "x &= y"
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   var z = (1 &= 1);
-  $ERROR('#1.1: 1 &= 1 throw ReferenceError (or SyntaxError). Actual: ' + (z));  
+  $ERROR('#1.1: 1 &= 1 throw ReferenceError. Actual: ' + (z));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1 &= 1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1 &= 1 throw ReferenceError. Actual: ' + (e));  
   } else {
     var z = (1 &= 1);
   }
diff --git a/test/suite/ch11/11.2/11.2.4/S11.2.4_A1.3_T1.js b/test/suite/ch11/11.2/11.2.4/S11.2.4_A1.3_T1.js
index 29d1111b05..e97e6edd0e 100644
--- a/test/suite/ch11/11.2/11.2.4/S11.2.4_A1.3_T1.js
+++ b/test/suite/ch11/11.2/11.2.4/S11.2.4_A1.3_T1.js
@@ -7,7 +7,7 @@ info: >
     syntax
 es5id: 11.2.4_A1.3_T1
 description: incorrect syntax
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function f_arg() {
diff --git a/test/suite/ch11/11.3/11.3.1/11.3.1-2-1gs.js b/test/suite/ch11/11.3/11.3.1/11.3.1-2-1gs.js
index 7aa7f51de6..5725fb9228 100644
--- a/test/suite/ch11/11.3/11.3.1/11.3.1-2-1gs.js
+++ b/test/suite/ch11/11.3/11.3.1/11.3.1-2-1gs.js
@@ -9,7 +9,7 @@ es5id: 11.3.1-2-1gs
 description: >
     Strict Mode - SyntaxError is throw if the identifier arguments
     appear as a PostfixExpression(arguments++)
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T1.js b/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T1.js
index 0ec0dd42cd..3e678b5ed2 100644
--- a/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T1.js
+++ b/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T1.js
@@ -5,7 +5,7 @@
 info: Line Terminator between LeftHandSideExpression and "++" is not allowed
 es5id: 11.3.1_A1.1_T1
 description: Checking Line Feed
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T2.js b/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T2.js
index 7348232aef..296ea00009 100644
--- a/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T2.js
+++ b/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T2.js
@@ -5,7 +5,7 @@
 info: Line Terminator between LeftHandSideExpression and "++" is not allowed
 es5id: 11.3.1_A1.1_T2
 description: Carriage Return
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T3.js b/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T3.js
index fbdcf07369..d6a51bd559 100644
--- a/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T3.js
+++ b/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T3.js
@@ -5,7 +5,7 @@
 info: Line Terminator between LeftHandSideExpression and "++" is not allowed
 es5id: 11.3.1_A1.1_T3
 description: Checking Line Seprator
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T4.js b/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T4.js
index c00676e1c8..8afd23013d 100644
--- a/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T4.js
+++ b/test/suite/ch11/11.3/11.3.1/S11.3.1_A1.1_T4.js
@@ -5,7 +5,7 @@
 info: Line Terminator between LeftHandSideExpression and "++" is not allowed
 es5id: 11.3.1_A1.1_T4
 description: Checking Paragraph separator
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch11/11.3/11.3.1/S11.3.1_A2.1_T3.js b/test/suite/ch11/11.3/11.3.1/S11.3.1_A2.1_T3.js
index 0d2ad4de8e..2e505b5324 100644
--- a/test/suite/ch11/11.3/11.3.1/S11.3.1_A2.1_T3.js
+++ b/test/suite/ch11/11.3/11.3.1/S11.3.1_A2.1_T3.js
@@ -2,20 +2,22 @@
 // This code is governed by the BSD license found in the LICENSE file.
 
 /*---
-info: Operator x++ uses GetValue and PutValue
+info: > 
+ Operator x++ uses GetValue and PutValue
+ ES6, 12.4.1 and 12.5.1 specify ReferenceError
 es5id: 11.3.1_A2.1_T3
-description: If Type(x) is not Reference, throw ReferenceError (or SyntaxError)
-flags: [negative]
+description: If Type(x) is not Reference, throw ReferenceError
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   1++;
-  $ERROR('#1.1: 1++ throw ReferenceError (or SyntaxError). Actual: ' + (1++));  
+  $ERROR('#1.1: 1++ throw ReferenceError. Actual: ' + (1++));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1++ throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1++ throw ReferenceError. Actual: ' + (e));  
   } else {
     1++;
   }
diff --git a/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T1.js b/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T1.js
index a6df2dbf95..226042ee9d 100644
--- a/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T1.js
+++ b/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T1.js
@@ -5,7 +5,7 @@
 info: Line Terminator between LeftHandSideExpression and "--" is not allowed
 es5id: 11.3.2_A1.1_T1
 description: Checking Line Feed
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T2.js b/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T2.js
index 08a84af4ba..5f9564515e 100644
--- a/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T2.js
+++ b/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T2.js
@@ -5,7 +5,7 @@
 info: Line Terminator between LeftHandSideExpression and "--" is not allowed
 es5id: 11.3.2_A1.1_T2
 description: Checking Carriage Return
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T3.js b/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T3.js
index 0dcbd04766..e691a9a9a0 100644
--- a/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T3.js
+++ b/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T3.js
@@ -5,7 +5,7 @@
 info: Line Terminator between LeftHandSideExpression and "--" is not allowed
 es5id: 11.3.2_A1.1_T3
 description: Checking Page separator
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T4.js b/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T4.js
index fe1ea374fa..9dcac1ee08 100644
--- a/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T4.js
+++ b/test/suite/ch11/11.3/11.3.2/S11.3.2_A1.1_T4.js
@@ -5,7 +5,7 @@
 info: Line Terminator between LeftHandSideExpression and "--" is not allowed
 es5id: 11.3.2_A1.1_T4
 description: Checking Line separator
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch11/11.3/11.3.2/S11.3.2_A2.1_T3.js b/test/suite/ch11/11.3/11.3.2/S11.3.2_A2.1_T3.js
index 3897f319aa..6730b85c9b 100644
--- a/test/suite/ch11/11.3/11.3.2/S11.3.2_A2.1_T3.js
+++ b/test/suite/ch11/11.3/11.3.2/S11.3.2_A2.1_T3.js
@@ -2,20 +2,22 @@
 // This code is governed by the BSD license found in the LICENSE file.
 
 /*---
-info: Operator x-- uses GetValue and PutValue
+info: >
+ Operator x-- uses GetValue and PutValue
+ ES6, 12.4.1 and 12.5.1 specify ReferenceError
 es5id: 11.3.2_A2.1_T3
-description: If Type(x) is not Reference, throw ReferenceError (or SyntaxError)
-flags: [negative]
+description: If Type(x) is not Reference, throw ReferenceError
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   1--;
-  $ERROR('#1.1: 1-- throw ReferenceError (or SyntaxError). Actual: ' + (1--));  
+  $ERROR('#1.1: 1-- throw ReferenceError. Actual: ' + (1--));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: 1-- throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: 1-- throw ReferenceError. Actual: ' + (e));  
   } else {
     1--;
   }
diff --git a/test/suite/ch11/11.4/11.4.1/11.4.1-5-a-5gs.js b/test/suite/ch11/11.4/11.4.1/11.4.1-5-a-5gs.js
index 1498dc497f..9700cadc33 100644
--- a/test/suite/ch11/11.4/11.4.1/11.4.1-5-a-5gs.js
+++ b/test/suite/ch11/11.4/11.4.1/11.4.1-5-a-5gs.js
@@ -9,7 +9,7 @@ es5id: 11.4.1-5-a-5gs
 description: >
     Strict Mode - SyntaxError is thrown when deleting a variable which
     is primitive type(boolean)
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch11/11.4/11.4.2/S11.4.2_A2_T2.js b/test/suite/ch11/11.4/11.4.2/S11.4.2_A2_T2.js
index dc65118cbe..a43f99ca78 100644
--- a/test/suite/ch11/11.4/11.4.2/S11.4.2_A2_T2.js
+++ b/test/suite/ch11/11.4/11.4.2/S11.4.2_A2_T2.js
@@ -5,7 +5,7 @@
 info: Operator "void" uses GetValue
 es5id: 11.4.2_A2_T2
 description: If GetBase(x) is null, throw ReferenceError
-flags: [negative]
+negative: ReferenceError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch11/11.4/11.4.4/S11.4.4_A2.1_T3.js b/test/suite/ch11/11.4/11.4.4/S11.4.4_A2.1_T3.js
index 72ed452f47..ffb1d1c377 100644
--- a/test/suite/ch11/11.4/11.4.4/S11.4.4_A2.1_T3.js
+++ b/test/suite/ch11/11.4/11.4.4/S11.4.4_A2.1_T3.js
@@ -2,20 +2,22 @@
 // This code is governed by the BSD license found in the LICENSE file.
 
 /*---
-info: Operator ++x uses GetValue and PutValue
+info: >
+ Operator ++x uses GetValue and PutValue
+ ES6, 12.4.1 and 12.5.1 specify ReferenceError
 es5id: 11.4.4_A2.1_T3
-description: If Type(x) is not Reference, throw ReferenceError (or SyntaxError)
-flags: [negative]
+description: If Type(x) is not Reference, throw ReferenceError
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   ++1;
-  $ERROR('#1.1: ++1 throw ReferenceError (or SyntaxError). Actual: ' + (++1));  
+  $ERROR('#1.1: ++1 throw ReferenceError. Actual: ' + (++1));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: ++1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: ++1 throw ReferenceError. Actual: ' + (e));  
   } else {
     ++1;
   }
diff --git a/test/suite/ch11/11.4/11.4.5/11.4.5-2-2gs.js b/test/suite/ch11/11.4/11.4.5/11.4.5-2-2gs.js
index 2779698e9e..a264488869 100644
--- a/test/suite/ch11/11.4/11.4.5/11.4.5-2-2gs.js
+++ b/test/suite/ch11/11.4/11.4.5/11.4.5-2-2gs.js
@@ -9,7 +9,7 @@ es5id: 11.4.5-2-2gs
 description: >
     Strict Mode - SyntaxError is throw if the UnaryExpression operated
     upon by a Prefix Increment operator(--arguments)
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch11/11.4/11.4.5/S11.4.5_A2.1_T3.js b/test/suite/ch11/11.4/11.4.5/S11.4.5_A2.1_T3.js
index e0f0449ff0..2676764921 100644
--- a/test/suite/ch11/11.4/11.4.5/S11.4.5_A2.1_T3.js
+++ b/test/suite/ch11/11.4/11.4.5/S11.4.5_A2.1_T3.js
@@ -2,20 +2,22 @@
 // This code is governed by the BSD license found in the LICENSE file.
 
 /*---
-info: Operator --x uses GetValue and PutValue
+info: > 
+ Operator --x uses GetValue and PutValue
+ ES6 12.5.1 specifies this as ReferenceError
 es5id: 11.4.5_A2.1_T3
-description: If Type(x) is not Reference, throw ReferenceError (or SyntaxError)
-flags: [negative]
+description: If Type(x) is not Reference, throw ReferenceError
+negative: ReferenceError
 ---*/
 
 //CHECK#1
 try {
   --1;
-  $ERROR('#1.1: --1 throw ReferenceError (or SyntaxError). Actual: ' + (--1));  
+  $ERROR('#1.1: --1 throw ReferenceError. Actual: ' + (--1));  
 }
 catch (e) {
   if ((e instanceof ReferenceError) !== true) {
-    $ERROR('#1.2: --1 throw ReferenceError (or SyntaxError). Actual: ' + (e));  
+    $ERROR('#1.2: --1 throw ReferenceError. Actual: ' + (e));  
   } else {
     --1;
   }
diff --git a/test/suite/ch12/12.1/S12.1_A4_T1.js b/test/suite/ch12/12.1/S12.1_A4_T1.js
index ab3effee41..bcd1697bcb 100644
--- a/test/suite/ch12/12.1/S12.1_A4_T1.js
+++ b/test/suite/ch12/12.1/S12.1_A4_T1.js
@@ -5,13 +5,13 @@
 info: The production Block can't be inside of expression
 es5id: 12.1_A4_T1
 description: Checking if execution of "y={__func}()" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function __func(){};
 
 //////////////////////////////////////////////////////////////////////////////
 //CHECK#1
-y={__func}();
+y={__func;}();
 //
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.1/S12.1_A4_T2.js b/test/suite/ch12/12.1/S12.1_A4_T2.js
index 7b332eb64d..10cfb43aa6 100644
--- a/test/suite/ch12/12.1/S12.1_A4_T2.js
+++ b/test/suite/ch12/12.1/S12.1_A4_T2.js
@@ -5,13 +5,13 @@
 info: The production Block can't be inside of expression
 es5id: 12.1_A4_T2
 description: Checking if execution of "y={x}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 x=1;
 
 //////////////////////////////////////////////////////////////////////////////
 //CHECK#1
-y={x};
+y={x;};
 //
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.10/12.10.1/12.10.1-11gs.js b/test/suite/ch12/12.10/12.10.1/12.10.1-11gs.js
index f3b3d479c9..d96c43dbff 100644
--- a/test/suite/ch12/12.10/12.10.1/12.10.1-11gs.js
+++ b/test/suite/ch12/12.10/12.10.1/12.10.1-11gs.js
@@ -7,7 +7,7 @@
 /*---
 es5id: 12.10.1-11gs
 description: Strict Mode - SyntaxError is thrown when using with statement
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch12/12.11/S12.11_A2_T1.js b/test/suite/ch12/12.11/S12.11_A2_T1.js
index c90633297d..5947de0f98 100644
--- a/test/suite/ch12/12.11/S12.11_A2_T1.js
+++ b/test/suite/ch12/12.11/S12.11_A2_T1.js
@@ -5,7 +5,7 @@
 info: There can be only one DefaultClause
 es5id: 12.11_A2_T1
 description: Duplicate DefaultClause
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function SwitchTest(value){
diff --git a/test/suite/ch12/12.11/S12.11_A3_T1.js b/test/suite/ch12/12.11/S12.11_A3_T1.js
index 892defa42f..56fa00ebd7 100644
--- a/test/suite/ch12/12.11/S12.11_A3_T1.js
+++ b/test/suite/ch12/12.11/S12.11_A3_T1.js
@@ -5,7 +5,7 @@
 info: Syntax constructions of switch statement
 es5id: 12.11_A3_T1
 description: Checking if execution of "switch() {}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function SwitchTest(value){
diff --git a/test/suite/ch12/12.11/S12.11_A3_T2.js b/test/suite/ch12/12.11/S12.11_A3_T2.js
index 9ccf91ac10..a6c4cecaeb 100644
--- a/test/suite/ch12/12.11/S12.11_A3_T2.js
+++ b/test/suite/ch12/12.11/S12.11_A3_T2.js
@@ -5,7 +5,7 @@
 info: Syntax constructions of switch statement
 es5id: 12.11_A3_T2
 description: Checking if execution of "switch {}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function SwitchTest(value){
diff --git a/test/suite/ch12/12.11/S12.11_A3_T3.js b/test/suite/ch12/12.11/S12.11_A3_T3.js
index f0bd3f868a..bb983237ba 100644
--- a/test/suite/ch12/12.11/S12.11_A3_T3.js
+++ b/test/suite/ch12/12.11/S12.11_A3_T3.js
@@ -5,7 +5,7 @@
 info: Syntax constructions of switch statement
 es5id: 12.11_A3_T3
 description: Checking if execution of "switch(value)" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 switch(value);
diff --git a/test/suite/ch12/12.11/S12.11_A3_T4.js b/test/suite/ch12/12.11/S12.11_A3_T4.js
index dd86d3e621..856e189d82 100644
--- a/test/suite/ch12/12.11/S12.11_A3_T4.js
+++ b/test/suite/ch12/12.11/S12.11_A3_T4.js
@@ -7,7 +7,7 @@ es5id: 12.11_A3_T4
 description: >
     Using "case" that has no Expresson after it. "CaseClause: case
     Expression : [StatementList]"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function SwitchTest(value){
diff --git a/test/suite/ch12/12.11/S12.11_A3_T5.js b/test/suite/ch12/12.11/S12.11_A3_T5.js
index 5aedd37f02..8dbb4d9548 100644
--- a/test/suite/ch12/12.11/S12.11_A3_T5.js
+++ b/test/suite/ch12/12.11/S12.11_A3_T5.js
@@ -5,7 +5,7 @@
 info: Syntax constructions of switch statement
 es5id: 12.11_A3_T5
 description: Introducing statement not followed by "case" keyword
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function SwitchTest(value){
diff --git a/test/suite/ch12/12.13/S12.13_A1.js b/test/suite/ch12/12.13/S12.13_A1.js
index e907a2fcbc..ce48406d25 100644
--- a/test/suite/ch12/12.13/S12.13_A1.js
+++ b/test/suite/ch12/12.13/S12.13_A1.js
@@ -5,7 +5,7 @@
 info: Sanity test for throw statement
 es5id: 12.13_A1
 description: Trying to throw exception with "throw"
-flags: [negative]
+negative: expected_message
 ---*/
 
-throw "error";
+throw "expected_message";
diff --git a/test/suite/ch12/12.14/12.14.1/12.14.1-1gs.js b/test/suite/ch12/12.14/12.14.1/12.14.1-1gs.js
index 55ad37ef1f..4574705f9d 100644
--- a/test/suite/ch12/12.14/12.14.1/12.14.1-1gs.js
+++ b/test/suite/ch12/12.14/12.14.1/12.14.1-1gs.js
@@ -10,7 +10,7 @@ description: >
     Strict Mode - SyntaxError is thrown if a TryStatement with a Catch
     occurs within strict code and the Identifier of the Catch
     production is eval
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch12/12.14/S12.14_A16_T1.js b/test/suite/ch12/12.14/S12.14_A16_T1.js
index f6dd97aac1..2d4f7c81e6 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T1.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T1.js
@@ -7,7 +7,7 @@ info: >
     Catch Finally"
 es5id: 12.14_A16_T1
 description: Checking if pure "try" syntax construction passes
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T10.js b/test/suite/ch12/12.14/S12.14_A16_T10.js
index c5579e419b..b70057076f 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T10.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T10.js
@@ -7,7 +7,7 @@ info: >
     Catch Finally"
 es5id: 12.14_A16_T10
 description: "Catch: \"catch (Identifier ) Block\""
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T11.js b/test/suite/ch12/12.14/S12.14_A16_T11.js
index 03a4c4059b..8b46cf73cb 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T11.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T11.js
@@ -9,7 +9,7 @@ es5id: 12.14_A16_T11
 description: >
     Catch and Finally are placed into the Block of "try" (whitle
     expected outside)
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T12.js b/test/suite/ch12/12.14/S12.14_A16_T12.js
index e20b1f0b49..0d6246dc93 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T12.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T12.js
@@ -7,7 +7,7 @@ info: >
     Catch Finally"
 es5id: 12.14_A16_T12
 description: Embedded "try" statements followed by two "catch" statements
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T13.js b/test/suite/ch12/12.14/S12.14_A16_T13.js
index b1d24f6647..ece3312bfe 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T13.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T13.js
@@ -9,7 +9,7 @@ es5id: 12.14_A16_T13
 description: >
     Catch: "catch (Identifier ) Block". Checking if execution of "22"
     passes at the place of Identifier of "catch"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T14.js b/test/suite/ch12/12.14/S12.14_A16_T14.js
index 9fed9a23fc..472201bc68 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T14.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T14.js
@@ -7,7 +7,7 @@ info: >
     Catch Finally"
 es5id: 12.14_A16_T14
 description: Checking if passing argument to "try" statement fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T15.js b/test/suite/ch12/12.14/S12.14_A16_T15.js
index 47d7f8c995..6290c9e09e 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T15.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T15.js
@@ -9,7 +9,7 @@ es5id: 12.14_A16_T15
 description: >
     Finally: "finally Block". Checking if passing argument to "try"
     statement fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T2.js b/test/suite/ch12/12.14/S12.14_A16_T2.js
index 1d21b5c98c..2aa5ae6ef1 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T2.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T2.js
@@ -7,7 +7,7 @@ info: >
     Catch Finally"
 es5id: 12.14_A16_T2
 description: Checking if execution of "catch" with no "try" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T3.js b/test/suite/ch12/12.14/S12.14_A16_T3.js
index 5b8e70e4ac..bed9ac8ab6 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T3.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T3.js
@@ -7,7 +7,7 @@ info: >
     Catch Finally"
 es5id: 12.14_A16_T3
 description: Checking if execution of "finally" with no "try" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T4.js b/test/suite/ch12/12.14/S12.14_A16_T4.js
index 4078ed6e52..65d66448ae 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T4.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T4.js
@@ -9,7 +9,7 @@ es5id: 12.14_A16_T4
 description: >
     Catch: "catch (Identifier ) Block". Checking if execution of
     "catch" that takes no arguments fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T5.js b/test/suite/ch12/12.14/S12.14_A16_T5.js
index 896b6487fb..48722136f8 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T5.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T5.js
@@ -9,7 +9,7 @@ es5id: 12.14_A16_T5
 description: >
     Catch: "catch (Identifier ) Block". Checking if execution of
     "catch" with no Block fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T6.js b/test/suite/ch12/12.14/S12.14_A16_T6.js
index 261160f453..fd00f1fd1a 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T6.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T6.js
@@ -9,7 +9,7 @@ es5id: 12.14_A16_T6
 description: >
     Block: "{ StatementList }". Checking if execution of "try{
     catch{}{}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T7.js b/test/suite/ch12/12.14/S12.14_A16_T7.js
index 96d948160a..44ca68cf30 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T7.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T7.js
@@ -9,7 +9,7 @@ es5id: 12.14_A16_T7
 description: >
     Block: "{ StatementList }". Checking if execution of "try{}
     catch(){" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T8.js b/test/suite/ch12/12.14/S12.14_A16_T8.js
index 6eebb0dd36..b9266cf7dc 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T8.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T8.js
@@ -9,7 +9,7 @@ es5id: 12.14_A16_T8
 description: >
     Block: "{ StatementList }". Catch: "catch (Identifier ) Block".
     Checking if execution of "try{} catch(){finally{}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.14/S12.14_A16_T9.js b/test/suite/ch12/12.14/S12.14_A16_T9.js
index 1eec9a544a..c6ca68ad0c 100644
--- a/test/suite/ch12/12.14/S12.14_A16_T9.js
+++ b/test/suite/ch12/12.14/S12.14_A16_T9.js
@@ -7,7 +7,7 @@ info: >
     Catch Finally"
 es5id: 12.14_A16_T9
 description: Checking if execution of "catch(){} finally{}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 // CHECK#1
diff --git a/test/suite/ch12/12.2/12.2.1/12.2.1-1gs.js b/test/suite/ch12/12.2/12.2.1/12.2.1-1gs.js
index 5cd0797eae..bed6f5a605 100644
--- a/test/suite/ch12/12.2/12.2.1/12.2.1-1gs.js
+++ b/test/suite/ch12/12.2/12.2.1/12.2.1-1gs.js
@@ -9,7 +9,7 @@ es5id: 12.2.1-1gs
 description: >
     Strict Mode - SyntaxError is thrown if a VariableDeclaration
     occurs within strict code and its Identifier is eval
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch12/12.2/12.2.1/12.2.1-4gs.js b/test/suite/ch12/12.2/12.2.1/12.2.1-4gs.js
index 111bf357ad..538089d10f 100644
--- a/test/suite/ch12/12.2/12.2.1/12.2.1-4gs.js
+++ b/test/suite/ch12/12.2/12.2.1/12.2.1-4gs.js
@@ -9,7 +9,7 @@ es5id: 12.2.1-4gs
 description: >
     Strict Mode - SyntaxError is thrown if a VariableDeclarationNoIn
     occurs within strict code and its Identifier is arguments
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch12/12.2/S12.2_A8_T1.js b/test/suite/ch12/12.2/S12.2_A8_T1.js
index 51e06b78ba..4e5f1efacd 100644
--- a/test/suite/ch12/12.2/S12.2_A8_T1.js
+++ b/test/suite/ch12/12.2/S12.2_A8_T1.js
@@ -5,7 +5,7 @@
 info: Only AssignmentExpression is admitted when variable is initialized
 es5id: 12.2_A8_T1
 description: Checking if execution of "var x += 1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.2/S12.2_A8_T2.js b/test/suite/ch12/12.2/S12.2_A8_T2.js
index c71294daa0..8f60c152c0 100644
--- a/test/suite/ch12/12.2/S12.2_A8_T2.js
+++ b/test/suite/ch12/12.2/S12.2_A8_T2.js
@@ -5,7 +5,7 @@
 info: Only AssignmentExpression is admitted when variable is initialized
 es5id: 12.2_A8_T2
 description: Checking if execution of "var x | true" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.2/S12.2_A8_T3.js b/test/suite/ch12/12.2/S12.2_A8_T3.js
index 00fcb034fb..b5b8949b99 100644
--- a/test/suite/ch12/12.2/S12.2_A8_T3.js
+++ b/test/suite/ch12/12.2/S12.2_A8_T3.js
@@ -5,7 +5,7 @@
 info: Only AssignmentExpression is admitted when variable is initialized
 es5id: 12.2_A8_T3
 description: Checking if execution of "var x && 1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.2/S12.2_A8_T4.js b/test/suite/ch12/12.2/S12.2_A8_T4.js
index e23fc937e8..9b125cc983 100644
--- a/test/suite/ch12/12.2/S12.2_A8_T4.js
+++ b/test/suite/ch12/12.2/S12.2_A8_T4.js
@@ -5,7 +5,7 @@
 info: Only AssignmentExpression is admitted when variable is initialized
 es5id: 12.2_A8_T4
 description: Checking if execution of "var x++" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.2/S12.2_A8_T5.js b/test/suite/ch12/12.2/S12.2_A8_T5.js
index cde132209b..4640a96dbc 100644
--- a/test/suite/ch12/12.2/S12.2_A8_T5.js
+++ b/test/suite/ch12/12.2/S12.2_A8_T5.js
@@ -5,7 +5,7 @@
 info: Only AssignmentExpression is admitted when variable is initialized
 es5id: 12.2_A8_T5
 description: Checking if execution of "var --x" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.2/S12.2_A8_T6.js b/test/suite/ch12/12.2/S12.2_A8_T6.js
index dca790eeed..9eb53feb8c 100644
--- a/test/suite/ch12/12.2/S12.2_A8_T6.js
+++ b/test/suite/ch12/12.2/S12.2_A8_T6.js
@@ -5,7 +5,7 @@
 info: Only AssignmentExpression is admitted when variable is initialized
 es5id: 12.2_A8_T6
 description: Checking if execution of "var x*1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.2/S12.2_A8_T7.js b/test/suite/ch12/12.2/S12.2_A8_T7.js
index 32b93b4483..6a80d0d7ab 100644
--- a/test/suite/ch12/12.2/S12.2_A8_T7.js
+++ b/test/suite/ch12/12.2/S12.2_A8_T7.js
@@ -5,7 +5,7 @@
 info: Only AssignmentExpression is admitted when variable is initialized
 es5id: 12.2_A8_T7
 description: Checking if execution of "var x>>1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.2/S12.2_A8_T8.js b/test/suite/ch12/12.2/S12.2_A8_T8.js
index 9b7795e2b3..e5138c7e06 100644
--- a/test/suite/ch12/12.2/S12.2_A8_T8.js
+++ b/test/suite/ch12/12.2/S12.2_A8_T8.js
@@ -5,7 +5,7 @@
 info: Only AssignmentExpression is admitted when variable is initialized
 es5id: 12.2_A8_T8
 description: Checking if execution of "var x in __arr" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 __arr = [];
diff --git a/test/suite/ch12/12.4/S12.4_A1.js b/test/suite/ch12/12.4/S12.4_A1.js
index 4ca4e197f1..dc4fe9dc03 100644
--- a/test/suite/ch12/12.4/S12.4_A1.js
+++ b/test/suite/ch12/12.4/S12.4_A1.js
@@ -7,7 +7,7 @@ info: >
     that might make it ambiguous with a FunctionDeclaration
 es5id: 12.4_A1
 description: Checking if execution of "function(){}()" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.5/S12.5_A11.js b/test/suite/ch12/12.5/S12.5_A11.js
index d2f9ae7c06..a574356ea8 100644
--- a/test/suite/ch12/12.5/S12.5_A11.js
+++ b/test/suite/ch12/12.5/S12.5_A11.js
@@ -5,7 +5,7 @@
 info: "{} within the \"if\" expression is not allowed"
 es5id: 12.5_A11
 description: Checking if execution of "if({1})" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.5/S12.5_A2.js b/test/suite/ch12/12.5/S12.5_A2.js
index ec21a34719..7b36e2eea0 100644
--- a/test/suite/ch12/12.5/S12.5_A2.js
+++ b/test/suite/ch12/12.5/S12.5_A2.js
@@ -5,8 +5,9 @@
 info: In the "if" Statement eval in Expression is admitted
 es5id: 12.5_A2
 description: Checking by using eval "eval("true")"
-flags: [negative]
-includes: [$FAIL.js]
 ---*/
 
-if (eval("true")) $FAIL('#1: In the "if" Statement eval as Expression is admitted');
+if (eval("true")) {
+} else {
+    $ERROR('#1: In the "if" Statement eval as Expression is admitted'); 
+}
diff --git a/test/suite/ch12/12.5/S12.5_A6_T1.js b/test/suite/ch12/12.5/S12.5_A6_T1.js
index ddac88dfe3..0eef08663a 100644
--- a/test/suite/ch12/12.5/S12.5_A6_T1.js
+++ b/test/suite/ch12/12.5/S12.5_A6_T1.js
@@ -5,7 +5,7 @@
 info: In the If statement expression must be enclosed in braces
 es5id: 12.5_A6_T1
 description: Checking if execution of "if true" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.5/S12.5_A6_T2.js b/test/suite/ch12/12.5/S12.5_A6_T2.js
index 1628a57b6d..f555ef988c 100644
--- a/test/suite/ch12/12.5/S12.5_A6_T2.js
+++ b/test/suite/ch12/12.5/S12.5_A6_T2.js
@@ -5,7 +5,7 @@
 info: In the If statement expression must be enclosed in braces
 es5id: 12.5_A6_T2
 description: Checking if execution of "if false" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.5/S12.5_A8.js b/test/suite/ch12/12.5/S12.5_A8.js
index 6ccf77f501..f4488788e6 100644
--- a/test/suite/ch12/12.5/S12.5_A8.js
+++ b/test/suite/ch12/12.5/S12.5_A8.js
@@ -5,7 +5,7 @@
 info: In the "if" Statement empty expression is not allowed
 es5id: 12.5_A8
 description: Checking if execution of "if()" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.1/S12.6.1_A12.js b/test/suite/ch12/12.6/12.6.1/S12.6.1_A12.js
index 19d010b46a..a174829c5f 100644
--- a/test/suite/ch12/12.6/12.6.1/S12.6.1_A12.js
+++ b/test/suite/ch12/12.6/12.6.1/S12.6.1_A12.js
@@ -5,7 +5,7 @@
 info: Any statement within "do-while" construction must be a compound
 es5id: 12.6.1_A12
 description: Checking if execution of "do var x=1; var y =2; while (0)" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.1/S12.6.1_A15.js b/test/suite/ch12/12.6/12.6.1/S12.6.1_A15.js
index 198d7b3b93..f079896efa 100644
--- a/test/suite/ch12/12.6/12.6.1/S12.6.1_A15.js
+++ b/test/suite/ch12/12.6/12.6.1/S12.6.1_A15.js
@@ -5,7 +5,7 @@
 info: Block within a "do-while" Expression is not allowed
 es5id: 12.6.1_A15
 description: Using "{0}" Block as an Expression
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T1.js b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T1.js
index f12b627d1c..a0aacd85fd 100644
--- a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T1.js
+++ b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T1.js
@@ -5,7 +5,7 @@
 info: Expression in "do-while" IterationStatement is bracketed with braces
 es5id: 12.6.1_A6_T1
 description: Checking if execution of "do{} while 1" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T2.js b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T2.js
index b4adc61884..a7686e92c8 100644
--- a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T2.js
+++ b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T2.js
@@ -5,7 +5,7 @@
 info: Expression in "do-while" IterationStatement is bracketed with braces
 es5id: 12.6.1_A6_T2
 description: Checking if execution of "do{} while 0" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T3.js b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T3.js
index a392a85dc5..4f59089ddc 100644
--- a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T3.js
+++ b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T3.js
@@ -5,7 +5,7 @@
 info: Expression in "do-while" IterationStatement is bracketed with braces
 es5id: 12.6.1_A6_T3
 description: Checking if execution of "do{}while true" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T4.js b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T4.js
index 674fde0de4..9e77619bca 100644
--- a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T4.js
+++ b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T4.js
@@ -5,7 +5,7 @@
 info: Expression in "do-while" IterationStatement is bracketed with braces
 es5id: 12.6.1_A6_T4
 description: Checking if execution of "do{}while false" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T5.js b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T5.js
index d40e36d7c8..2182ea4f9a 100644
--- a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T5.js
+++ b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T5.js
@@ -5,7 +5,7 @@
 info: Expression in "do-while" IterationStatement is bracketed with braces
 es5id: 12.6.1_A6_T5
 description: Checking if execution of "do{}while ''" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T6.js b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T6.js
index f84325b85c..2ee26417fb 100644
--- a/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T6.js
+++ b/test/suite/ch12/12.6/12.6.1/S12.6.1_A6_T6.js
@@ -5,7 +5,7 @@
 info: Expression in "do-while" IterationStatement is bracketed with braces
 es5id: 12.6.1_A6_T6
 description: Checking if execution of "do{}while 'hood'" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.2/S12.6.2_A15.js b/test/suite/ch12/12.6/12.6.2/S12.6.2_A15.js
index 0ec17b53d1..a5dcce4a5c 100644
--- a/test/suite/ch12/12.6/12.6.2/S12.6.2_A15.js
+++ b/test/suite/ch12/12.6/12.6.2/S12.6.2_A15.js
@@ -5,7 +5,7 @@
 info: Block within a "while" Expression is not allowed
 es5id: 12.6.2_A15
 description: Expression is "{0}"
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T1.js b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T1.js
index d5b8a897db..b2d4949b15 100644
--- a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T1.js
+++ b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T1.js
@@ -5,7 +5,7 @@
 info: Expression in "while" IterationStatement is bracketed with braces
 es5id: 12.6.2_A6_T1
 description: Checking if execution of "while 1 break" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T2.js b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T2.js
index 0d611b50e8..beb06e866a 100644
--- a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T2.js
+++ b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T2.js
@@ -5,7 +5,7 @@
 info: Expression in "while" IterationStatement is bracketed with braces
 es5id: 12.6.2_A6_T2
 description: Checking if execution of "while 0 break" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T3.js b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T3.js
index 6a7ab5475c..6c28cf6628 100644
--- a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T3.js
+++ b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T3.js
@@ -5,7 +5,7 @@
 info: Expression in "while" IterationStatement is bracketed with braces
 es5id: 12.6.2_A6_T3
 description: Checking if execution of "while true break" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T4.js b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T4.js
index 5534501bbd..7b74d4efce 100644
--- a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T4.js
+++ b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T4.js
@@ -5,7 +5,7 @@
 info: Expression in "while" IterationStatement is bracketed with braces
 es5id: 12.6.2_A6_T4
 description: Checking if execution of "while false break" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T5.js b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T5.js
index 403bb69924..644e32b525 100644
--- a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T5.js
+++ b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T5.js
@@ -5,7 +5,7 @@
 info: Expression in "while" IterationStatement is bracketed with braces
 es5id: 12.6.2_A6_T5
 description: Checking if execution of "while '' break" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T6.js b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T6.js
index 7996d422c3..49cba88d4d 100644
--- a/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T6.js
+++ b/test/suite/ch12/12.6/12.6.2/S12.6.2_A6_T6.js
@@ -5,7 +5,7 @@
 info: Expression in "while" IterationStatement is bracketed with braces
 es5id: 12.6.2_A6_T6
 description: Checking if execution of "while 'hood' break" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A11.1_T3.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A11.1_T3.js
index 67a98b22bc..686587b616 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A11.1_T3.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A11.1_T3.js
@@ -8,7 +8,7 @@ info: >
     "var-loop" breaks
 es5id: 12.6.3_A11.1_T3
 description: Trying to continue non-existent label
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 __str="";
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A11_T3.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A11_T3.js
index a8b6ca9c26..a3272871cb 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A11_T3.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A11_T3.js
@@ -8,7 +8,7 @@ info: >
     breaks
 es5id: 12.6.3_A11_T3
 description: Trying to continue non-existent label
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 __str="";
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A12.1_T3.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A12.1_T3.js
index 467305186d..b54efa56ce 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A12.1_T3.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A12.1_T3.js
@@ -8,7 +8,7 @@ info: >
     returned while evaluating a "var-loop"
 es5id: 12.6.3_A12.1_T3
 description: Trying to break non-existent label
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 __str="";
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A12_T3.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A12_T3.js
index 022e9318d7..42680be4d6 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A12_T3.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A12_T3.js
@@ -8,7 +8,7 @@ info: >
     returned while evaluating a loop
 es5id: 12.6.3_A12_T3
 description: Trying to break non-existent label
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 __str="";
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A4.1.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A4.1.js
index 4fff7bdc71..aa8b4dca22 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A4.1.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A4.1.js
@@ -8,7 +8,7 @@ info: >
     IterationStatement
 es5id: 12.6.3_A4.1
 description: Checking if execution of "for (var a in arr;1;){}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 arr = [1,2,3,4,5];
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A4_T1.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A4_T1.js
index 6a8945f26d..d9654fa5f8 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A4_T1.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A4_T1.js
@@ -8,7 +8,7 @@ info: >
     IterationStatement
 es5id: 12.6.3_A4_T1
 description: Checking if execution of "for (a in arr;1;){}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 arr = [1,2,3,4,5];
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A4_T2.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A4_T2.js
index f2116de452..0fe801b152 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A4_T2.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A4_T2.js
@@ -8,7 +8,7 @@ info: >
     IterationStatement
 es5id: 12.6.3_A4_T2
 description: Checking if execution of "for (1 in arr;1;){}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 arr = [1,2,3,4,5];
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A7.1_T1.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A7.1_T1.js
index 8646600c66..5b61708279 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A7.1_T1.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A7.1_T1.js
@@ -9,7 +9,7 @@ es5id: 12.6.3_A7.1_T1
 description: >
     Checking if execution of "for(var index=0; index<10; index++;
     index--)" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A7.1_T2.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A7.1_T2.js
index cad7077293..20cd21ef76 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A7.1_T2.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A7.1_T2.js
@@ -9,7 +9,7 @@ es5id: 12.6.3_A7.1_T2
 description: >
     Checking if execution of "for(var index=0; index<10; index+=4;
     index++; index--)" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A7_T1.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A7_T1.js
index b4e47a486a..11189440ee 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A7_T1.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A7_T1.js
@@ -9,7 +9,7 @@ es5id: 12.6.3_A7_T1
 description: >
     Checking if execution of "for(index=0; index<10; index++;
     index--)" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A7_T2.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A7_T2.js
index ecc6011ccf..342a611457 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A7_T2.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A7_T2.js
@@ -9,7 +9,7 @@ es5id: 12.6.3_A7_T2
 description: >
     Checking if execution of "for(index=0; index<10; index+=4;
     index++; index--)" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T1.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T1.js
index 6e680ac17f..eae1d63e70 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T1.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T1.js
@@ -7,7 +7,7 @@ es5id: 12.6.3_A8.1_T1
 description: >
     Checking if execution of "for(var index=0; index<100; {index++;
     index*2;}) {  arr.add(""+index);}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var arr = [];
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T2.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T2.js
index 4075a08b4d..d5774cd7bb 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T2.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T2.js
@@ -7,7 +7,7 @@ es5id: 12.6.3_A8.1_T2
 description: >
     Checking if execution of "for(var index=0; {index++;index<100;};
     index*2;) {  arr.add(""+index);}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var arr = [];
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T3.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T3.js
index 2d11d19c0e..2298869eb8 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T3.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8.1_T3.js
@@ -7,7 +7,7 @@ es5id: 12.6.3_A8.1_T3
 description: >
     Checking if execution of "for({var index=0; index+=1;}
     index++<=10; index*2;) { arr.add(""+index);}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var arr = [];
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T1.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T1.js
index b61735e61d..90a8a52e3f 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T1.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T1.js
@@ -7,7 +7,7 @@ es5id: 12.6.3_A8_T1
 description: >
     Checking if execution of "for(index=0; index<100; {index++;
     index*2;}) {  arr.add(""+index);}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var arr = [];
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T2.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T2.js
index aac7670df1..8bb3742e9b 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T2.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T2.js
@@ -7,7 +7,7 @@ es5id: 12.6.3_A8_T2
 description: >
     Checking if execution of "for(index=0; {index++;index<100;};
     index*2;) {  arr.add(""+index);}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var arr = [];
diff --git a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T3.js b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T3.js
index a343bde6d5..cea0f6099e 100644
--- a/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T3.js
+++ b/test/suite/ch12/12.6/12.6.3/S12.6.3_A8_T3.js
@@ -7,7 +7,7 @@ es5id: 12.6.3_A8_T3
 description: >
     Checking if execution of "for({index=0; index+=1;} index++<=10;
     index*2;) { arr.add(""+index);}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var arr = [];
diff --git a/test/suite/ch12/12.6/12.6.4/S12.6.4_A15.js b/test/suite/ch12/12.6/12.6.4/S12.6.4_A15.js
index 039ec346ea..64f1e25e1b 100644
--- a/test/suite/ch12/12.6/12.6.4/S12.6.4_A15.js
+++ b/test/suite/ch12/12.6/12.6.4/S12.6.4_A15.js
@@ -5,14 +5,14 @@
 info: Block within a "for-in" Expression is not allowed
 es5id: 12.6.4_A15
 description: Using block within "for-in" Expression
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var __arr=[1,2,3];
 
 //////////////////////////////////////////////////////////////////////////////
 //CHECK#
-for(x in {__arr}){
+for(x in {__arr;}){
    break ;
 };
 //
diff --git a/test/suite/ch12/12.7/S12.7_A1_T1.js b/test/suite/ch12/12.7/S12.7_A1_T1.js
index 30b5da7b65..b93a188952 100644
--- a/test/suite/ch12/12.7/S12.7_A1_T1.js
+++ b/test/suite/ch12/12.7/S12.7_A1_T1.js
@@ -7,7 +7,7 @@ es5id: 12.7_A1_T1
 description: >
     Checking if execution of single "continue" without any
     IterationStatement fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.7/S12.7_A1_T2.js b/test/suite/ch12/12.7/S12.7_A1_T2.js
index 7158c19cc3..3f64dc48f9 100644
--- a/test/suite/ch12/12.7/S12.7_A1_T2.js
+++ b/test/suite/ch12/12.7/S12.7_A1_T2.js
@@ -7,7 +7,7 @@ es5id: 12.7_A1_T2
 description: >
     Checking if single "continue" with Label but without any
     IterationStatement fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 LABEL : x=3.14;
diff --git a/test/suite/ch12/12.7/S12.7_A1_T3.js b/test/suite/ch12/12.7/S12.7_A1_T3.js
index b5b980febb..5dc269fa75 100644
--- a/test/suite/ch12/12.7/S12.7_A1_T3.js
+++ b/test/suite/ch12/12.7/S12.7_A1_T3.js
@@ -7,7 +7,7 @@ es5id: 12.7_A1_T3
 description: >
     Checking if laballed "continue" with no IterationStatement, placed
     into a block, fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 LABEL : x=3.14;
diff --git a/test/suite/ch12/12.7/S12.7_A1_T4.js b/test/suite/ch12/12.7/S12.7_A1_T4.js
index 72d7b6a5da..f766c3390a 100644
--- a/test/suite/ch12/12.7/S12.7_A1_T4.js
+++ b/test/suite/ch12/12.7/S12.7_A1_T4.js
@@ -7,7 +7,7 @@ es5id: 12.7_A1_T4
 description: >
     Checking if execution of "continue" with no IterationStatement,
     placed into a block, fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.7/S12.7_A5_T1.js b/test/suite/ch12/12.7/S12.7_A5_T1.js
index 82655a7caa..48980dd7a2 100644
--- a/test/suite/ch12/12.7/S12.7_A5_T1.js
+++ b/test/suite/ch12/12.7/S12.7_A5_T1.js
@@ -8,7 +8,7 @@ info: >
     IterationStatement
 es5id: 12.7_A5_T1
 description: Trying to continue another labeled loop
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 LABEL_OUT : var x=0, y=0;
diff --git a/test/suite/ch12/12.7/S12.7_A5_T2.js b/test/suite/ch12/12.7/S12.7_A5_T2.js
index c2ba06648b..e31903c2c7 100644
--- a/test/suite/ch12/12.7/S12.7_A5_T2.js
+++ b/test/suite/ch12/12.7/S12.7_A5_T2.js
@@ -8,7 +8,7 @@ info: >
     IterationStatement
 es5id: 12.7_A5_T2
 description: Identifier is a function name
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 LABEL_OUT : var x=0, y=0;
diff --git a/test/suite/ch12/12.7/S12.7_A5_T3.js b/test/suite/ch12/12.7/S12.7_A5_T3.js
index d1b6aec5ee..1f7b0226f0 100644
--- a/test/suite/ch12/12.7/S12.7_A5_T3.js
+++ b/test/suite/ch12/12.7/S12.7_A5_T3.js
@@ -8,7 +8,7 @@ info: >
     IterationStatement
 es5id: 12.7_A5_T3
 description: Identifier is within loop label
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 LABEL_OUT : var x=0, y=0;
diff --git a/test/suite/ch12/12.7/S12.7_A6.js b/test/suite/ch12/12.7/S12.7_A6.js
index 2ba847496f..48d0646b2a 100644
--- a/test/suite/ch12/12.7/S12.7_A6.js
+++ b/test/suite/ch12/12.7/S12.7_A6.js
@@ -7,7 +7,7 @@ info: >
     IterationStatement yields SyntaxError
 es5id: 12.7_A6
 description: Using labaled "continue Identifier" within a function body
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var x=0,y=0;
diff --git a/test/suite/ch12/12.7/S12.7_A8_T1.js b/test/suite/ch12/12.7/S12.7_A8_T1.js
index 3887cd247c..68e2e22d58 100644
--- a/test/suite/ch12/12.7/S12.7_A8_T1.js
+++ b/test/suite/ch12/12.7/S12.7_A8_T1.js
@@ -7,7 +7,7 @@ es5id: 12.7_A8_T1
 description: >
     Checking if execution of "continue Identifier" within catch Block
     fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var x=0,y=0;
diff --git a/test/suite/ch12/12.7/S12.7_A8_T2.js b/test/suite/ch12/12.7/S12.7_A8_T2.js
index 90228d44ab..005df354e1 100644
--- a/test/suite/ch12/12.7/S12.7_A8_T2.js
+++ b/test/suite/ch12/12.7/S12.7_A8_T2.js
@@ -5,7 +5,7 @@
 info: Appearing of "continue" within a "try/catch" Block yields SyntaxError
 es5id: 12.7_A8_T2
 description: Checking if execution of "continue" within catch Block fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var x=0,y=0;
diff --git a/test/suite/ch12/12.8/S12.8_A1_T1.js b/test/suite/ch12/12.8/S12.8_A1_T1.js
index da7652d465..9a631ca00c 100644
--- a/test/suite/ch12/12.8/S12.8_A1_T1.js
+++ b/test/suite/ch12/12.8/S12.8_A1_T1.js
@@ -5,7 +5,7 @@
 info: Appearing of break without an IterationStatement leads to syntax error
 es5id: 12.8_A1_T1
 description: Checking if break statement with no loop fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.8/S12.8_A1_T2.js b/test/suite/ch12/12.8/S12.8_A1_T2.js
index 7076da14b4..4b2ee30c2b 100644
--- a/test/suite/ch12/12.8/S12.8_A1_T2.js
+++ b/test/suite/ch12/12.8/S12.8_A1_T2.js
@@ -5,7 +5,7 @@
 info: Appearing of break without an IterationStatement leads to syntax error
 es5id: 12.8_A1_T2
 description: Checking if break Identifier with no loop fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 LABEL : x=3.14;
diff --git a/test/suite/ch12/12.8/S12.8_A1_T3.js b/test/suite/ch12/12.8/S12.8_A1_T3.js
index f0491b68aa..9f1693cbad 100644
--- a/test/suite/ch12/12.8/S12.8_A1_T3.js
+++ b/test/suite/ch12/12.8/S12.8_A1_T3.js
@@ -7,7 +7,7 @@ es5id: 12.8_A1_T3
 description: >
     Checking if break statement with no loop, placed into a block,
     fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.8/S12.8_A1_T4.js b/test/suite/ch12/12.8/S12.8_A1_T4.js
index d011cc1b1e..e1c5752ea2 100644
--- a/test/suite/ch12/12.8/S12.8_A1_T4.js
+++ b/test/suite/ch12/12.8/S12.8_A1_T4.js
@@ -7,7 +7,7 @@ es5id: 12.8_A1_T4
 description: >
     Checking if break Identifier with no loop, placed into a  block,
     fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 LABEL : x=3.14;
diff --git a/test/suite/ch12/12.8/S12.8_A5_T1.js b/test/suite/ch12/12.8/S12.8_A5_T1.js
index 53fe39c746..c30bfa322c 100644
--- a/test/suite/ch12/12.8/S12.8_A5_T1.js
+++ b/test/suite/ch12/12.8/S12.8_A5_T1.js
@@ -7,7 +7,7 @@ info: >
     crossing function boundaries) IterationStatement
 es5id: 12.8_A5_T1
 description: Checking if breaking another labeled loop fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 (function(){
diff --git a/test/suite/ch12/12.8/S12.8_A5_T2.js b/test/suite/ch12/12.8/S12.8_A5_T2.js
index 2c9eb0ba90..d22d0af9c7 100644
--- a/test/suite/ch12/12.8/S12.8_A5_T2.js
+++ b/test/suite/ch12/12.8/S12.8_A5_T2.js
@@ -9,7 +9,7 @@ es5id: 12.8_A5_T2
 description: >
     Checking if using function name as an Identifier appears to be
     invalid
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 (function(){
diff --git a/test/suite/ch12/12.8/S12.8_A5_T3.js b/test/suite/ch12/12.8/S12.8_A5_T3.js
index 456c611690..ac14feb593 100644
--- a/test/suite/ch12/12.8/S12.8_A5_T3.js
+++ b/test/suite/ch12/12.8/S12.8_A5_T3.js
@@ -9,7 +9,7 @@ es5id: 12.8_A5_T3
 description: >
     Checking if using internal loop label as an Identifier appears to
     be invalid
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 (function(){
diff --git a/test/suite/ch12/12.8/S12.8_A6.js b/test/suite/ch12/12.8/S12.8_A6.js
index e503aa14a0..d996d39204 100644
--- a/test/suite/ch12/12.8/S12.8_A6.js
+++ b/test/suite/ch12/12.8/S12.8_A6.js
@@ -9,7 +9,7 @@ es5id: 12.8_A6
 description: >
     Checking if using "break Identifier" within a function body
     appears to be invalid
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var x=0,y=0;
diff --git a/test/suite/ch12/12.8/S12.8_A8_T1.js b/test/suite/ch12/12.8/S12.8_A8_T1.js
index 9b995278da..cdcb23e929 100644
--- a/test/suite/ch12/12.8/S12.8_A8_T1.js
+++ b/test/suite/ch12/12.8/S12.8_A8_T1.js
@@ -7,7 +7,7 @@ es5id: 12.8_A8_T1
 description: >
     Checking if using "break Identifier" from within catch Block
     appears to be invalid
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var x=0,y=0;
diff --git a/test/suite/ch12/12.8/S12.8_A8_T2.js b/test/suite/ch12/12.8/S12.8_A8_T2.js
index 946bef6072..51d7f1f49a 100644
--- a/test/suite/ch12/12.8/S12.8_A8_T2.js
+++ b/test/suite/ch12/12.8/S12.8_A8_T2.js
@@ -7,7 +7,7 @@ es5id: 12.8_A8_T2
 description: >
     Checking if using "break Identifier" from within catch Block
     appears to be invalid
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 var x=0,y=0;
diff --git a/test/suite/ch12/12.9/S12.9_A1_T1.js b/test/suite/ch12/12.9/S12.9_A1_T1.js
index f4e191e38f..5738fa4c6a 100644
--- a/test/suite/ch12/12.9/S12.9_A1_T1.js
+++ b/test/suite/ch12/12.9/S12.9_A1_T1.js
@@ -5,7 +5,7 @@
 info: Appearing of "return" without a function body leads to syntax error
 es5id: 12.9_A1_T1
 description: Checking if execution of "return" with no function fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.9/S12.9_A1_T10.js b/test/suite/ch12/12.9/S12.9_A1_T10.js
index fe67d24c73..b7bce0a775 100644
--- a/test/suite/ch12/12.9/S12.9_A1_T10.js
+++ b/test/suite/ch12/12.9/S12.9_A1_T10.js
@@ -5,7 +5,7 @@
 info: Appearing of "return" without a function body leads to syntax error
 es5id: 12.9_A1_T10
 description: Checking if execution of "return (0)" with no function fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.9/S12.9_A1_T2.js b/test/suite/ch12/12.9/S12.9_A1_T2.js
index c8348dd9df..52fc7500c5 100644
--- a/test/suite/ch12/12.9/S12.9_A1_T2.js
+++ b/test/suite/ch12/12.9/S12.9_A1_T2.js
@@ -5,7 +5,7 @@
 info: Appearing of "return" without a function body leads to syntax error
 es5id: 12.9_A1_T2
 description: Checking if execution of "return x" with no function fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.9/S12.9_A1_T3.js b/test/suite/ch12/12.9/S12.9_A1_T3.js
index 353b902cf4..db82a9aa29 100644
--- a/test/suite/ch12/12.9/S12.9_A1_T3.js
+++ b/test/suite/ch12/12.9/S12.9_A1_T3.js
@@ -5,7 +5,7 @@
 info: Appearing of "return" without a function body leads to syntax error
 es5id: 12.9_A1_T3
 description: Checking if execution of "return" within "try" statement fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.9/S12.9_A1_T4.js b/test/suite/ch12/12.9/S12.9_A1_T4.js
index a372d85418..c26d347e33 100644
--- a/test/suite/ch12/12.9/S12.9_A1_T4.js
+++ b/test/suite/ch12/12.9/S12.9_A1_T4.js
@@ -5,7 +5,7 @@
 info: Appearing of "return" without a function body leads to syntax error
 es5id: 12.9_A1_T4
 description: Checking if execution of "return" with no function fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.9/S12.9_A1_T5.js b/test/suite/ch12/12.9/S12.9_A1_T5.js
index 473ea4efc8..12c8a617a0 100644
--- a/test/suite/ch12/12.9/S12.9_A1_T5.js
+++ b/test/suite/ch12/12.9/S12.9_A1_T5.js
@@ -7,7 +7,7 @@ es5id: 12.9_A1_T5
 description: >
     Checking if execution of "return" with no function, placed into a
     Block, fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.9/S12.9_A1_T6.js b/test/suite/ch12/12.9/S12.9_A1_T6.js
index 0438d5c46b..372d6a4b93 100644
--- a/test/suite/ch12/12.9/S12.9_A1_T6.js
+++ b/test/suite/ch12/12.9/S12.9_A1_T6.js
@@ -7,7 +7,7 @@ es5id: 12.9_A1_T6
 description: >
     Checking if execution of "return" with no function, placed into a
     loop, fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.9/S12.9_A1_T7.js b/test/suite/ch12/12.9/S12.9_A1_T7.js
index e9f64c79d1..0a2d7d33a9 100644
--- a/test/suite/ch12/12.9/S12.9_A1_T7.js
+++ b/test/suite/ch12/12.9/S12.9_A1_T7.js
@@ -7,7 +7,7 @@ es5id: 12.9_A1_T7
 description: >
     Checking if execution of "return x" with no function, placed
     inside Block, fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.9/S12.9_A1_T8.js b/test/suite/ch12/12.9/S12.9_A1_T8.js
index 1545778753..0433fabc2e 100644
--- a/test/suite/ch12/12.9/S12.9_A1_T8.js
+++ b/test/suite/ch12/12.9/S12.9_A1_T8.js
@@ -7,7 +7,7 @@ es5id: 12.9_A1_T8
 description: >
     Checking if execution of "return x" with no function, placed into
     a loop, fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch12/12.9/S12.9_A1_T9.js b/test/suite/ch12/12.9/S12.9_A1_T9.js
index ef3fa9c442..d6df82e861 100644
--- a/test/suite/ch12/12.9/S12.9_A1_T9.js
+++ b/test/suite/ch12/12.9/S12.9_A1_T9.js
@@ -5,7 +5,7 @@
 info: Appearing of "return" without a function body leads to syntax error
 es5id: 12.9_A1_T9
 description: Checking if execution of "return", placed into a catch Block, fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //////////////////////////////////////////////////////////////////////////////
diff --git a/test/suite/ch13/13.0/13.0_4-17gs.js b/test/suite/ch13/13.0/13.0_4-17gs.js
index fe927783c9..6cfee358d9 100644
--- a/test/suite/ch13/13.0/13.0_4-17gs.js
+++ b/test/suite/ch13/13.0/13.0_4-17gs.js
@@ -9,11 +9,8 @@ es5id: 13.0_4-17gs
 description: >
     Strict Mode - SourceElements is not evaluated as strict mode code
     when a Function constructor is contained in strict mode code
-negative: Test262Error
 flags: [onlyStrict]
-includes: [Test262Error.js]
 ---*/
 
 "use strict";
 var _13_0_4_17_fun = new Function('eval = 42;');
-throw new Test262Error();
diff --git a/test/suite/ch13/13.0/13.0_4-5gs.js b/test/suite/ch13/13.0/13.0_4-5gs.js
index b5d43182aa..49e32cfd7a 100644
--- a/test/suite/ch13/13.0/13.0_4-5gs.js
+++ b/test/suite/ch13/13.0/13.0_4-5gs.js
@@ -9,7 +9,7 @@ es5id: 13.0_4-5gs
 description: >
     Strict Mode - SourceElements is evaluated as strict mode code when
     a FunctionDeclaration is contained in strict mode code
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch13/13.0/S13_A7_T3.js b/test/suite/ch13/13.0/S13_A7_T3.js
index cc00387e21..315edd9470 100644
--- a/test/suite/ch13/13.0/S13_A7_T3.js
+++ b/test/suite/ch13/13.0/S13_A7_T3.js
@@ -5,7 +5,7 @@
 info: The FunctionBody must be SourceElements
 es5id: 13_A7_T3
 description: Checking if execution of "function __func(){\A\B\C}" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 function __func(){\A\B\C};
diff --git a/test/suite/ch13/13.1/13.1-13gs.js b/test/suite/ch13/13.1/13.1-13gs.js
index 0c2f8eb7ed..6d31f5266e 100644
--- a/test/suite/ch13/13.1/13.1-13gs.js
+++ b/test/suite/ch13/13.1/13.1-13gs.js
@@ -9,7 +9,7 @@ es5id: 13.1-13gs
 description: >
     StrictMode - SyntaxError is thrown if 'arguments' occurs as the
     Identifier of a FunctionDeclaration
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch13/13.1/13.1-1gs.js b/test/suite/ch13/13.1/13.1-1gs.js
index cfb1b8e67d..17d9148cde 100644
--- a/test/suite/ch13/13.1/13.1-1gs.js
+++ b/test/suite/ch13/13.1/13.1-1gs.js
@@ -10,7 +10,7 @@ description: >
     Strict Mode - SyntaxError is thrown if the identifier 'eval'
     appears within a FormalParameterList of a strict mode
     FunctionDeclaration
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch13/13.1/13.1-4gs.js b/test/suite/ch13/13.1/13.1-4gs.js
index 1f97e1e09b..e47d37f510 100644
--- a/test/suite/ch13/13.1/13.1-4gs.js
+++ b/test/suite/ch13/13.1/13.1-4gs.js
@@ -10,7 +10,7 @@ description: >
     Strict Mode - SyntaxError is thrown if the identifier 'arguments'
     appears within a FormalParameterList of a strict mode
     FunctionExpression
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch13/13.1/13.1-5gs.js b/test/suite/ch13/13.1/13.1-5gs.js
index 0bf5dbde20..d150dd37e5 100644
--- a/test/suite/ch13/13.1/13.1-5gs.js
+++ b/test/suite/ch13/13.1/13.1-5gs.js
@@ -9,7 +9,7 @@ es5id: 13.1-5gs
 description: >
     Strict Mode - SyntaxError is thrown if a FunctionDeclaration has
     two identical parameters
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch13/13.1/13.1-8gs.js b/test/suite/ch13/13.1/13.1-8gs.js
index bb81b20d4b..2572d649c8 100644
--- a/test/suite/ch13/13.1/13.1-8gs.js
+++ b/test/suite/ch13/13.1/13.1-8gs.js
@@ -9,7 +9,7 @@ es5id: 13.1-8gs
 description: >
     Strict Mode - SyntaxError is thrown if a FunctionExpression has
     two identical parameters
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch13/13.2/13.2-19-b-3gs.js b/test/suite/ch13/13.2/13.2-19-b-3gs.js
index 7a12438343..156c150c80 100644
--- a/test/suite/ch13/13.2/13.2-19-b-3gs.js
+++ b/test/suite/ch13/13.2/13.2-19-b-3gs.js
@@ -9,12 +9,10 @@ es5id: 13.2-19-b-3gs
 description: >
     StrictMode - error is thrown when assign a value to the 'caller'
     property of a function object
-negative: Test262Error
+negative: TypeError
 flags: [onlyStrict]
-includes: [Test262Error.js]
 ---*/
 
 "use strict";
-throw new Test262Error();
 function _13_2_19_b_3_gs() {}
 _13_2_19_b_3_gs.caller = 1;
diff --git a/test/suite/ch14/14.1/14.1-4gs.js b/test/suite/ch14/14.1/14.1-4gs.js
index 34a6bc1b67..e9a439bbe6 100644
--- a/test/suite/ch14/14.1/14.1-4gs.js
+++ b/test/suite/ch14/14.1/14.1-4gs.js
@@ -9,7 +9,7 @@ es5id: 14.1-4gs
 description: >
     StrictMode - a Use Strict Directive followed by a strict mode
     violation
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch14/14.1/14.1-5gs.js b/test/suite/ch14/14.1/14.1-5gs.js
index 2ac4ac9c13..92ce007eed 100644
--- a/test/suite/ch14/14.1/14.1-5gs.js
+++ b/test/suite/ch14/14.1/14.1-5gs.js
@@ -9,7 +9,7 @@ es5id: 14.1-5gs
 description: >
     StrictMode - a Use Strict Directive embedded in a directive
     prologue followed by a strict mode violation
-negative: ^((?!NotEarlyError).)*$
+negative: SyntaxError
 flags: [onlyStrict]
 ---*/
 
diff --git a/test/suite/ch15/15.1/15.1.2/15.1.2.1/S15.1.2.1_A2_T2.js b/test/suite/ch15/15.1/15.1.2/15.1.2.1/S15.1.2.1_A2_T2.js
index 1338b1f160..54716deafa 100644
--- a/test/suite/ch15/15.1/15.1.2/15.1.2.1/S15.1.2.1_A2_T2.js
+++ b/test/suite/ch15/15.1/15.1.2/15.1.2.1/S15.1.2.1_A2_T2.js
@@ -5,7 +5,7 @@
 info: If the parse fails, throw a SyntaxError exception (but see also clause 16)
 es5id: 15.1.2.1_A2_T2
 description: Checking if execution of "eval("x = 1; x\u000A++")" fails
-flags: [negative]
+negative: SyntaxError
 ---*/
 
 //CHECK#1
diff --git a/test/suite/ch15/15.1/S15.1_A1_T1.js b/test/suite/ch15/15.1/S15.1_A1_T1.js
index fa53b9b593..fc285a2fec 100644
--- a/test/suite/ch15/15.1/S15.1_A1_T1.js
+++ b/test/suite/ch15/15.1/S15.1_A1_T1.js
@@ -7,7 +7,7 @@ es5id: 15.1_A1_T1
 description: >
     It is not possible to use the global object as a constructor  with
     the new operator
-flags: [negative]
+negative: TypeError
 ---*/
 
 new this;
diff --git a/test/suite/ch15/15.1/S15.1_A1_T2.js b/test/suite/ch15/15.1/S15.1_A1_T2.js
index 353fc90c12..e2bab6d97f 100644
--- a/test/suite/ch15/15.1/S15.1_A1_T2.js
+++ b/test/suite/ch15/15.1/S15.1_A1_T2.js
@@ -7,7 +7,7 @@ es5id: 15.1_A1_T2
 description: >
     It is not possible to use the global object as a constructor  with
     the new operator
-flags: [negative]
+negative: TypeError
 ---*/
 
 new this();
diff --git a/test/suite/ch15/15.1/S15.1_A2_T1.js b/test/suite/ch15/15.1/S15.1_A2_T1.js
index 1325d56381..018ba752fc 100644
--- a/test/suite/ch15/15.1/S15.1_A2_T1.js
+++ b/test/suite/ch15/15.1/S15.1_A2_T1.js
@@ -5,7 +5,7 @@
 info: The global object does not have a [[Call]] property
 es5id: 15.1_A2_T1
 description: It is not possible to invoke the global object as a function
-flags: [negative]
+negative: TypeError
 ---*/
 
 this();
diff --git a/test/suite/ch15/15.11/15.11.4/15.11.4.4/15.11.4.4-8-2.js b/test/suite/ch15/15.11/15.11.4/15.11.4.4/15.11.4.4-8-2.js
index cc7b930104..2794d04a1c 100644
--- a/test/suite/ch15/15.11/15.11.4/15.11.4.4/15.11.4.4-8-2.js
+++ b/test/suite/ch15/15.11/15.11.4/15.11.4.4/15.11.4.4-8-2.js
@@ -9,12 +9,13 @@ es5id: 15.11.4.4-8-2
 description: >
     Error.prototype.toString return empty string when 'name' is empty
     string and 'msg' is undefined
-includes: [runTestCase.js]
 ---*/
 
-function testcase() {
-        var errObj = new Error();
-        errObj.name = "";
-        return errObj.toString() === "";
-    }
-runTestCase(testcase);
+var errObj = new Error();
+errObj.name = "";
+if (errObj.name !== "") {
+    $ERROR("Expected errObj.name to be '', actually " + errObj.name);
+}
+if (errObj.toString() !== "") {
+    $ERROR("Expected errObj.toString() to be '', actually " + errObj.toString());
+}
diff --git a/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1-4.js b/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1-4.js
index ece9b230fb..2fdda1531f 100644
--- a/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1-4.js
+++ b/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1-4.js
@@ -6,16 +6,10 @@
 
 /*---
 es5id: 15.2.3.4-1-4
+info: >
+  ES5 requires a `TypeError` here, while ES6 requires `ToObject` (19.1.2.7, 19.1.2.8.1)
 description: Object.getOwnPropertyNames throws TypeError if 'O' is a boolean
-includes: [runTestCase.js]
+negative: TypeError
 ---*/
 
-function testcase() {
-        try {
-            Object.getOwnPropertyNames(true);
-            return false;
-        } catch (e) {
-            return e instanceof TypeError;
-        }
-    }
-runTestCase(testcase);
+Object.getOwnPropertyNames(true);
diff --git a/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1-5.js b/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1-5.js
index 9dd7d265ad..74f66d60d7 100644
--- a/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1-5.js
+++ b/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1-5.js
@@ -6,16 +6,10 @@
 
 /*---
 es5id: 15.2.3.4-1-5
+info: >
+  ES5 requires a `TypeError` here, while ES6 requires `ToObject` (19.1.2.7, 19.1.2.8.1)
 description: Object.getOwnPropertyNames throws TypeError if 'O' is a string
-includes: [runTestCase.js]
+negative: TypeError
 ---*/
 
-function testcase() {
-        try {
-            Object.getOwnPropertyNames("abc");
-            return false;
-        } catch (e) {
-            return e instanceof TypeError;
-        }
-    }
-runTestCase(testcase);
+Object.getOwnPropertyNames("abc");
diff --git a/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1.js b/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1.js
index 96cf9c8b61..5d3f9748ef 100644
--- a/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1.js
+++ b/test/suite/ch15/15.2/15.2.3/15.2.3.4/15.2.3.4-1.js
@@ -6,20 +6,12 @@
 
 /*---
 es5id: 15.2.3.4-1
+info: >
+  ES5 requires a `TypeError` here, while ES6 requires `ToObject` (19.1.2.7, 19.1.2.8.1)
 description: >
     Object.getOwnPropertyNames throws TypeError if type of first param
     is not Object
-includes: [runTestCase.js]
+negative: TypeError
 ---*/
 
-function testcase() {
-    try {
-      Object.getOwnPropertyNames(0);
-    }
-    catch (e) {
-      if (e instanceof TypeError) {
-        return true;
-      }
-    }
- }
-runTestCase(testcase);
+Object.getOwnPropertyNames(0);
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.3/S15.2.4.3_A12.js b/test/suite/ch15/15.2/15.2.4/15.2.4.3/S15.2.4.3_A12.js
index e88e23bc51..f49b906bed 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.3/S15.2.4.3_A12.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.3/S15.2.4.3_A12.js
@@ -6,7 +6,7 @@ es5id: 15.2.4.3_A12
 description: >
     Let O be the result of calling ToObject passing the this value as
     the argument.
-flags: [negative]
+negative: TypeError
 ---*/
 
 Object.prototype.toLocaleString.call(undefined);
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.3/S15.2.4.3_A13.js b/test/suite/ch15/15.2/15.2.4/15.2.4.3/S15.2.4.3_A13.js
index c438ea539d..682fa9994e 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.3/S15.2.4.3_A13.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.3/S15.2.4.3_A13.js
@@ -6,7 +6,7 @@ es5id: 15.2.4.3_A13
 description: >
     Let O be the result of calling ToObject passing the this value as
     the argument.
-flags: [negative]
+negative: TypeError
 ---*/
 
 Object.prototype.toLocaleString.call(null);
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A12.js b/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A12.js
index e620e6da84..24b24f66ee 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A12.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A12.js
@@ -7,7 +7,7 @@ info: >
     argument.
 es5id: 15.2.4.4_A12
 description: Checking Object.prototype.valueOf invoked by the 'call' property.
-flags: [negative]
+negative: TypeError
 ---*/
 
 Object.prototype.valueOf.call(undefined);
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A13.js b/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A13.js
index b60d60537d..05e6972092 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A13.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A13.js
@@ -7,7 +7,7 @@ info: >
     argument.
 es5id: 15.2.4.4_A13
 description: Checking Object.prototype.valueOf invoked by the 'call' property.
-flags: [negative]
+negative: TypeError
 ---*/
 
 Object.prototype.valueOf.call(null);
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A14.js b/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A14.js
index 1f1df5b7a2..cdb953f084 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A14.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A14.js
@@ -7,7 +7,7 @@ info: >
     argument.
 es5id: 15.2.4.4_A14
 description: Checking Object.prototype.valueOf invoked by the 'call' property.
-flags: [negative]
+negative: TypeError
 ---*/
 
 (1,Object.prototype.valueOf)();
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A15.js b/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A15.js
index b95ec31965..148e06fc4b 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A15.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.4/S15.2.4.4_A15.js
@@ -7,7 +7,7 @@ info: >
     argument.
 es5id: 15.2.4.4_A15
 description: Checking Object.prototype.valueOf when called as a global function.
-flags: [negative]
+negative: TypeError
 ---*/
 
 var v = Object.prototype.valueOf;
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.5/S15.2.4.5_A12.js b/test/suite/ch15/15.2/15.2.4/15.2.4.5/S15.2.4.5_A12.js
index a873a36cc7..6a97daba70 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.5/S15.2.4.5_A12.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.5/S15.2.4.5_A12.js
@@ -6,7 +6,7 @@ es5id: 15.2.4.5_A12
 description: >
     Let O be the result of calling ToObject passing the this value as
     the argument.
-flags: [negative]
+negative: TypeError
 ---*/
 
 Object.prototype.hasOwnProperty.call(undefined, 'foo');
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.5/S15.2.4.5_A13.js b/test/suite/ch15/15.2/15.2.4/15.2.4.5/S15.2.4.5_A13.js
index a2264a9a91..ea6df998e4 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.5/S15.2.4.5_A13.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.5/S15.2.4.5_A13.js
@@ -6,7 +6,7 @@ es5id: 15.2.4.5_A13
 description: >
     Let O be the result of calling ToObject passing the this value as
     the argument.
-flags: [negative]
+negative: TypeError
 ---*/
 
 Object.prototype.hasOwnProperty.call(null, 'foo');
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.6/S15.2.4.6_A12.js b/test/suite/ch15/15.2/15.2.4/15.2.4.6/S15.2.4.6_A12.js
index ada5deb3b1..8ca37a1aa8 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.6/S15.2.4.6_A12.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.6/S15.2.4.6_A12.js
@@ -6,7 +6,7 @@ es5id: 15.2.4.6_A12
 description: >
     Let O be the result of calling ToObject passing the this value as
     the argument.
-flags: [negative]
+negative: TypeError
 ---*/
 
 Object.prototype.isPrototypeOf.call(undefined, {});
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.6/S15.2.4.6_A13.js b/test/suite/ch15/15.2/15.2.4/15.2.4.6/S15.2.4.6_A13.js
index f2fd45dd3a..720b469bef 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.6/S15.2.4.6_A13.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.6/S15.2.4.6_A13.js
@@ -6,7 +6,7 @@ es5id: 15.2.4.6_A13
 description: >
     Let O be the result of calling ToObject passing the this value as
     the argument.
-flags: [negative]
+negative: TypeError
 ---*/
 
 Object.prototype.isPrototypeOf.call(null, {});
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.7/S15.2.4.7_A12.js b/test/suite/ch15/15.2/15.2.4/15.2.4.7/S15.2.4.7_A12.js
index a7449b757d..7f109a78fc 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.7/S15.2.4.7_A12.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.7/S15.2.4.7_A12.js
@@ -6,7 +6,7 @@ es5id: 15.2.4.7_A12
 description: >
     Let O be the result of calling ToObject passing the this value as
     the argument.
-flags: [negative]
+negative: TypeError
 ---*/
 
 Object.prototype.propertyIsEnumerable.call(undefined, 'foo');
diff --git a/test/suite/ch15/15.2/15.2.4/15.2.4.7/S15.2.4.7_A13.js b/test/suite/ch15/15.2/15.2.4/15.2.4.7/S15.2.4.7_A13.js
index 99177cb25d..e5df558b53 100644
--- a/test/suite/ch15/15.2/15.2.4/15.2.4.7/S15.2.4.7_A13.js
+++ b/test/suite/ch15/15.2/15.2.4/15.2.4.7/S15.2.4.7_A13.js
@@ -6,7 +6,7 @@ es5id: 15.2.4.7_A13
 description: >
     Let O be the result of calling ToObject passing the this value as
     the argument.
-flags: [negative]
+negative: TypeError
 ---*/
 
 Object.prototype.propertyIsEnumerable.call(null, 'foo');
diff --git a/test/suite/ch15/15.3/15.3.5/15.3.5-2gs.js b/test/suite/ch15/15.3/15.3.5/15.3.5-2gs.js
index f4895b2657..3bf8680c11 100644
--- a/test/suite/ch15/15.3/15.3.5/15.3.5-2gs.js
+++ b/test/suite/ch15/15.3/15.3.5/15.3.5-2gs.js
@@ -9,7 +9,7 @@ es5id: 15.3.5-2gs
 description: >
     StrictMode - error is thrown when reading the 'caller' property of
     a function object
-negative: ^((?!NotEarlyError).)*$
+negative: TypeError
 flags: [onlyStrict]
 ---*/
 
diff --git a/tools/packaging/test262.py b/tools/packaging/test262.py
index 55cb55add3..8e6fd0a105 100755
--- a/tools/packaging/test262.py
+++ b/tools/packaging/test262.py
@@ -148,25 +148,27 @@ class TestResult(object):
     if self.HasUnexpectedOutcome():
       if self.case.IsNegative():
         print "=== %s was expected to fail in %s, but didn't ===" % (name, mode)
+        print "--- expected error: %s ---\n" % self.case.GetNegative()
       else:
         if long_format:
           print "=== %s failed in %s ===" % (name, mode)
         else:
           print "%s in %s: " % (name, mode)
-        out = self.stdout.strip()
-        if len(out) > 0:
-          print "--- output ---"
-          print out
-        err = self.stderr.strip()
-        if len(err) > 0:
-          print "--- errors ---"
-          print err
-        if long_format:
-          print "==="
+      self.WriteOutput(sys.stdout)
+      if long_format:
+        print "==="
     elif self.case.IsNegative():
       print "%s failed in %s as expected" % (name, mode)
     else:
       print "%s passed in %s" % (name, mode)
+
+  def WriteOutput(self, target):
+    out = self.stdout.strip()
+    if len(out) > 0:
+       target.write("--- output --- \n %s" % out)
+    err = self.stderr.strip()
+    if len(err) > 0:
+       target.write("--- errors ---  \n %s" % err)
     
   def XmlAssemble(self, result):
     test_name = self.case.GetName()
@@ -205,12 +207,13 @@ class TestResult(object):
 
   def HasUnexpectedOutcome(self):
     if self.case.IsAsyncTest():		
-	return self.AsyncHasFailed() or self.HasFailed()
+       return self.AsyncHasFailed() or self.HasFailed()
     elif self.case.IsNegative():      
-       return not self.HasFailed()
+       return not (self.HasFailed() and self.case.NegativeMatch(self.stderr))
     else:      
        return self.HasFailed()
 
+
 class TestCase(object):
 
   def __init__(self, suite, name, full_path, strict_mode):
@@ -228,6 +231,12 @@ class TestCase(object):
     testRecord.pop("commentary", None)    # do not throw if missing
     self.testRecord = testRecord;
     
+  def NegativeMatch(self, stderr):
+    neg = re.compile(self.GetNegative())
+    return re.search(neg, stderr)
+
+  def GetNegative(self):
+    return self.testRecord['negative']
 
   def GetName(self):
     return path.join(*self.name)
@@ -549,17 +558,14 @@ class TestSuite(object):
     name = result.case.GetName()
     mode = result.case.GetMode()
     if result.HasUnexpectedOutcome():
-       if result.case.IsNegative():
+      if result.case.IsNegative():
           self.logf.write("=== %s was expected to fail in %s, but didn't === \n" % (name, mode))
-       else:
+          self.logf.write("--- expected error: %s ---\n" % result.case.GetNegative())
+          result.WriteOutput(self.logf)
+      else:
           self.logf.write("=== %s failed in %s === \n" % (name, mode))
-          out = result.stdout.strip()
-          if len(out) > 0:
-             self.logf.write("--- output --- \n %s" % out)
-          err = result.stderr.strip()
-          if len(err) > 0:
-             self.logf.write("--- errors ---  \n %s" % err)
-             self.logf.write("=== \n")
+          result.WriteOutput(self.logf)
+      self.logf.write("===\n")
     elif result.case.IsNegative():
        self.logf.write("%s failed in %s as expected \n" % (name, mode))
     else:
-- 
GitLab