six-caver-js
Version:
caver-js is a JavaScript API library that allows developers to interact with a Klaytn node
553 lines (444 loc) • 26 kB
JavaScript
/*
Copyright 2018 The caver-js Authors
This file is part of the caver-js library.
The caver-js library is free software: you can redistribute it and/or modify
it under the terms of the GNU Lesser General Public License as published by
the Free Software Foundation, either version 3 of the License, or
(at your option) any later version.
The caver-js library is distributed in the hope that it will be useful,
but WITHOUT ANY WARRANTY; without even the implied warranty of
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
GNU Lesser General Public License for more details.
You should have received a copy of the GNU Lesser General Public License
along with the caver-js. If not, see <http://www.gnu.org/licenses/>.
*/
const { expect, assert } = require('../extendedChai')
const testRPCURL = require('../testrpc')
const Caver = require('../../index.js')
let caver
let senderAddress
let senderPrvKey
let payerPrvKey
let testAccount
before(() => {
caver = new Caver(testRPCURL)
senderPrvKey =
process.env.privateKey && String(process.env.privateKey).indexOf('0x') === -1
? `0x${process.env.privateKey}`
: process.env.privateKey
payerPrvKey =
process.env.privateKey2 && String(process.env.privateKey2).indexOf('0x') === -1
? `0x${process.env.privateKey2}`
: process.env.privateKey2
const sender = caver.klay.accounts.wallet.add(senderPrvKey)
senderAddress = sender.address
testAccount = caver.klay.accounts.wallet.add(caver.klay.accounts.create())
})
describe('FEE_DELEGATED_CANCEL transaction', () => {
let cancelObject
beforeEach(() => {
cancelObject = {
type: 'FEE_DELEGATED_CANCEL',
from: senderAddress,
gas: 900000,
}
})
// Error from missing
it('CAVERJS-UNIT-TX-526 : If transaction object missing from, signTransaction should throw error', async () => {
const tx = Object.assign({}, cancelObject)
delete tx.from
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"from" is missing'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-526 : If transaction object missing from, sendTransaction should throw error', () => {
const tx = Object.assign({}, cancelObject)
delete tx.from
expect(() => caver.klay.sendTransaction(tx)).to.throws('The send transactions "from" field must be defined!')
}).timeout(200000)
// UnnecessaryTo
it('CAVERJS-UNIT-TX-527 : If transaction object has unnecessary to field, signTransaction should throw error', async () => {
const tx = Object.assign({ to: testAccount.address }, cancelObject)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"to" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-527 : If transaction object has unnecessary to field, sendTransaction should throw error', () => {
const tx = Object.assign({ to: testAccount.address }, cancelObject)
expect(() => caver.klay.sendTransaction(tx)).to.throws('"to" cannot be used with FEE_DELEGATED_CANCEL transaction')
}).timeout(200000)
// UnnecessaryValue
it('CAVERJS-UNIT-TX-528 : If transaction object has unnecessary value field, signTransaction should throw error', async () => {
const tx = Object.assign({ value: 1 }, cancelObject)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"value" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-528 : If transaction object has unnecessary value field, sendTransaction should throw error', () => {
const tx = Object.assign({ value: 1 }, cancelObject)
expect(() => caver.klay.sendTransaction(tx)).to.throws('"value" cannot be used with FEE_DELEGATED_CANCEL transaction')
}).timeout(200000)
// MissingGas
it('CAVERJS-UNIT-TX-529 : If transaction object missing gas and gasLimit, signTransaction should throw error', async () => {
const tx = Object.assign({}, cancelObject)
delete tx.gas
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"gas" is missing'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-529 : If transaction object missing gas and gasLimit, sendTransaction should throw error', () => {
const tx = Object.assign({}, cancelObject)
delete tx.gas
expect(() => caver.klay.sendTransaction(tx)).to.throws('"gas" is missing')
}).timeout(200000)
// UnnecessaryData
it('CAVERJS-UNIT-TX-530 : If transaction object has unnecessary data field, signTransaction should throw error', async () => {
const tx = Object.assign({ data: '0x68656c6c6f' }, cancelObject)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"data" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-530 : If transaction object has unnecessary data field, sendTransaction should throw error', () => {
const tx = Object.assign({ data: '0x68656c6c6f' }, cancelObject)
expect(() => caver.klay.sendTransaction(tx)).to.throws('"data" cannot be used with FEE_DELEGATED_CANCEL transaction')
}).timeout(200000)
// MissingFeePayer
it('CAVERJS-UNIT-TX-531 : If transaction object missing feePayer, should throw error', async () => {
const tx = Object.assign({}, cancelObject)
const ret = await caver.klay.accounts.signTransaction(tx, senderPrvKey)
expect(() =>
caver.klay.sendTransaction({
senderRawTransaction: ret.rawTransaction,
})
).to.throws('The "feePayer" field must be defined for signing with feePayer!')
}).timeout(200000)
// UnnecessaryFeeRatio
it('CAVERJS-UNIT-TX-533 : If transaction object has unnecessary feeRatio field, signTransaction should throw error', async () => {
const tx = Object.assign({ feeRatio: 10 }, cancelObject)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"feeRatio" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-533 : If transaction object has unnecessary feeRatio field, sendTransaction should throw error', () => {
const tx = Object.assign({ feeRatio: 10 }, cancelObject)
expect(() => caver.klay.sendTransaction(tx)).to.throws('"feeRatio" cannot be used with FEE_DELEGATED_CANCEL transaction')
}).timeout(200000)
// UnnecessaryPublicKey
it('CAVERJS-UNIT-TX-534 : If transaction object has unnecessary publicKey field, signTransaction should throw error', async () => {
const tx = Object.assign(
{
publicKey:
'0x006dc19d50bbc8a8e4b0f26c0dd3e78978f5f691a6161c41e3b0e4d1aa2d60fad62f37912b59f484b2e05bd3c9c3b4d93b0ca570d6d4421eee544e7da99e9de4',
},
cancelObject
)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"publicKey" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-534 : If transaction object has unnecessary publicKey field, sendTransaction should throw error', () => {
const tx = Object.assign(
{
publicKey:
'0x006dc19d50bbc8a8e4b0f26c0dd3e78978f5f691a6161c41e3b0e4d1aa2d60fad62f37912b59f484b2e05bd3c9c3b4d93b0ca570d6d4421eee544e7da99e9de4',
},
cancelObject
)
expect(() => caver.klay.sendTransaction(tx)).to.throws('"publicKey" cannot be used with FEE_DELEGATED_CANCEL transaction')
}).timeout(200000)
// UnnecessaryMultisig
it('CAVERJS-UNIT-TX-535 : If transaction object has unnecessary multisig field, signTransaction should throw error', async () => {
const multisig = {
threshold: 3,
keys: [
{
weight: 1,
publicKey:
'0x006dc19d50bbc8a8e4b0f26c0dd3e78978f5f691a6161c41e3b0e4d1aa2d60fad62f37912b59f484b2e05bd3c9c3b4d93b0ca570d6d4421eee544e7da99e9de4',
},
{
weight: 1,
publicKey:
'0x8244b727f63656f0c6c6923395b67cb293342de66557d26409fb0e6de96d74a58e20479c531ef99b86699969dcf0ff5c9545bf893f1aaeb20de1978b3e6bc89e',
},
{
weight: 1,
publicKey:
'0x3c63118f279933d6530ffb3ca46d2473dec1ed94b9829d290e8aa8ac8b384c9d3d79a4596abbc172d1ac6b97c079f7a6c3a7902471a20a09ab4139858352fb4f',
},
{
weight: 1,
publicKey:
'0xf4fa613bf44e5fa7505ad196605a1f32d3eb695f41916fb50f6c3ce65d345a059ebc2dc69629808c2a7c98eb0f2daad68f0b39f0a49141318fe59b777e6b8d1c',
},
],
}
const tx = Object.assign({ multisig }, cancelObject)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"multisig" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-535 : If transaction object has unnecessary multisig field, sendTransaction should throw error', () => {
const multisig = {
threshold: 3,
keys: [
{
weight: 1,
publicKey:
'0x006dc19d50bbc8a8e4b0f26c0dd3e78978f5f691a6161c41e3b0e4d1aa2d60fad62f37912b59f484b2e05bd3c9c3b4d93b0ca570d6d4421eee544e7da99e9de4',
},
{
weight: 1,
publicKey:
'0x8244b727f63656f0c6c6923395b67cb293342de66557d26409fb0e6de96d74a58e20479c531ef99b86699969dcf0ff5c9545bf893f1aaeb20de1978b3e6bc89e',
},
{
weight: 1,
publicKey:
'0x3c63118f279933d6530ffb3ca46d2473dec1ed94b9829d290e8aa8ac8b384c9d3d79a4596abbc172d1ac6b97c079f7a6c3a7902471a20a09ab4139858352fb4f',
},
{
weight: 1,
publicKey:
'0xf4fa613bf44e5fa7505ad196605a1f32d3eb695f41916fb50f6c3ce65d345a059ebc2dc69629808c2a7c98eb0f2daad68f0b39f0a49141318fe59b777e6b8d1c',
},
],
}
const tx = Object.assign({ multisig }, cancelObject)
expect(() => caver.klay.sendTransaction(tx)).to.throws('"multisig" cannot be used with FEE_DELEGATED_CANCEL transaction')
}).timeout(200000)
// UnnecessaryRoleTransactionKey
it('CAVERJS-UNIT-TX-536 : If transaction object has unnecessary roleTransactionKey field, signTransaction should throw error', async () => {
const roleTransactionKey = {
publicKey:
'0xf4fa613bf44e5fa7505ad196605a1f32d3eb695f41916fb50f6c3ce65d345a059ebc2dc69629808c2a7c98eb0f2daad68f0b39f0a49141318fe59b777e6b8d1c',
}
const tx = Object.assign({ roleTransactionKey }, cancelObject)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"roleTransactionKey" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-536 : If transaction object has unnecessary roleTransactionKey field, sendTransaction should throw error', () => {
const roleTransactionKey = {
publicKey:
'0xf4fa613bf44e5fa7505ad196605a1f32d3eb695f41916fb50f6c3ce65d345a059ebc2dc69629808c2a7c98eb0f2daad68f0b39f0a49141318fe59b777e6b8d1c',
}
const tx = Object.assign({ roleTransactionKey }, cancelObject)
expect(() => caver.klay.sendTransaction(tx)).to.throws('"roleTransactionKey" cannot be used with FEE_DELEGATED_CANCEL transaction')
}).timeout(200000)
// UnnecessaryRoleAccountUpdateKey
it('CAVERJS-UNIT-TX-537 : If transaction object has unnecessary roleAccountUpdateKey field, signTransaction should throw error', async () => {
const roleAccountUpdateKey = {
publicKey:
'0xf4fa613bf44e5fa7505ad196605a1f32d3eb695f41916fb50f6c3ce65d345a059ebc2dc69629808c2a7c98eb0f2daad68f0b39f0a49141318fe59b777e6b8d1c',
}
const tx = Object.assign({ roleAccountUpdateKey }, cancelObject)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"roleAccountUpdateKey" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-537 : If transaction object has unnecessary roleAccountUpdateKey field, sendTransaction should throw error', () => {
const roleAccountUpdateKey = {
publicKey:
'0xf4fa613bf44e5fa7505ad196605a1f32d3eb695f41916fb50f6c3ce65d345a059ebc2dc69629808c2a7c98eb0f2daad68f0b39f0a49141318fe59b777e6b8d1c',
}
const tx = Object.assign({ roleAccountUpdateKey }, cancelObject)
expect(() => caver.klay.sendTransaction(tx)).to.throws(
'"roleAccountUpdateKey" cannot be used with FEE_DELEGATED_CANCEL transaction'
)
}).timeout(200000)
// UnnecessaryRoleFeePayerKey
it('CAVERJS-UNIT-TX-538 : If transaction object has unnecessary roleFeePayerKey field, signTransaction should throw error', async () => {
const roleFeePayerKey = {
publicKey:
'0xf4fa613bf44e5fa7505ad196605a1f32d3eb695f41916fb50f6c3ce65d345a059ebc2dc69629808c2a7c98eb0f2daad68f0b39f0a49141318fe59b777e6b8d1c',
}
const tx = Object.assign({ roleFeePayerKey }, cancelObject)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"roleFeePayerKey" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-538 : If transaction object has unnecessary roleFeePayerKey field, sendTransaction should throw error', () => {
const roleFeePayerKey = {
publicKey:
'0xf4fa613bf44e5fa7505ad196605a1f32d3eb695f41916fb50f6c3ce65d345a059ebc2dc69629808c2a7c98eb0f2daad68f0b39f0a49141318fe59b777e6b8d1c',
}
const tx = Object.assign({ roleFeePayerKey }, cancelObject)
expect(() => caver.klay.sendTransaction(tx)).to.throws('"roleFeePayerKey" cannot be used with FEE_DELEGATED_CANCEL transaction')
}).timeout(200000)
// UnnecessaryFailKey
it('CAVERJS-UNIT-TX-539 : If transaction object has unnecessary failKey field, signTransaction should throw error', async () => {
const tx = Object.assign({ failKey: true }, cancelObject)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"failKey" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-539 : If transaction object has unnecessary failKey field, sendTransaction should throw error', () => {
const tx = Object.assign({ failKey: true }, cancelObject)
expect(() => caver.klay.sendTransaction(tx)).to.throws('"failKey" cannot be used with FEE_DELEGATED_CANCEL transaction')
}).timeout(200000)
// UnnecessaryCodeFormat
it('CAVERJS-UNIT-TX-540 : If transaction object has unnecessary codeFormat field, signTransaction should throw error', async () => {
const tx = Object.assign({ codeFormat: 'EVM' }, cancelObject)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"codeFormat" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-540 : If transaction object has unnecessary codeFormat field, sendTransaction should throw error', () => {
const tx = Object.assign({ codeFormat: 'EVM' }, cancelObject)
expect(() => caver.klay.sendTransaction(tx)).to.throws('"codeFormat" cannot be used with FEE_DELEGATED_CANCEL transaction')
}).timeout(200000)
// UnnecessaryLegacyKey
it('CAVERJS-UNIT-TX-541 : If transaction object has unnecessary legacyKey field, signTransaction should throw error', async () => {
const tx = Object.assign({ legacyKey: true }, cancelObject)
await caver.klay.accounts
.signTransaction(tx, senderPrvKey)
.then(() => assert(false))
.catch(err => expect(err.message).to.equals('"legacyKey" cannot be used with FEE_DELEGATED_CANCEL transaction'))
}).timeout(200000)
it('CAVERJS-UNIT-TX-541 : If transaction object has unnecessary legacyKey field, sendTransaction should throw error', () => {
const tx = Object.assign({ legacyKey: true }, cancelObject)
expect(() => caver.klay.sendTransaction(tx)).to.throws('"legacyKey" cannot be used with FEE_DELEGATED_CANCEL transaction')
}).timeout(200000)
// Invalid from address
it('CAVERJS-UNIT-TX-607: If transaction object has invalid from, signTransaction should throw error', async () => {
const tx = Object.assign({}, cancelObject)
tx.from = 'invalidAddress'
const expectedError = `Invalid address of from: ${tx.from}`
await expect(caver.klay.accounts.signTransaction(tx, testAccount.privateKey)).to.be.rejectedWith(expectedError)
}).timeout(200000)
it('CAVERJS-UNIT-TX-607: If transaction object has invalid from, sendTransaction should throw error', () => {
const tx = Object.assign({}, cancelObject)
tx.from = 'invalidAddress'
const expectedError = `Provided address "${tx.from}" is invalid, the capitalization checksum test failed`
// Throw error from formatter validation
expect(() => caver.klay.sendTransaction(tx)).to.throws(expectedError)
}).timeout(200000)
// Error feePayer missing when feePayerSignatures is defined in transaction object
it('CAVERJS-UNIT-TX-608: If transaction object missing feePayer, signTransaction should throw error', async () => {
const feePayerSignatures = [
[
'0x26',
'0x984e9d43c496ef39ef2d496c8e1aee695f871e4f6cfae7f205ddda1589ca5c9e',
'0x46647d1ce8755cd664f5fb4eba3082dd1a13817488029f3869662986b7b1a5ae',
],
]
const tx = Object.assign({ feePayerSignatures }, cancelObject)
const expectedError = '"feePayer" is missing: feePayer must be defined with feePayerSignatures.'
await expect(caver.klay.accounts.signTransaction(tx, testAccount.privateKey)).to.be.rejectedWith(expectedError)
}).timeout(200000)
it('CAVERJS-UNIT-TX-608: If transaction object missing feePayer, sendTransaction should throw error', async () => {
const feePayerSignatures = [
[
'0x26',
'0x984e9d43c496ef39ef2d496c8e1aee695f871e4f6cfae7f205ddda1589ca5c9e',
'0x46647d1ce8755cd664f5fb4eba3082dd1a13817488029f3869662986b7b1a5ae',
],
]
const tx = Object.assign({ feePayerSignatures }, cancelObject)
const expectedError = '"feePayer" is missing: feePayer must be defined with feePayerSignatures.'
// Throw error from formatter validation
expect(() => caver.klay.sendTransaction(tx)).to.throws(expectedError)
}).timeout(200000)
// Error with invalid feePayer missing when feePayerSignatures is defined in transaction object
it('CAVERJS-UNIT-TX-609: If transaction object missing feePayer, signTransaction should throw error', async () => {
const feePayerSignatures = [
[
'0x26',
'0x984e9d43c496ef39ef2d496c8e1aee695f871e4f6cfae7f205ddda1589ca5c9e',
'0x46647d1ce8755cd664f5fb4eba3082dd1a13817488029f3869662986b7b1a5ae',
],
]
const invalidFeePayer = 'feePayer'
const tx = Object.assign({ feePayer: invalidFeePayer, feePayerSignatures }, cancelObject)
const expectedError = `Invalid address of fee payer: ${invalidFeePayer}`
await expect(caver.klay.accounts.signTransaction(tx, testAccount.privateKey)).to.be.rejectedWith(expectedError)
}).timeout(200000)
it('CAVERJS-UNIT-TX-609: If transaction object missing feePayer, sendTransaction should throw error', async () => {
const feePayerSignatures = [
[
'0x26',
'0x984e9d43c496ef39ef2d496c8e1aee695f871e4f6cfae7f205ddda1589ca5c9e',
'0x46647d1ce8755cd664f5fb4eba3082dd1a13817488029f3869662986b7b1a5ae',
],
]
const invalidFeePayer = 'feePayer'
const tx = Object.assign({ feePayer: invalidFeePayer, feePayerSignatures }, cancelObject)
const expectedError = `Invalid address of fee payer: ${invalidFeePayer}`
// Throw error from formatter validation
expect(() => caver.klay.sendTransaction(tx)).to.throws(expectedError)
}).timeout(200000)
// Error when feePayer is not defined with fee payer transaction format
it('CAVERJS-UNIT-TX-610: If transaction object missing feePayer, signTransaction should throw error', async () => {
const tx = Object.assign({}, cancelObject)
const { rawTransaction } = await caver.klay.accounts.signTransaction(tx, testAccount.privateKey)
const feePayerTx = {
senderRawTransaction: rawTransaction,
feePayer: '0x',
}
const expectedError = `Invalid fee payer: ${feePayerTx.feePayer}`
await expect(caver.klay.accounts.signTransaction(feePayerTx, payerPrvKey)).to.be.rejectedWith(expectedError)
}).timeout(200000)
it('CAVERJS-UNIT-TX-610: If transaction object missing feePayer, sendTransaction should throw error', async () => {
const tx = Object.assign({}, cancelObject)
const { rawTransaction } = await caver.klay.accounts.signTransaction(tx, testAccount.privateKey)
const feePayerTx = {
senderRawTransaction: rawTransaction,
feePayer: '0x',
}
// when sendTransaction, get account from wallet before calling signTransaction
const expectedError = `Provided address "${feePayerTx.feePayer}" is invalid, the capitalization checksum test failed.`
expect(() => caver.klay.sendTransaction(feePayerTx)).to.throws(expectedError)
}).timeout(200000)
// Error when feePayer is invalid with fee payer transaction format
it('CAVERJS-UNIT-TX-611: If transaction object has invalid feePayer, signTransaction should throw error', async () => {
const tx = Object.assign({}, cancelObject)
const { rawTransaction } = await caver.klay.accounts.signTransaction(tx, testAccount.privateKey)
const feePayerTx = {
senderRawTransaction: rawTransaction,
feePayer: 'invalid',
}
const expectedError = `Invalid address of fee payer: ${feePayerTx.feePayer}`
await expect(caver.klay.accounts.signTransaction(feePayerTx, payerPrvKey)).to.be.rejectedWith(expectedError)
}).timeout(200000)
it('CAVERJS-UNIT-TX-611: If transaction object has invalid feePayer, sendTransaction should throw error', async () => {
const tx = Object.assign({}, cancelObject)
const { rawTransaction } = await caver.klay.accounts.signTransaction(tx, testAccount.privateKey)
const feePayerTx = {
senderRawTransaction: rawTransaction,
feePayer: 'invalid',
}
// when sendTransaction, get account from wallet before calling signTransaction
const expectedError = `Provided address "${feePayerTx.feePayer}" is invalid, the capitalization checksum test failed.`
expect(() => caver.klay.sendTransaction(feePayerTx)).to.throws(expectedError)
}).timeout(200000)
it('CAVERJS-UNIT-TX-717: sendTransaction should throw error when try to use an account in Node with not LEGACY transaction', async () => {
const acctInNode = caver.klay.accounts.create()
const tx = Object.assign({}, cancelObject)
tx.from = acctInNode.address
const expectedError = `No private key found in the caver-js wallet. Trying to use the Klaytn node's wallet, but it only supports legacy transactions. Please add private key of ${acctInNode.address.toLowerCase()} to the caver-js wallet.`
try {
await caver.klay.sendTransaction(tx, (error, result) => {
expect(error).not.to.be.null
expect(result).to.be.undefined
expect(error.message).to.equals(expectedError)
})
assert(false)
} catch (error) {
expect(error.message).to.equals(expectedError)
}
}).timeout(100000)
})