aboutsummaryrefslogtreecommitdiff
path: root/test
diff options
context:
space:
mode:
Diffstat (limited to 'test')
-rw-r--r--test/bun.js/ffi-test.c1
-rw-r--r--test/bun.js/ffi.test.fixture.callback.c6
-rw-r--r--test/bun.js/ffi.test.fixture.receiver.c6
-rw-r--r--test/bun.js/ffi.test.js7
4 files changed, 20 insertions, 0 deletions
diff --git a/test/bun.js/ffi-test.c b/test/bun.js/ffi-test.c
index e508b2c11..0fe227385 100644
--- a/test/bun.js/ffi-test.c
+++ b/test/bun.js/ffi-test.c
@@ -118,6 +118,7 @@ void *getDeallocatorBuffer() {
}
int getDeallocatorCalledCount() { return deallocatorCalled; }
+bool is_null(int32_t *ptr) { return ptr == NULL; }
bool does_pointer_equal_42_as_int32_t(int32_t *ptr);
bool does_pointer_equal_42_as_int32_t(int32_t *ptr) { return *ptr == 42; }
diff --git a/test/bun.js/ffi.test.fixture.callback.c b/test/bun.js/ffi.test.fixture.callback.c
index bd912dde2..f6e74f8ba 100644
--- a/test/bun.js/ffi.test.fixture.callback.c
+++ b/test/bun.js/ffi.test.fixture.callback.c
@@ -149,11 +149,17 @@ static bool JSVALUE_IS_NUMBER(EncodedJSValue val) {
static void* JSVALUE_TO_PTR(EncodedJSValue val) {
// must be a double
+ if (val.asInt64 == TagValueNull)
+ return 0;
return (void*)(val.asInt64 - DoubleEncodeOffset);
}
static EncodedJSValue PTR_TO_JSVALUE(void* ptr) {
EncodedJSValue val;
+ if (ptr == 0) {
+ val.asInt64 = TagValueNull;
+ return val;
+ }
val.asInt64 = (int64_t)ptr + DoubleEncodeOffset;
return val;
}
diff --git a/test/bun.js/ffi.test.fixture.receiver.c b/test/bun.js/ffi.test.fixture.receiver.c
index 6e1795919..3e2939a26 100644
--- a/test/bun.js/ffi.test.fixture.receiver.c
+++ b/test/bun.js/ffi.test.fixture.receiver.c
@@ -150,11 +150,17 @@ static bool JSVALUE_IS_NUMBER(EncodedJSValue val) {
static void* JSVALUE_TO_PTR(EncodedJSValue val) {
// must be a double
+ if (val.asInt64 == TagValueNull)
+ return 0;
return (void*)(val.asInt64 - DoubleEncodeOffset);
}
static EncodedJSValue PTR_TO_JSVALUE(void* ptr) {
EncodedJSValue val;
+ if (ptr == 0) {
+ val.asInt64 = TagValueNull;
+ return val;
+ }
val.asInt64 = (int64_t)ptr + DoubleEncodeOffset;
return val;
}
diff --git a/test/bun.js/ffi.test.js b/test/bun.js/ffi.test.js
index 424670b37..4e8ab42a7 100644
--- a/test/bun.js/ffi.test.js
+++ b/test/bun.js/ffi.test.js
@@ -206,6 +206,11 @@ function getTypes(fast) {
args: ["uint32_t", "uint32_t"],
},
+ is_null: {
+ returns: "bool",
+ args: ["ptr"],
+ },
+
does_pointer_equal_42_as_int32_t: {
returns: "bool",
args: ["ptr"],
@@ -339,6 +344,7 @@ function ffiRunner(fast) {
identity_ptr,
add_uint32_t,
add_uint64_t,
+ is_null,
does_pointer_equal_42_as_int32_t,
ptr_should_point_to_42_as_int32_t,
cb_identity_true,
@@ -460,6 +466,7 @@ function ffiRunner(fast) {
expect(add_uint16_t(1, 1)).toBe(2);
expect(add_uint32_t(1, 1)).toBe(2);
Bun.gc(true);
+ expect(is_null(null)).toBe(true);
const cptr = ptr_should_point_to_42_as_int32_t();
expect(cptr != 0).toBe(true);
expect(typeof cptr === "number").toBe(true);