Nevar pievienot vairāk kā 25 tēmas Tēmai ir jāsākas ar burtu vai ciparu, tā var saturēt domu zīmes ('-') un var būt līdz 35 simboliem gara.

start.ts 2.9KB

12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182
  1. import * as dotevnv from "dotenv"
  2. import {toUtf8String,parseUnits,ContractFactory, parseEther,JsonRpcProvider, Contract, JsonRpcSigner, Wallet,ContractTransactionResponse, MaxInt256
  3. ,Transaction,formatEther,
  4. ZeroHash,ethers,keccak256,
  5. FetchRequest,JsonRpcApiProviderOptions
  6. } from 'ethers'
  7. import {Calulator} from "../inc/calc";
  8. import chalk from "chalk";
  9. import { TokenIssuer } from "../inc/TokenIssuer";
  10. import {
  11. SecurityToken,
  12. SecurityToken__factory,
  13. } from '../typechain'
  14. // import { HardhatEthersSigner } from "@nomicfoundation/hardhat-ethers/signers";
  15. import {checkReceipt,checkReceipt2, setProvider,getDeploymentAddresses,
  16. getElapsed, sleep,getBlockInfo,getNonce} from '../inc/util'
  17. import { assert } from "console";
  18. dotevnv.config();
  19. if (!process.env.RPCURL) {
  20. console.log(`No rpcur value specified...`)
  21. }
  22. async function readTest(symbol:string, holder: Wallet, count: number = 100): Promise<any> {
  23. const proxy = getDeploymentAddresses(symbol).address;
  24. console.log(`토큰 주소 : ${proxy}`);
  25. const token = new SecurityToken__factory(holder).attach(proxy) as SecurityToken;
  26. let balance1= await token.balanceOf(holder);
  27. console.log(chalk.blue(`잔고(${holder.address}) = ${balance1}`));
  28. const start = Date.now();
  29. console.log(chalk.cyan(`조회시작 시간 : ${new Date(start).toUTCString()}`));
  30. console.log(chalk.yellow(`reading balance ${count} times`));
  31. let proms = [];
  32. for(let i = 0; i < count; i++) {
  33. proms.push(token.balanceOf(holder));
  34. }
  35. let resolved = await Promise.all(proms);
  36. assert(count == resolved.length);
  37. resolved.forEach(balance => {
  38. // console.log(balance);
  39. if(balance != balance1) {
  40. console.log('balance mismatch!!!!!!!!!!!!!!!!!!!!!!!!!!');
  41. }
  42. });
  43. const end = Date.now();
  44. const elapsed = getElapsed(start,1000);
  45. console.log(`request finished in ${elapsed} seconds`);
  46. const CEPS = calc.CQPS(count,start,end);
  47. console.log(`CQPS = ${CEPS}`);
  48. return 0;
  49. }
  50. const calc = new Calulator();
  51. const rpcUrl = process.env.RPCURL;
  52. const fetchRequest = new FetchRequest(rpcUrl);
  53. fetchRequest.timeout = 10000;
  54. // const provider = new JsonRpcProvider(fetchRequest,null,{batchMaxSize: 5, batchMaxCount: 100});
  55. const provider = new JsonRpcProvider(fetchRequest);
  56. setProvider(provider);
  57. console.log(`목적 서버 : ${rpcUrl}`);
  58. const admin = new Wallet('0xc87509a1c067bbde78beb793e6fa76530b6382a4c0241e5e4a9ec0a0f44dc0d3',provider);
  59. const issuer = new Wallet('0x8f2a55949038a9610f50fb23b5883af3b4ecb3c3bb792cbcefbd1542c692be63',provider);
  60. const holder1 = new Wallet('0xae6ae8e5ccbfb04590405997ee2d52d2b330726137b875053c36d94e974d162f',provider);
  61. const holder2 = new Wallet('0xac0974bec39a17e36ba4a6b4d238ff944bacb478cbed5efcae784d7bf4f2ff80',provider);
  62. async function main() {
  63. await readTest('test001',holder1,1000);
  64. }
  65. main();