Files
Matt Hess 733ecd2681 Migrate all JS tests to Rust: 9-crate workspace, 703 tests, 0 JS remaining
Add root Cargo workspace with 9 crates: salvium-crypto (extended),
  salvium-types, salvium-consensus, salvium-wallet, salvium-tx,
  salvium-rpc, salvium-miner (extended), salvium-cli, salvium-multisig.

  New modules: chain_state, block_weight, alt_chain, validation,
  offline signing, stake lifecycle, wallet sync/query/encryption/utxo,
  randomx utilities, and full multisig crate with CARROT support.

  Delete 188 JS test/helper/debug files; archive integration test
  scripts to test/legacy-js/ for live testnet use. Testnet integration
  tests (transfer, stake, burn, convert, sweep) remain as #[ignore]-
  gated Rust tests runnable with --ignored against a live daemon.
2026-02-17 23:09:35 +00:00

36 lines
1.2 KiB
JavaScript

/**
* Debug: Quick hash test with WASM cache
*/
import { RandomXContext, preloadWasm } from '../src/randomx/index.js';
console.log('=== Quick Hash Test ===\n');
// Pre-load WASM
console.log('Pre-loading WASM...');
await preloadWasm();
console.log('WASM loaded.\n');
const testKey = new TextEncoder().encode('test key 000');
const testInput = new TextEncoder().encode('This is a test');
const ctx = new RandomXContext({ wasm: true, fullMode: false });
console.log('Initializing cache (WASM)...');
const startInit = Date.now();
await ctx.init(testKey);
console.log(`Cache init: ${((Date.now() - startInit) / 1000).toFixed(1)}s\n`);
console.log('Computing hash...');
const startHash = Date.now();
const hash = ctx.hash(testInput);
const hashTime = (Date.now() - startHash) / 1000;
console.log(`Hash: ${Buffer.from(hash).toString('hex')}`);
console.log(`Expected: 639183aae1bf4c9a35884cb46b09cad9175f04efd7684e7262a0ac1c2f0b4e3f`);
console.log(`Time: ${hashTime.toFixed(2)}s`);
const expected = '639183aae1bf4c9a35884cb46b09cad9175f04efd7684e7262a0ac1c2f0b4e3f';
const actual = Buffer.from(hash).toString('hex');
console.log(`\nMatch: ${actual === expected ? 'YES!' : 'NO'}`);