|
|
|
/*===
|
|
|
|
top: 19
|
|
|
|
index 0, ToString(result): 'undefined', type: 1 -> 1
|
|
|
|
index 1, ToString(result): 'null', type: 2 -> 2
|
|
|
|
index 2, ToString(result): 'true', type: 3 -> 3
|
|
|
|
index 3, ToString(result): 'false', type: 3 -> 3
|
|
|
|
index 4, ToString(result): '0', type: 4 -> 4
|
|
|
|
index 5, ToString(result): '1', type: 4 -> 4
|
|
|
|
index 6, ToString(result): 'NaN', type: 4 -> 4
|
|
|
|
index 7, ToString(result): 'Infinity', type: 4 -> 4
|
|
|
|
index 8, ToString(result): '', type: 5 -> 5
|
|
|
|
index 9, ToString(result): 'foo', type: 5 -> 5
|
|
|
|
index 10, ToString(result): '[object Object]', type: 6 -> 5
|
|
|
|
index 11, ToString(result): '123.456', type: 6 -> 4
|
|
|
|
index 12, ToString(result): '[object Thread]', type: 6 -> 5
|
|
|
|
index 13, ToString(result): '', type: 7 -> 7
|
|
|
|
index 14, ToString(result): '', type: 7 -> 7
|
|
|
|
index 15, ToString(result): '', type: 7 -> 7
|
|
|
|
index 16, ToString(result): '', type: 7 -> 7
|
|
|
|
index 17, ToString(result): 'null', type: 8 -> 8
|
|
|
|
index 18, ToString(result): '0xdeadbeef', type: 8 -> 8
|
|
|
|
rc=0, result=undefined
|
|
|
|
rc=1, result=Error: invalid index: 3
|
|
|
|
rc=1, result=Error: invalid index: -2147483648
|
|
|
|
===*/
|
|
|
|
|
|
|
|
/* FIXME: coverage is pretty poor, e.g. different hints are not tested.
|
|
|
|
* They are indirectly covered by Ecmascript tests to some extent, though.
|
|
|
|
*/
|
|
|
|
|
|
|
|
int test_1(duk_context *ctx) {
|
|
|
|
int i, n;
|
|
|
|
|
|
|
|
duk_set_top(ctx, 0);
|
|
|
|
duk_push_undefined(ctx);
|
|
|
|
duk_push_null(ctx);
|
|
|
|
duk_push_true(ctx);
|
|
|
|
duk_push_false(ctx);
|
|
|
|
duk_push_int(ctx, 0);
|
|
|
|
duk_push_int(ctx, 1);
|
|
|
|
duk_push_nan(ctx);
|
|
|
|
duk_push_number(ctx, INFINITY);
|
|
|
|
duk_push_string(ctx, "");
|
|
|
|
duk_push_string(ctx, "foo");
|
|
|
|
duk_push_object(ctx);
|
|
|
|
duk_push_number(ctx, 123.456);
|
|
|
|
duk_to_object(ctx, -1); /* Number(123.456) */
|
|
|
|
duk_push_thread(ctx);
|
|
|
|
duk_push_fixed_buffer(ctx, 0);
|
|
|
|
duk_push_fixed_buffer(ctx, 1024);
|
|
|
|
duk_push_dynamic_buffer(ctx, 0);
|
|
|
|
duk_push_dynamic_buffer(ctx, 1024);
|
|
|
|
duk_push_pointer(ctx, (void *) NULL);
|
|
|
|
duk_push_pointer(ctx, (void *) 0xdeadbeef);
|
|
|
|
|
|
|
|
n = duk_get_top(ctx);
|
|
|
|
printf("top: %d\n", n);
|
|
|
|
for (i = 0; i < n; i++) {
|
|
|
|
int t1, t2;
|
|
|
|
|
|
|
|
t1 = duk_get_type(ctx, i);
|
|
|
|
duk_to_primitive(ctx, i, DUK_HINT_NONE);
|
|
|
|
t2 = duk_get_type(ctx, i);
|
|
|
|
|
|
|
|
printf("index %d, ToString(result): '%s', type: %d -> %d\n",
|
|
|
|
i, duk_to_string(ctx, i), t1, t2);
|
|
|
|
}
|
|
|
|
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int test_2(duk_context *ctx) {
|
|
|
|
duk_set_top(ctx, 0);
|
|
|
|
duk_to_primitive(ctx, 3, DUK_HINT_NONE);
|
|
|
|
printf("index 3 OK\n");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
int test_3(duk_context *ctx) {
|
|
|
|
duk_set_top(ctx, 0);
|
|
|
|
duk_to_primitive(ctx, DUK_INVALID_INDEX, DUK_HINT_NONE);
|
|
|
|
printf("index DUK_INVALID_INDEX OK\n");
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
void test(duk_context *ctx) {
|
|
|
|
int rc;
|
|
|
|
|
|
|
|
rc = duk_safe_call(ctx, test_1, 0, 1, DUK_INVALID_INDEX);
|
|
|
|
printf("rc=%d, result=%s\n", rc, duk_to_string(ctx, -1));
|
|
|
|
duk_pop(ctx);
|
|
|
|
|
|
|
|
rc = duk_safe_call(ctx, test_2, 0, 1, DUK_INVALID_INDEX);
|
|
|
|
printf("rc=%d, result=%s\n", rc, duk_to_string(ctx, -1));
|
|
|
|
duk_pop(ctx);
|
|
|
|
|
|
|
|
/* FIXME: this test now results in an error string containing the
|
|
|
|
* exact index, which is platform dependent.
|
|
|
|
*/
|
|
|
|
rc = duk_safe_call(ctx, test_3, 0, 1, DUK_INVALID_INDEX);
|
|
|
|
printf("rc=%d, result=%s\n", rc, duk_to_string(ctx, -1));
|
|
|
|
duk_pop(ctx);
|
|
|
|
}
|
|
|
|
|