feat: update getSignatureStatus methods

This commit is contained in:
Justin Starry 2020-04-06 17:56:26 +08:00 committed by Michael Vines
parent ae10f1ecab
commit 3a2fe7fdbc
7 changed files with 57 additions and 23 deletions

9
web3.js/module.d.ts vendored
View File

@ -48,6 +48,10 @@ declare module '@solana/web3.js' {
export type Commitment = 'max' | 'recent';
export type SignatureStatusConfig = {
searchTransactionHistory: boolean;
};
export type SignatureStatus = {
slot: number;
err: TransactionError | null;
@ -160,6 +164,7 @@ declare module '@solana/web3.js' {
export class Connection {
constructor(endpoint: string, commitment?: Commitment);
commitment?: Commitment;
getAccountInfoAndContext(
publicKey: PublicKey,
commitment?: Commitment,
@ -192,11 +197,11 @@ declare module '@solana/web3.js' {
getSlotLeader(commitment?: Commitment): Promise<string>;
getSignatureStatus(
signature: TransactionSignature,
commitment?: Commitment,
config?: SignatureStatusConfig,
): Promise<RpcResponseAndContext<SignatureStatus | null>>;
getSignatureStatuses(
signatures: Array<TransactionSignature>,
commitment?: Commitment,
config?: SignatureStatusConfig,
): Promise<RpcResponseAndContext<Array<SignatureStatus | null>>>;
getTransactionCount(commitment?: Commitment): Promise<number>;
getTotalSupply(commitment?: Commitment): Promise<number>;

View File

@ -61,6 +61,10 @@ declare module '@solana/web3.js' {
declare export type Commitment = 'max' | 'recent';
declare export type SignatureStatusConfig = {
searchTransactionHistory: boolean,
};
declare export type SignatureStatus = {
slot: number,
err: TransactionError | null,
@ -173,6 +177,7 @@ declare module '@solana/web3.js' {
declare export class Connection {
constructor(endpoint: string, commitment: ?Commitment): Connection;
commitment: ?Commitment;
getAccountInfoAndContext(
publicKey: PublicKey,
commitment: ?Commitment,
@ -205,11 +210,11 @@ declare module '@solana/web3.js' {
getSlotLeader(commitment: ?Commitment): Promise<string>;
getSignatureStatus(
signature: TransactionSignature,
commitment: ?Commitment,
config: ?SignatureStatusConfig,
): Promise<RpcResponseAndContext<SignatureStatus | null>>;
getSignatureStatuses(
signatures: Array<TransactionSignature>,
commitment: ?Commitment,
config: ?SignatureStatusConfig,
): Promise<RpcResponseAndContext<Array<SignatureStatus | null>>>;
getTransactionCount(commitment: ?Commitment): Promise<number>;
getTotalSupply(commitment: ?Commitment): Promise<number>;

View File

@ -96,6 +96,16 @@ function notificationResultAndContext(resultDescription: any) {
*/
export type Commitment = 'max' | 'recent';
/**
* Configuration object for changing query behavior
*
* @typedef {Object} SignatureStatusConfig
* @property {boolean} searchTransactionHistory enable searching status history, not needed for recent transactions
*/
export type SignatureStatusConfig = {
searchTransactionHistory: boolean,
};
/**
* Information describing a cluster node
*
@ -829,6 +839,13 @@ export class Connection {
);
}
/**
* The default commitment used for requests
*/
get commitment(): ?Commitment {
return this._commitment;
}
/**
* Fetch the balance for the specified public key, return with context
*/
@ -1033,25 +1050,28 @@ export class Connection {
*/
async getSignatureStatus(
signature: TransactionSignature,
commitment: ?Commitment,
config: ?SignatureStatusConfig,
): Promise<RpcResponseAndContext<SignatureStatus | null>> {
const {context, value} = await this.getSignatureStatuses(
[signature],
commitment,
config,
);
assert(value.length === 1);
return {context, value: value[0]};
}
/**
* Fetch the current status of a signature
* Fetch the current statuses of a batch of signatures
*/
async getSignatureStatuses(
signatures: Array<TransactionSignature>,
commitment: ?Commitment,
config: ?SignatureStatusConfig,
): Promise<RpcResponseAndContext<Array<SignatureStatus | null>>> {
const args = this._argsWithCommitment([signatures], commitment);
const unsafeRes = await this._rpcRequest('getSignatureStatuses', args);
const params = [signatures];
if (config) {
params.push(config);
}
const unsafeRes = await this._rpcRequest('getSignatureStatuses', params);
const res = GetSignatureStatusesRpcResult(unsafeRes);
if (res.error) {
throw new Error(res.error.message);

View File

@ -15,15 +15,20 @@ export async function sendAndConfirmRawTransaction(
commitment: ?Commitment,
): Promise<TransactionSignature> {
const start = Date.now();
const statusCommitment = commitment || connection.commitment || 'max';
let signature = await connection.sendRawTransaction(rawTransaction);
// Wait up to a couple slots for a confirmation
let status = null;
let statusRetries = 6;
for (;;) {
status = (await connection.getSignatureStatus(signature, commitment)).value;
status = (await connection.getSignatureStatus(signature)).value;
if (status) {
if (statusCommitment === 'max' && status.confirmations === null) {
break;
} else if (statusCommitment === 'recent') {
break;
}
}
// Sleep for approximately half a slot

View File

@ -43,8 +43,11 @@ async function _sendAndConfirmTransaction(
signers: Array<Account>,
commitment: ?Commitment,
): Promise<TransactionSignature> {
const statusCommitment = commitment || connection.commitment || 'max';
let sendRetries = 10;
let signature;
for (;;) {
const start = Date.now();
signature = await connection.sendTransaction(transaction, ...signers);
@ -53,10 +56,13 @@ async function _sendAndConfirmTransaction(
let status = null;
let statusRetries = 6;
for (;;) {
status = (await connection.getSignatureStatus(signature, commitment))
.value;
status = (await connection.getSignatureStatus(signature)).value;
if (status) {
if (statusCommitment === 'max' && status.confirmations === null) {
break;
} else if (statusCommitment === 'recent') {
break;
}
}
if (--statusRetries <= 0) {

View File

@ -109,7 +109,6 @@ test('get program accounts', async () => {
[
'3WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
],
{commitment: 'recent'},
],
},
{
@ -154,7 +153,6 @@ test('get program accounts', async () => {
[
'3WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
],
{commitment: 'recent'},
],
},
{
@ -905,7 +903,6 @@ test('request airdrop - max commitment', async () => {
[
'1WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
],
{commitment: 'recent'},
],
},
{
@ -926,7 +923,7 @@ test('request airdrop - max commitment', async () => {
},
]);
const {value} = await connection.getSignatureStatus(signature, 'recent');
const {value} = await connection.getSignatureStatus(signature);
if (value === null) {
expect(value).not.toBeNull();
return;
@ -1050,7 +1047,6 @@ test('transaction failure', async () => {
[
'3WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
],
{commitment: 'recent'},
],
},
{
@ -1249,7 +1245,6 @@ test('transaction', async () => {
[
'3WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
],
{commitment: 'recent'},
],
},
{
@ -1297,7 +1292,6 @@ test('transaction', async () => {
'3WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
unprocessedSignature,
],
{commitment: 'recent'},
],
},
{

View File

@ -151,7 +151,6 @@ test('transaction-payer', async () => {
[
'3WE5w4B7v59x6qjyC4FbG2FEKYKQfvsJwqSxNVmtMjT8TQ31hsZieDHcSgqzxiAoTL56n2w5TncjqEKjLhtF4Vk',
],
{commitment: 'recent'},
],
},
{