ethers.js/lib.commonjs/_tests/test-wallet.js
2022-09-05 16:57:11 -04:00

77 lines
3.7 KiB
JavaScript

"use strict";
var __importDefault = (this && this.__importDefault) || function (mod) {
return (mod && mod.__esModule) ? mod : { "default": mod };
};
Object.defineProperty(exports, "__esModule", { value: true });
const assert_1 = __importDefault(require("assert"));
const utils_js_1 = require("./utils.js");
const index_js_1 = require("../index.js");
describe("Test Private Key Wallet", function () {
const tests = (0, utils_js_1.loadTests)("accounts");
tests.forEach(({ name, privateKey, address }) => {
it(`creates wallet: ${name}`, function () {
const wallet = new index_js_1.Wallet(privateKey);
assert_1.default.equal(wallet.privateKey, privateKey);
assert_1.default.equal(wallet.address, address);
});
});
});
describe("Test Transaction Signing", function () {
const tests = (0, utils_js_1.loadTests)("transactions");
for (const test of tests) {
it(`tests signing a legacy transaction: ${test.name}`, async function () {
const wallet = new index_js_1.Wallet(test.privateKey);
const txData = Object.assign({}, test.transaction, { type: 0, accessList: undefined, maxFeePerGas: undefined, maxPriorityFeePerGas: undefined });
// Use the testcase sans the chainId for a legacy test
if (txData.chainId != null && parseInt(txData.chainId) != 0) {
txData.chainId = "0x00";
}
const signed = await wallet.signTransaction(txData);
assert_1.default.equal(signed, test.signedLegacy, "signedLegacy");
});
}
for (const test of tests) {
if (!test.signedEip155) {
continue;
}
it(`tests signing an EIP-155 transaction: ${test.name}`, async function () {
const wallet = new index_js_1.Wallet(test.privateKey);
const txData = Object.assign({}, test.transaction, { type: 0, accessList: undefined, maxFeePerGas: undefined, maxPriorityFeePerGas: undefined });
const signed = await wallet.signTransaction(txData);
assert_1.default.equal(signed, test.signedEip155, "signedEip155");
});
}
for (const test of tests) {
it(`tests signing a Berlin transaction: ${test.name}`, async function () {
const wallet = new index_js_1.Wallet(test.privateKey);
const txData = Object.assign({}, test.transaction, { type: 1, maxFeePerGas: undefined, maxPriorityFeePerGas: undefined });
const signed = await wallet.signTransaction(txData);
assert_1.default.equal(signed, test.signedBerlin, "signedBerlin");
});
}
for (const test of tests) {
it(`tests signing a London transaction: ${test.name}`, async function () {
const wallet = new index_js_1.Wallet(test.privateKey);
const txData = Object.assign({}, test.transaction, { type: 2 });
const signed = await wallet.signTransaction(txData);
assert_1.default.equal(signed, test.signedLondon, "signedLondon");
});
}
});
describe("Test Message Signing (EIP-191)", function () {
});
describe("Test Typed-Data Signing (EIP-712)", function () {
const tests = (0, utils_js_1.loadTests)("typed-data");
for (const test of tests) {
const { privateKey, signature } = test;
if (privateKey == null || signature == null) {
continue;
}
it(`tests signing typed-data: ${test.name}`, async function () {
const wallet = new index_js_1.Wallet(privateKey);
const sig = await wallet.signTypedData(test.domain, test.types, test.data);
assert_1.default.equal(sig, signature, "signature");
});
}
});
//# sourceMappingURL=test-wallet.js.map