summaryrefslogtreecommitdiff
path: root/tests/compare.ts
diff options
context:
space:
mode:
authorCzarek Nakamoto <cyjan@mrcyjanek.net>2025-01-05 13:17:22 +0100
committerCzarek Nakamoto <cyjan@mrcyjanek.net>2025-01-05 13:17:22 +0100
commit085d74b37b478be77bc873d66876247a751aa957 (patch)
treed8434dd9c8c57df9b64ae93059d9ebb5a16b90f2 /tests/compare.ts
parent8e7bc59509c40f00702ba568a0adcb3cf82e6e05 (diff)
parentc3dd64bdee37d361a2c1252d127fb575936e43e6 (diff)
Merge remote-tracking branch 'origin/develop' into rust-develop
Diffstat (limited to 'tests/compare.ts')
-rwxr-xr-xtests/compare.ts75
1 files changed, 9 insertions, 66 deletions
diff --git a/tests/compare.ts b/tests/compare.ts
index d09bdd9..8c13fc5 100755
--- a/tests/compare.ts
+++ b/tests/compare.ts
@@ -1,80 +1,23 @@
-import { moneroSymbols as symbols, type MoneroTsDylib, type WowneroTsDylib } from "../impls/monero.ts/src/symbols.ts";
-import { loadMoneroDylib, loadWowneroDylib } from "../impls/monero.ts/src/bindings.ts";
-import { Wallet, WalletManager } from "../impls/monero.ts/mod.ts";
-import { readCString } from "../impls/monero.ts/src/utils.ts";
import { assertEquals } from "jsr:@std/assert";
+import { WalletManager } from "../impls/monero.ts/mod.ts";
+import { loadDylib } from "./utils.ts";
+
const coin = Deno.args[0] as "monero" | "wownero";
const version = Deno.args[1];
const walletInfo = JSON.parse(Deno.args[2]);
-const moneroSymbols = {
- ...symbols,
-
- "MONERO_Wallet_secretViewKey": {
- nonblocking: true,
- // void* wallet_ptr
- parameters: ["pointer"],
- // const char*
- result: "pointer",
- },
- "MONERO_Wallet_publicViewKey": {
- nonblocking: true,
- // void* wallet_ptr
- parameters: ["pointer"],
- // const char*
- result: "pointer",
- },
-
- "MONERO_Wallet_secretSpendKey": {
- nonblocking: true,
- // void* wallet_ptr
- parameters: ["pointer"],
- // const char*
- result: "pointer",
- },
- "MONERO_Wallet_publicSpendKey": {
- nonblocking: true,
- // void* wallet_ptr
- parameters: ["pointer"],
- // const char*
- result: "pointer",
- },
-} as const;
-
-type ReplaceMonero<T extends string> = T extends `MONERO${infer Y}` ? `WOWNERO${Y}` : never;
-type WowneroSymbols = { [Key in keyof typeof moneroSymbols as ReplaceMonero<Key>]: (typeof moneroSymbols)[Key] };
-const wowneroSymbols = Object.fromEntries(
- Object.entries(moneroSymbols).map(([key, value]) => [key.replace("MONERO", "WOWNERO"), value]),
-) as WowneroSymbols;
-
-let getKey: (wallet: Wallet, type: `${"secret" | "public"}${"Spend" | "View"}Key`) => Promise<string | null>;
-
-if (coin === "monero") {
- const dylib = Deno.dlopen(`tests/libs/${version}/monero_libwallet2_api_c.so`, moneroSymbols);
- loadMoneroDylib(dylib as MoneroTsDylib);
-
- getKey = async (wallet, type) =>
- await readCString(await dylib.symbols[`MONERO_Wallet_${type}` as const](wallet.getPointer()));
-} else {
- const dylib = Deno.dlopen(`tests/libs/${version}/wownero_libwallet2_api_c.so`, wowneroSymbols);
- loadWowneroDylib(dylib as WowneroTsDylib);
-
- getKey = async (wallet, type) =>
- await readCString(
- await dylib.symbols[`WOWNERO_Wallet_${type}` as const](wallet.getPointer()),
- );
-}
+loadDylib(coin, version);
const walletManager = await WalletManager.new();
-const wallet = await Wallet.open(walletManager, walletInfo.path, walletInfo.password);
+const wallet = await walletManager.openWallet(walletInfo.path, walletInfo.password);
assertEquals(await wallet.address(), walletInfo.address);
-assertEquals(await getKey(wallet, "publicSpendKey"), walletInfo.publicSpendKey);
-assertEquals(await getKey(wallet, "secretSpendKey"), walletInfo.secretSpendKey);
+assertEquals(await wallet.publicSpendKey(), walletInfo.publicSpendKey);
+assertEquals(await wallet.secretSpendKey(), walletInfo.secretSpendKey);
-assertEquals(await getKey(wallet, "publicViewKey"), walletInfo.publicViewKey);
-assertEquals(await getKey(wallet, "secretViewKey"), walletInfo.secretViewKey);
+assertEquals(await wallet.publicViewKey(), walletInfo.publicViewKey);
+assertEquals(await wallet.secretViewKey(), walletInfo.secretViewKey);
await wallet.store(walletInfo.path);