Emulation toolkit for TON Smart Contracts
yarn add @tact-lang/emulator @ton/core @ton/crypto ton-abi
import { ContractSystem, randomAddress } from '@tact-lang/emulator';
import { WalletContractV4 } from '@ton/ton';
// Contract System is a virtual environment that emulates the TON blockchain
const system = await ContractSystem.create();
// Treasure is a contract that has 1m of TONs and is a handy entry point for your smart contracts
let treasure = await system.treasure('my-treasure');
system.name(treasure, 'my treasure'); // Set a name for the contract. Useful for snapshot testing.
// Update verbosity
system.verbosity(treasure, Verbosity.ERROR); // Overwrite for a specific contract
// Track contract transactions and events
let tracker = system.track(treasure);
// Logger to collect VM logs from a contract
let logger = system.log(treasure);
// Create a random unknown address that would be treated as uninitialized contract
let unknownAddress = randomAddress('some-unknown-seed'); // This seed is used to generate deterministic address
// Send an empty message to the unknown address
await treasure.send({
to: unknownAddress,
bounce: true,
});
// Run a block
let transactions = await system.run();
console.warn(inspect(transactions, false, 10000));
// Open a contract
let wallet = system.open(WalletContractV4.create({ workchain: 0, publicKey: <some-test-key> }));
// Show contract logs
console.warn(logger.collect());
// Test events and transactions
expect(tracker.collect()).toMatchSnapshot();
MIT