733ecd2681
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.
52 lines
1.9 KiB
JavaScript
52 lines
1.9 KiB
JavaScript
/**
|
|
* Debug Argon2 final cache value after all 3 passes
|
|
*/
|
|
|
|
import { initCache } from '../src/randomx/argon2d-wasm.js';
|
|
|
|
// Helper to read little-endian uint64
|
|
function readLE64(memory, qwordIndex) {
|
|
return memory[qwordIndex];
|
|
}
|
|
|
|
console.log('=== Testing Argon2d initCache (WASM) ===\n');
|
|
|
|
const key = new TextEncoder().encode("test key 000");
|
|
console.log('Key: test key 000');
|
|
console.log('Expected cacheMemory[0]: 0x191e0e1d23c02186');
|
|
console.log('\nInitializing cache...\n');
|
|
|
|
const startTime = Date.now();
|
|
const cache = await initCache(key, (completed, total, pass, slice) => {
|
|
const percent = Math.floor(completed / total * 100);
|
|
if (percent % 10 === 0) {
|
|
process.stdout.write(`\rProgress: ${percent}% (pass ${pass + 1}/3, slice ${slice + 1}/4)`);
|
|
}
|
|
});
|
|
const elapsed = Date.now() - startTime;
|
|
console.log(`\n\nCache initialized in ${elapsed}ms`);
|
|
|
|
// Check first qword
|
|
const cacheMemory0 = readLE64(cache, 0);
|
|
console.log('\ncacheMemory[0]:', '0x' + cacheMemory0.toString(16));
|
|
console.log('Expected: ', '0x191e0e1d23c02186');
|
|
console.log('Match:', cacheMemory0 === 0x191e0e1d23c02186n);
|
|
|
|
// Check other test values
|
|
const cacheMemory1568413 = readLE64(cache, 1568413);
|
|
console.log('\ncacheMemory[1568413]:', '0x' + cacheMemory1568413.toString(16));
|
|
console.log('Expected: ', '0xf1b62fe6210bf8b1');
|
|
console.log('Match:', cacheMemory1568413 === 0xf1b62fe6210bf8b1n);
|
|
|
|
// Check index 33554431 (this is the last qword)
|
|
const cacheLength = cache.length;
|
|
console.log('\nCache length:', cacheLength, 'qwords');
|
|
if (33554431 < cacheLength) {
|
|
const cacheMemory33554431 = readLE64(cache, 33554431);
|
|
console.log('cacheMemory[33554431]:', '0x' + cacheMemory33554431.toString(16));
|
|
console.log('Expected: ', '0x1f47f056d05cd99b');
|
|
console.log('Match:', cacheMemory33554431 === 0x1f47f056d05cd99bn);
|
|
} else {
|
|
console.log('Index 33554431 out of range (cache length:', cacheLength, ')');
|
|
}
|