ethers.js/lib.commonjs/_tests/test-providers-data.js

205 lines
8.5 KiB
JavaScript
Raw Permalink Normal View History

2022-09-29 22:57:27 -04:00
"use strict";
Object.defineProperty(exports, "__esModule", { value: true });
2023-04-25 20:04:48 +09:00
const tslib_1 = require("tslib");
const assert_1 = tslib_1.__importDefault(require("assert"));
2022-09-29 22:57:27 -04:00
const create_provider_js_1 = require("./create-provider.js");
2022-10-01 01:34:06 -04:00
const utils_js_1 = require("./utils.js");
2022-09-29 22:57:27 -04:00
const blockchain_data_js_1 = require("./blockchain-data.js");
2022-12-30 16:35:04 -05:00
(0, create_provider_js_1.setupProviders)();
2022-09-29 22:57:27 -04:00
function forEach(prefix, tests, func) {
for (const networkName of blockchain_data_js_1.networkNames) {
const networkTests = tests[networkName];
if (networkTests == null) {
continue;
}
for (const test of networkTests) {
for (const providerName of create_provider_js_1.providerNames) {
if (!(0, create_provider_js_1.checkProvider)(providerName, networkName)) {
continue;
}
// Let the testcase skip this by returning null
const testFunc = func(providerName, test);
if (testFunc == null) {
continue;
}
// Prepare the testcase
2022-10-20 05:03:32 -04:00
(0, utils_js_1.retryIt)(`${prefix}: ${providerName}:${networkName}.${test.test}`, async function () {
2022-09-29 22:57:27 -04:00
// Create a provider
const provider = (0, create_provider_js_1.getProvider)(providerName, networkName);
try {
assert_1.default.ok(provider != null, "missing provider");
await testFunc(provider);
}
catch (error) {
// Shutdown socket-based provider, otherwise its socket will prevent
// this process from exiting
if (provider.destroy) {
provider.destroy();
}
throw error;
}
// Shutdown socket-based provider, otherwise its socket will prevent
// this process from exiting
if (provider.destroy) {
provider.destroy();
}
});
}
}
}
}
describe("Test Provider Address operations", function () {
forEach("test getBalance(address)", blockchain_data_js_1.testAddress, (providerName, test) => {
if (test.balance == null) {
return null;
}
return async (provider) => {
assert_1.default.equal(await provider.getBalance(test.address), test.balance);
};
});
forEach("test getCode(address)", blockchain_data_js_1.testAddress, (providerName, test) => {
if (test.code == null) {
return null;
}
return async (provider) => {
assert_1.default.equal(await provider.getCode(test.address), test.code);
};
});
/*
forEach("test lookupAddress(address)", testAddress, (provider, test) => {
if (test.name == null) { return null; }
return async () => {
assert.equal(await provider.lookupAddress(test.address), test.name);
};
});
forEach("test resolveName(name)", testAddress, (provider, test) => {
if (test.name == null) { return null; }
return async () => {
assert.equal(await provider.lookupAddress(<string>(test.name)), test.address);
};
});
*/
forEach("test getStorage(address)", blockchain_data_js_1.testAddress, (providerName, test) => {
if (test.storage == null) {
return null;
}
return async (provider) => {
for (const key in test.storage) {
assert_1.default.equal(await provider.getStorage(test.address, key), test.storage[key]);
}
};
});
forEach("test getTransactionCount(address)", blockchain_data_js_1.testAddress, (providerName, test) => {
if (test.balance == null) {
return null;
}
return async (provider) => {
assert_1.default.equal(await provider.getTransactionCount(test.address), test.nonce);
};
});
});
function assertObj(prefix, actual, expected) {
assert_1.default.ok(actual != null, `${prefix} is null`);
for (const key in expected) {
if (expected[key] === undefined) {
continue;
}
assert_1.default.equal(actual[key], expected[key], `${prefix}.${key}`);
}
}
function assertBlock(actual, expected) {
// Check transactions
for (let i = 0; i < expected.transactions.length; i++) {
const expectedTx = expected.transactions[i];
if (typeof (expectedTx) === "string") {
assert_1.default.equal(actual.transactions[i], expectedTx, `block.transactions[${i}]`);
}
else {
throw new Error("@TODO");
}
}
// Remove the transactions and test keys
expected = Object.assign({}, expected, { transactions: undefined, test: undefined });
// Check remaining keys
assertObj("block", actual, expected);
}
function assertTransaction(actual, expected) {
// @TODO: Accesslist
// Check signature
assertObj("tx.signature", actual.signature, expected.signature);
// Remove the transactions and test keys
expected = Object.assign({}, expected, {
accessList: undefined,
signature: undefined,
test: undefined
});
// Check remaining keys
assertObj("tx", actual, expected);
}
function assertReceipt(actual, expected) {
// Check logs
for (let i = 0; i < expected.logs.length; i++) {
let expectedLog = expected.logs[i];
for (let j = 0; j < expectedLog.topics.length; j++) {
assert_1.default.equal(actual.logs[i].topics[j], expectedLog.topics[j], `receipt.logs[${i}].topics[${j}]`);
}
expectedLog = Object.assign({}, expectedLog, { topics: undefined });
assertObj(`receipt.log[${i}]`, actual.logs[i], expectedLog);
}
// Remove the transactions and test keys
expected = Object.assign({}, expected, { logs: undefined, test: undefined });
// In Byzantium, the root was dropped and the status was added
if ((0, blockchain_data_js_1.networkFeatureAtBlock)("byzantium", expected.blockNumber)) {
expected = Object.assign({}, expected, { root: undefined });
}
else {
expected = Object.assign({}, expected, { status: undefined });
}
// Check remaining keys
assertObj("receipt", actual, expected);
}
describe("Test Provider Block operations", function () {
forEach("test getBlock(blockHash)", blockchain_data_js_1.testBlock, (providerName, test) => {
// Etherscan does not support getting a block by blockhash
if (providerName === "EtherscanProvider") {
return null;
}
return async (provider) => {
assertBlock(await provider.getBlock(test.hash), test);
};
});
forEach("test getBlock(blockNumber)", blockchain_data_js_1.testBlock, (providerName, test) => {
return async (provider) => {
assertBlock(await provider.getBlock(test.number), test);
};
});
});
describe("Test Provider Transaction operations", function () {
forEach("test getTransaction(hash)", blockchain_data_js_1.testTransaction, (providerName, test) => {
return async (provider) => {
assertTransaction(await provider.getTransaction(test.hash), test);
};
});
forEach("test getTransactionReceipt(hash)", blockchain_data_js_1.testReceipt, (providerName, test) => {
return async (provider) => {
const receipt = await provider.getTransactionReceipt(test.hash);
assert_1.default.ok(receipt != null, "receipt != null");
// Cloudflare doesn't return the root in legacy receipts; but it isn't
// *actually* that important, so we'll give it a pass...
2023-02-16 08:19:59 -05:00
if (providerName === "CloudflareProvider" || providerName === "AnkrProvider" || providerName === "PocketProvider") {
2022-09-29 22:57:27 -04:00
test = Object.assign({}, test, { root: undefined });
}
2023-02-16 08:19:59 -05:00
//if (providerName === "PocketProvider") {
//}
2022-09-29 22:57:27 -04:00
assertReceipt(receipt, test);
};
});
2023-02-16 08:19:59 -05:00
forEach("test lookupAddress(addr) == null", blockchain_data_js_1.testReceipt, (providerName, test) => {
return async (provider) => {
const name = await provider.lookupAddress("0x0123456789012345678901234567890123456789");
assert_1.default.ok(name == null, "name == null");
};
});
2022-09-29 22:57:27 -04:00
});
//# sourceMappingURL=test-providers-data.js.map