2023-01-19 06:38:42 -08:00
|
|
|
import { Connection, Keypair, LAMPORTS_PER_SOL, PublicKey, TransactionSignature, Transaction } from '@solana/web3.js';
|
|
|
|
import * as fs from 'fs';
|
|
|
|
import * as splToken from "@solana/spl-token";
|
2023-03-29 19:26:24 -07:00
|
|
|
import { deserialize_keypair, get_postional_arg, OutputFile, sleep } from './util';
|
2023-01-19 06:38:42 -08:00
|
|
|
|
|
|
|
// number of users
|
2023-03-29 19:26:24 -07:00
|
|
|
const tps: number = +get_postional_arg(2, 10);
|
|
|
|
const forSeconds: number = +get_postional_arg(3, 10);
|
2023-01-19 06:38:42 -08:00
|
|
|
// url
|
2023-03-29 19:26:24 -07:00
|
|
|
const url = get_postional_arg(4, "http://0.0.0.0:8899");
|
|
|
|
//@ts-ignore
|
|
|
|
const skip_confirmations = get_postional_arg(5, false) === "true";
|
2023-01-19 06:38:42 -08:00
|
|
|
|
2023-03-29 14:01:15 -07:00
|
|
|
(async function main() {
|
2023-03-29 19:26:24 -07:00
|
|
|
const InFile: OutputFile = JSON.parse(fs.readFileSync('out.json').toString());
|
2023-01-19 06:38:42 -08:00
|
|
|
|
2023-03-29 14:01:15 -07:00
|
|
|
console.log("benching " + tps + " transactions per second on " + url + " for " + forSeconds + " seconds");
|
2023-01-19 06:38:42 -08:00
|
|
|
|
2023-02-06 07:15:26 -08:00
|
|
|
const connection = new Connection(url, 'finalized');
|
2023-03-29 19:26:24 -07:00
|
|
|
|
|
|
|
const blockhash = await connection.getLatestBlockhash();
|
2023-02-06 07:15:26 -08:00
|
|
|
console.log('blockhash : ' + blockhash.blockhash);
|
2023-01-19 06:38:42 -08:00
|
|
|
|
2023-03-29 19:26:24 -07:00
|
|
|
const payers = InFile.fee_payers.map(deserialize_keypair);
|
|
|
|
const users = InFile.users.map(deserialize_keypair);
|
2023-01-19 06:38:42 -08:00
|
|
|
const userAccounts = InFile.tokenAccounts.map(x => new PublicKey(x));
|
2023-03-29 19:26:24 -07:00
|
|
|
|
2023-02-06 07:15:26 -08:00
|
|
|
let signatures_to_unpack: TransactionSignature[][] = new Array<TransactionSignature[]>(forSeconds);
|
2023-01-19 06:38:42 -08:00
|
|
|
let time_taken_to_send = [];
|
|
|
|
|
2023-03-29 19:26:24 -07:00
|
|
|
let payer_index = 0;
|
|
|
|
|
2023-01-19 06:38:42 -08:00
|
|
|
for (let i = 0; i < forSeconds; ++i) {
|
2023-02-06 07:15:26 -08:00
|
|
|
console.log('Sending transaction ' + i);
|
2023-01-19 06:38:42 -08:00
|
|
|
const start = performance.now();
|
2023-02-06 07:15:26 -08:00
|
|
|
signatures_to_unpack[i] = new Array<TransactionSignature>(tps);
|
|
|
|
let blockhash = (await connection.getLatestBlockhash()).blockhash;
|
2023-01-19 06:38:42 -08:00
|
|
|
for (let j = 0; j < tps; ++j) {
|
2023-03-29 14:01:15 -07:00
|
|
|
if (j % 100 == 0) {
|
2023-02-06 07:15:26 -08:00
|
|
|
blockhash = (await connection.getLatestBlockhash()).blockhash;
|
|
|
|
}
|
2023-01-19 06:38:42 -08:00
|
|
|
const toIndex = Math.floor(Math.random() * users.length);
|
|
|
|
let fromIndex = toIndex;
|
|
|
|
while (fromIndex === toIndex) {
|
|
|
|
fromIndex = Math.floor(Math.random() * users.length);
|
|
|
|
}
|
|
|
|
const userFrom = userAccounts[fromIndex];
|
|
|
|
const userTo = userAccounts[toIndex];
|
2023-02-06 07:15:26 -08:00
|
|
|
|
|
|
|
const transaction = new Transaction().add(
|
2023-03-29 14:01:15 -07:00
|
|
|
splToken.createTransferInstruction(userFrom, userTo, users[fromIndex].publicKey, Math.ceil((Math.random() + 1) * 100))
|
2023-02-06 07:15:26 -08:00
|
|
|
);
|
|
|
|
transaction.recentBlockhash = blockhash;
|
2023-03-29 19:26:24 -07:00
|
|
|
transaction.feePayer = payers[payer_index].publicKey;
|
2023-02-06 07:15:26 -08:00
|
|
|
|
2023-03-29 19:26:24 -07:00
|
|
|
connection
|
|
|
|
.sendTransaction(transaction, [payers[payer_index], users[fromIndex]], { skipPreflight: true })
|
|
|
|
.then(p => { signatures_to_unpack[i][j] = p });
|
|
|
|
|
|
|
|
payer_index++;
|
|
|
|
if (payer_index == payers.length) {
|
|
|
|
payer_index = 0;
|
|
|
|
}
|
2023-01-19 06:38:42 -08:00
|
|
|
}
|
|
|
|
const end = performance.now();
|
|
|
|
const diff = (end - start);
|
|
|
|
time_taken_to_send[i] = diff;
|
|
|
|
if (diff > 0 && diff < 1000) {
|
|
|
|
await sleep(1000 - diff)
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
console.log('finish sending transactions');
|
2023-03-29 19:26:24 -07:00
|
|
|
await sleep(10000)
|
2023-01-19 06:38:42 -08:00
|
|
|
console.log('checking for confirmations');
|
|
|
|
if (skip_confirmations === false) {
|
|
|
|
const size = signatures_to_unpack.length
|
|
|
|
let successes: Uint32Array = new Uint32Array(size).fill(0);
|
|
|
|
let failures: Uint32Array = new Uint32Array(size).fill(0);
|
|
|
|
for (let i = 0; i < size; ++i) {
|
|
|
|
const signatures = signatures_to_unpack[i];
|
|
|
|
for (const signature of signatures) {
|
|
|
|
const confirmed = await connection.getSignatureStatus(signature);
|
|
|
|
if (confirmed != null && confirmed.value != null && confirmed.value.err == null) {
|
|
|
|
successes[i]++;
|
|
|
|
} else {
|
|
|
|
failures[i]++;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
2024-01-02 07:22:46 -08:00
|
|
|
console.log("successes : " + successes)
|
2023-01-19 06:38:42 -08:00
|
|
|
console.log("failures : " + failures)
|
|
|
|
//console.log("time taken to send : " + time_taken_to_send)
|
|
|
|
}
|
2023-03-29 14:01:15 -07:00
|
|
|
})()
|