Mypal/js/src/jsapi-tests
Fedor 8e4756b26b Split js/src/moz.build into multiple files. 2021-02-04 16:49:57 +02:00
..
Makefile.in basic source 2019-03-11 13:26:37 +03:00
README ooops, some files where missed 2019-03-12 18:31:25 +03:00
jsapi-tests-gdb.py.in basic source 2019-03-11 13:26:37 +03:00
moz.build Split js/src/moz.build into multiple files. 2021-02-04 16:49:57 +02:00
selfTest.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testAddPropertyPropcache.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testArgumentsObject.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testArrayBuffer.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testArrayBufferView.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testAssemblerBuffer.cpp basic source 2019-03-11 13:26:37 +03:00
testBoundFunction.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testBug604087.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testCallArgs.cpp basic source 2019-03-11 13:26:37 +03:00
testCallNonGenericMethodOnProxy.cpp basic source 2019-03-11 13:26:37 +03:00
testChromeBuffer.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testClassGetter.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testCloneScript.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testDateToLocaleString.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testDebugger.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testDeepFreeze.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testDefineGetterSetterNonEnumerable.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testDefineProperty.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testDefinePropertyIgnoredAttributes.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testDeflateStringToUTF8Buffer.cpp basic source 2019-03-11 13:26:37 +03:00
testDifferentNewTargetInvokeConstructor.cpp basic source 2019-03-11 13:26:37 +03:00
testEnclosingFunction.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testErrorCopying.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testException.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testExternalArrayBuffer.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testExternalStrings.cpp basic source 2019-03-11 13:26:37 +03:00
testFindSCCs.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testForOfIterator.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testForceLexicalInitialization.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testForwardSetProperty.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testFreshGlobalEvalRedefinition.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testFunctionBinding.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testFunctionProperties.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGCAllocator.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGCCellPtr.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGCChunkPool.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGCExactRooting.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGCFinalizeCallback.cpp basic source 2019-03-11 13:26:37 +03:00
testGCHeapPostBarriers.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGCHooks.cpp basic source 2019-03-11 13:26:37 +03:00
testGCMarking.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGCOutOfMemory.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGCStoreBufferRemoval.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGCUniqueId.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGCWeakCache.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGCWeakRef.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testGetPropertyDescriptor.cpp basic source 2019-03-11 13:26:37 +03:00
testHashTable.cpp basic source 2019-03-11 13:26:37 +03:00
testIndexToString.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testIntString.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testIntTypesABI.cpp basic source 2019-03-11 13:26:37 +03:00
testIntern.cpp basic source 2019-03-11 13:26:37 +03:00
testIntlAvailableLocales.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testIsInsideNursery.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testIteratorObject.cpp basic source 2019-03-11 13:26:37 +03:00
testJSEvaluateScript.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testJitDCEinGVN.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testJitFoldsTo.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testJitGVN.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testJitMacroAssembler.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testJitMinimalFunc.h Nuke vim lines. 2021-02-04 16:48:36 +02:00
testJitMoveEmitterCycles-mips32.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testJitMoveEmitterCycles.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testJitRValueAlloc.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testJitRangeAnalysis.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testJitRegisterSet.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testLookup.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testLooselyEqual.cpp basic source 2019-03-11 13:26:37 +03:00
testMappedArrayBuffer.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testMutedErrors.cpp basic source 2019-03-11 13:26:37 +03:00
testNewObject.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testNewTargetInvokeConstructor.cpp basic source 2019-03-11 13:26:37 +03:00
testNullRoot.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testOOM.cpp basic source 2019-03-11 13:26:37 +03:00
testObjectEmulatingUndefined.cpp basic source 2019-03-11 13:26:37 +03:00
testParseJSON.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testPersistentRooted.cpp basic source 2019-03-11 13:26:37 +03:00
testPreserveJitCode.cpp basic source 2019-03-11 13:26:37 +03:00
testPrintf.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testPrivateGCThingValue.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testProfileStrings.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testPromise.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testPropCache.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testRegExp.cpp basic source 2019-03-11 13:26:37 +03:00
testResolveRecursion.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testSameValue.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testSavedStacks.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testScriptInfo.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testScriptObject.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testSetProperty.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testSetPropertyIgnoringNamedGetter.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testSharedImmutableStringsCache.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testSlowScript.cpp basic source 2019-03-11 13:26:37 +03:00
testSourcePolicy.cpp basic source 2019-03-11 13:26:37 +03:00
testStringBuffer.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testStructuredClone.cpp basic source 2019-03-11 13:26:37 +03:00
testSymbol.cpp basic source 2019-03-11 13:26:37 +03:00
testThreadingConditionVariable.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testThreadingExclusiveData.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testThreadingMutex.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testThreadingThread.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testToIntWidth.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testTypedArrays.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testUTF8.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testUbiNode.cpp 1320408 - Change method that does GC on |this| to static method with Handle parameter. 2019-09-05 20:05:54 +03:00
testUncaughtSymbol.cpp basic source 2019-03-11 13:26:37 +03:00
testValueABI.cpp basic source 2019-03-11 13:26:37 +03:00
testWasmLEB128.cpp basic source 2019-03-11 13:26:37 +03:00
testWeakMap.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
testXDR.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
tests.cpp Nuke vim lines. 2021-02-04 16:48:36 +02:00
tests.h Nuke vim lines. 2021-02-04 16:48:36 +02:00
valueABI.c Nuke vim lines. 2021-02-04 16:48:36 +02:00

