From 6cb5d8eb86fe205ad4f4411e20c206246ff25682 Mon Sep 17 00:00:00 2001 From: Matt Mastracci Date: Sun, 8 Oct 2023 14:02:07 +0900 Subject: fix(ext/ffi): use anybuffer for op_ffi_ptr_of (#20820) Fixes #20817 --- cli/tests/unit/ffi_test.ts | 23 ++++++++++++++++++++++- 1 file changed, 22 insertions(+), 1 deletion(-) (limited to 'cli/tests') diff --git a/cli/tests/unit/ffi_test.ts b/cli/tests/unit/ffi_test.ts index c5961c6fb..018cec674 100644 --- a/cli/tests/unit/ffi_test.ts +++ b/cli/tests/unit/ffi_test.ts @@ -1,6 +1,6 @@ // Copyright 2018-2023 the Deno authors. All rights reserved. MIT license. -import { assertThrows } from "./test_util.ts"; +import { assertEquals, assertThrows } from "./test_util.ts"; Deno.test({ permissions: { ffi: true } }, function dlopenInvalidArguments() { const filename = "/usr/lib/libc.so.6"; @@ -77,3 +77,24 @@ Deno.test({ permissions: { ffi: false } }, function ffiPermissionDenied() { ptrView.getFloat64(); }, Deno.errors.PermissionDenied); }); + +Deno.test({ permissions: { ffi: true } }, function pointerOf() { + const buffer = new ArrayBuffer(1024); + const baseAddress = Deno.UnsafePointer.value(Deno.UnsafePointer.of(buffer)); + const uint8Address = Deno.UnsafePointer.value( + Deno.UnsafePointer.of(new Uint8Array(buffer)), + ); + assertEquals(baseAddress, uint8Address); + const float64Address = Deno.UnsafePointer.value( + Deno.UnsafePointer.of(new Float64Array(buffer)), + ); + assertEquals(baseAddress, float64Address); + const uint8AddressOffset = Deno.UnsafePointer.value( + Deno.UnsafePointer.of(new Uint8Array(buffer, 100)), + ); + assertEquals(Number(baseAddress) + 100, uint8AddressOffset); + const float64AddressOffset = Deno.UnsafePointer.value( + Deno.UnsafePointer.of(new Float64Array(buffer, 80)), + ); + assertEquals(Number(baseAddress) + 80, float64AddressOffset); +}); -- cgit v1.2.3