2019-05-28 08:25:16 -07:00
|
|
|
// @flow
|
2019-10-19 11:36:06 -07:00
|
|
|
import {Account, Connection, SystemProgram, SOL_LAMPORTS} from '../src';
|
2019-05-28 08:25:16 -07:00
|
|
|
import {mockRpc, mockRpcEnabled} from './__mocks__/node-fetch';
|
|
|
|
import {mockGetRecentBlockhash} from './mockrpc/get-recent-blockhash';
|
|
|
|
import {url} from './url';
|
|
|
|
import {sleep} from '../src/util/sleep';
|
|
|
|
|
|
|
|
if (!mockRpcEnabled) {
|
|
|
|
// The default of 5 seconds is too slow for live testing sometimes
|
|
|
|
jest.setTimeout(30000);
|
|
|
|
}
|
|
|
|
|
|
|
|
test('transaction-payer', async () => {
|
|
|
|
const accountPayer = new Account();
|
|
|
|
const accountFrom = new Account();
|
|
|
|
const accountTo = new Account();
|
2019-11-11 13:01:10 -05:00
|
|
|
const connection = new Connection(url, 'recent');
|
2019-05-28 08:25:16 -07:00
|
|
|
|
|
|
|
mockRpc.push([
|
|
|
|
url,
|
|
|
|
{
|
|
|
|
method: 'requestAirdrop',
|
2019-11-11 13:01:10 -05:00
|
|
|
params: [
|
|
|
|
accountPayer.publicKey.toBase58(),
|
|
|
|
SOL_LAMPORTS,
|
|
|
|
{commitment: 'recent'},
|
|
|
|
],
|
2019-05-28 08:25:16 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
error: null,
|
|
|
|
result:
|
|
|
|
'0WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
|
|
|
|
},
|
|
|
|
]);
|
2019-10-19 11:36:06 -07:00
|
|
|
await connection.requestAirdrop(accountPayer.publicKey, SOL_LAMPORTS);
|
2019-05-28 08:25:16 -07:00
|
|
|
|
|
|
|
mockRpc.push([
|
|
|
|
url,
|
|
|
|
{
|
|
|
|
method: 'requestAirdrop',
|
2019-11-11 13:01:10 -05:00
|
|
|
params: [accountFrom.publicKey.toBase58(), 12, {commitment: 'recent'}],
|
2019-05-28 08:25:16 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
error: null,
|
|
|
|
result:
|
|
|
|
'0WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
|
|
|
|
},
|
|
|
|
]);
|
|
|
|
await connection.requestAirdrop(accountFrom.publicKey, 12);
|
|
|
|
|
|
|
|
mockRpc.push([
|
|
|
|
url,
|
|
|
|
{
|
|
|
|
method: 'requestAirdrop',
|
2019-11-11 13:01:10 -05:00
|
|
|
params: [accountTo.publicKey.toBase58(), 21, {commitment: 'recent'}],
|
2019-05-28 08:25:16 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
error: null,
|
|
|
|
result:
|
|
|
|
'8WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
|
|
|
|
},
|
|
|
|
]);
|
|
|
|
await connection.requestAirdrop(accountTo.publicKey, 21);
|
|
|
|
|
2019-11-11 13:01:10 -05:00
|
|
|
mockGetRecentBlockhash('recent');
|
2019-05-28 08:25:16 -07:00
|
|
|
mockRpc.push([
|
|
|
|
url,
|
|
|
|
{
|
|
|
|
method: 'sendTransaction',
|
|
|
|
},
|
|
|
|
{
|
|
|
|
error: null,
|
|
|
|
result:
|
|
|
|
'3WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
|
|
|
|
},
|
|
|
|
]);
|
|
|
|
|
|
|
|
const transaction = SystemProgram.transfer(
|
|
|
|
accountFrom.publicKey,
|
|
|
|
accountTo.publicKey,
|
|
|
|
10,
|
|
|
|
);
|
|
|
|
|
|
|
|
const signature = await connection.sendTransaction(
|
|
|
|
transaction,
|
|
|
|
accountPayer,
|
|
|
|
accountFrom,
|
|
|
|
);
|
|
|
|
|
|
|
|
mockRpc.push([
|
|
|
|
url,
|
|
|
|
{
|
|
|
|
method: 'confirmTransaction',
|
|
|
|
params: [
|
|
|
|
'3WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
|
2019-11-11 13:01:10 -05:00
|
|
|
{commitment: 'recent'},
|
2019-05-28 08:25:16 -07:00
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
error: null,
|
|
|
|
result: true,
|
|
|
|
},
|
|
|
|
]);
|
|
|
|
|
|
|
|
let i = 0;
|
|
|
|
for (;;) {
|
|
|
|
if (await connection.confirmTransaction(signature)) {
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
|
|
|
expect(mockRpcEnabled).toBe(false);
|
|
|
|
expect(++i).toBeLessThan(10);
|
|
|
|
await sleep(500);
|
|
|
|
}
|
|
|
|
|
|
|
|
mockRpc.push([
|
|
|
|
url,
|
|
|
|
{
|
|
|
|
method: 'getSignatureStatus',
|
|
|
|
params: [
|
|
|
|
'3WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
|
2019-11-11 13:01:10 -05:00
|
|
|
{commitment: 'recent'},
|
2019-05-28 08:25:16 -07:00
|
|
|
],
|
|
|
|
},
|
|
|
|
{
|
|
|
|
error: null,
|
|
|
|
result: {Ok: null},
|
|
|
|
},
|
|
|
|
]);
|
|
|
|
await expect(connection.getSignatureStatus(signature)).resolves.toEqual({
|
|
|
|
Ok: null,
|
|
|
|
});
|
|
|
|
|
|
|
|
mockRpc.push([
|
|
|
|
url,
|
|
|
|
{
|
|
|
|
method: 'getBalance',
|
2019-11-11 13:01:10 -05:00
|
|
|
params: [accountPayer.publicKey.toBase58(), {commitment: 'recent'}],
|
2019-05-28 08:25:16 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
error: null,
|
|
|
|
result: 99,
|
|
|
|
},
|
|
|
|
]);
|
|
|
|
|
2019-06-12 14:36:05 -07:00
|
|
|
// accountPayer could be less than 100 as it paid for the transaction
|
2019-05-28 08:25:16 -07:00
|
|
|
// (exact amount less depends on the current cluster fees)
|
|
|
|
const balance = await connection.getBalance(accountPayer.publicKey);
|
|
|
|
expect(balance).toBeGreaterThan(0);
|
2019-10-19 11:36:06 -07:00
|
|
|
expect(balance).toBeLessThanOrEqual(SOL_LAMPORTS);
|
2019-05-28 08:25:16 -07:00
|
|
|
|
|
|
|
// accountFrom should have exactly 2, since it didn't pay for the transaction
|
|
|
|
mockRpc.push([
|
|
|
|
url,
|
|
|
|
{
|
|
|
|
method: 'getBalance',
|
2019-11-11 13:01:10 -05:00
|
|
|
params: [accountFrom.publicKey.toBase58(), {commitment: 'recent'}],
|
2019-05-28 08:25:16 -07:00
|
|
|
},
|
|
|
|
{
|
|
|
|
error: null,
|
|
|
|
result: 2,
|
|
|
|
},
|
|
|
|
]);
|
|
|
|
expect(await connection.getBalance(accountFrom.publicKey)).toBe(2);
|
|
|
|
});
|