README

# JSAPI Test Suite

The tests in this directory exercise the JSAPI.


## Building and running the tests

If you built JS, you already built the tests.

The tests are built by default when you build JS. All the tests are compiled
into a single binary named jsapi-tests. They all run in a single process.

To run the tests:

    cd $OBJDIR/dist/bin
    ./jsapi-tests

To run the tests in a debugger:

    cd $OBJDIR/dist/bin
    gdb ./jsapi-tests


## Creating new tests

1.  You can either add to an existing test*.cpp file or make a new one.
    Copy an existing test and replace the body with your test code.
    The test harness provides `cx`, `rt`, and `global` for your use.

2.  If you made a new .cpp file, add it to the UNIFIED_SOURCES list
    in moz.build.


## Writing test code

Here is a sample test:

    #include "tests.h"

    BEGIN_TEST(testIntString_bug515273)
    {
        RootedValue v(cx);

        EVAL("'42';", &v);
        JSString *str = v.toString();
        CHECK(JS_StringHasBeenInterned(cx, str));
        CHECK(JS_FlatStringEqualsAscii(JS_ASSERT_STRING_IS_FLAT(str), "42"));
        return true;
    }
    END_TEST(testIntString_bug515273)

The BEGIN_TEST and END_TEST macros bracket each test. By convention, the test
name is <testFilename>_<detail>. (The above test is in testIntString.cpp.)

The curly braces are required. This block is the body of a C++ member function
that returns bool. The test harness calls this member function
automatically. If the function returns true, the test passes. False, it fails.

JSAPI tests often need extra global C/C++ code: a JSClass, a getter or setter
function, a resolve hook. Put these before the BEGIN_TEST macro.

The body of the test can use these member variables and macros, defined in
tests.h:

    JSRuntime *rt;
    JSContext *cx;
    JSObject *global;

        The test framework creates these fresh for each test. The default
        environment has reasonable default settings, including
        JSOPTION_VAROBJFIX, JSOPTION_JIT, a global object of a class with
        JSCLASS_GLOBAL_FLAGS, and an error reporter that prints to stderr.
        See also "Custom test setup" below.

    EXEC(const char *code);

        Execute some JS code in global scope, using JS::Evaluate. Return
        false if that fails. (This means that if the code throws an uncaught JS
        exception, the test fails.)

    EVAL(const char *code, jsval *vp);

        Same as EXEC, but store the result value in *vp.

    CHECK(bool cond);

        If the condition is not true, print an error message and return false,
        failing the test.

    CHECK_SAME(jsval a, jsval b);

        If a and b are different values, print an error message and return
        false, failing the test.

        This is like CHECK(sameValue(a, b)) but with a more detailed error
        message on failure. See sameValue below.

    CHECK_EQUAL(const T &a, const U &b);

        CHECK(a == b), but with a more detailed error message.

    CHECK_NULL(const T *ptr);

        CHECK(ptr == nullptr), but with a more detailed error message.

        (This is here because CHECK_EQUAL(ptr, nullptr) fails to compile on GCC
        2.5 and before.)


    bool knownFail;

        Set this to true if your test is known to fail. The test runner will
        print a TEST-KNOWN-FAIL line rather than a TEST-UNEXPECTED-FAIL
        line. This way you can check in a test illustrating a bug ahead of the
        fix.

        If your test actually crashes the process or triggers an assertion,
        this of course will not help, so you should add something like

            knownFail = true;  // see bug 123456
            return false;  // the code below crashes!

        as the first two lines of the test.

    bool isNegativeZero(jsval v);
    bool isNaN(jsval v);

        Self-explanatory.

    bool sameValue(jsval v1, jsval v2);

        True if v1 and v2 are the same value according to the ES5 SameValue()
        function, to wit:

        SameValue(NaN, NaN) is true.
        SameValue(-0, 0) is false.
        Otherwise SameValue(a, b) iff a === b.


## Custom test setup

Before executing each test, the test framework calls the tests' init() member
function, which populates the rt, cx, and global member variables.

A test can customize the test setup process by overloading virtual member
functions, like this:

    const JSClass globalClassWithResolve = { ... };

    BEGIN_TEST(testGlobalResolveHook)
        {
            RootedValue v;
            EVAL("v", v.address());
            CHECK_SAME(v, JSVAL_VOID);
            return true;
        }

        // Other class members can go here.

        // This one overloads a base-class method.
        virtual JSClass *getGlobalJSClass() {
            return &globalClassWithResolve;
        }
    END_TEST(testGlobalResolveHook)

The overloadable member functions are:

    virtual bool init();
    virtual void uninit();
    virtual JSRuntime * createRuntime();
    virtual JSContext * createContext();
    virtual JSClass * getGlobalClass();
    virtual JSObject * createGlobal();