From ed10ef234aba27301476792a54b8f54f63bb6d00 Mon Sep 17 00:00:00 2001 From: surbhigarg92 Date: Mon, 21 Oct 2024 17:49:55 +0530 Subject: [PATCH] fix: remove begin call for non retriable errors --- src/transaction.ts | 30 ------------ test/spanner.ts | 119 +-------------------------------------------- 2 files changed, 1 insertion(+), 148 deletions(-) diff --git a/src/transaction.ts b/src/transaction.ts index e7993e74c..bdc12b421 100644 --- a/src/transaction.ts +++ b/src/transaction.ts @@ -743,21 +743,6 @@ export class Snapshot extends EventEmitter { this._update(response.metadata!.transaction); } }) - .on('error', err => { - const isServiceError = - err && typeof err === 'object' && 'code' in err; - if ( - !this.id && - this._useInRunner && - !( - isServiceError && - (err as grpc.ServiceError).code === grpc.status.ABORTED - ) - ) { - this.begin(); - } - setSpanError(span, err); - }) .on('end', err => { if (err) { setSpanError(span, err); @@ -1318,21 +1303,6 @@ export class Snapshot extends EventEmitter { this._update(response.metadata!.transaction); } }) - .on('error', err => { - setSpanError(span, err as Error); - const isServiceError = - err && typeof err === 'object' && 'code' in err; - if ( - !this.id && - this._useInRunner && - !( - isServiceError && - (err as grpc.ServiceError).code === grpc.status.ABORTED - ) - ) { - this.begin(); - } - }) .on('end', err => { if (err) { setSpanError(span, err as Error); diff --git a/test/spanner.ts b/test/spanner.ts index 032d18493..189717b8f 100644 --- a/test/spanner.ts +++ b/test/spanner.ts @@ -452,11 +452,8 @@ describe('Spanner with mock server', () => { request.requestOptions!.transactionTag, 'transaction-tag' ); - const beginTxnRequest = spannerMock.getRequests().find(val => { - return (val as v1.BeginTransactionRequest).options?.readWrite; - }) as v1.BeginTransactionRequest; assert.strictEqual( - beginTxnRequest.options?.readWrite!.readLockMode, + request.transaction?.begin?.readWrite?.readLockMode, 'OPTIMISTIC' ); }); @@ -3758,120 +3755,6 @@ describe('Spanner with mock server', () => { ); }); - it('should use beginTransaction on retry for unknown reason', async () => { - const database = newTestDatabase(); - await database.runTransactionAsync(async tx => { - try { - await tx.runUpdate(invalidSql); - assert.fail('missing expected error'); - } catch (e) { - assert.strictEqual( - (e as ServiceError).message, - `${grpc.status.NOT_FOUND} NOT_FOUND: ${fooNotFoundErr.message}` - ); - } - await tx.run(selectSql); - await tx.commit(); - }); - await database.close(); - - const beginTxnRequest = spannerMock - .getRequests() - .filter(val => (val as v1.BeginTransactionRequest).options?.readWrite) - .map(req => req as v1.BeginTransactionRequest); - assert.deepStrictEqual(beginTxnRequest.length, 1); - }); - - it('should use beginTransaction on retry for unknown reason with excludeTxnFromChangeStreams', async () => { - const database = newTestDatabase(); - await database.runTransactionAsync( - { - excludeTxnFromChangeStreams: true, - }, - async tx => { - try { - await tx.runUpdate(invalidSql); - assert.fail('missing expected error'); - } catch (e) { - assert.strictEqual( - (e as ServiceError).message, - `${grpc.status.NOT_FOUND} NOT_FOUND: ${fooNotFoundErr.message}` - ); - } - await tx.run(selectSql); - await tx.commit(); - } - ); - await database.close(); - - const beginTxnRequest = spannerMock - .getRequests() - .filter(val => (val as v1.BeginTransactionRequest).options?.readWrite) - .map(req => req as v1.BeginTransactionRequest); - assert.deepStrictEqual(beginTxnRequest.length, 1); - assert.strictEqual( - beginTxnRequest[0].options?.excludeTxnFromChangeStreams, - true - ); - }); - - it('should use beginTransaction for streaming on retry for unknown reason', async () => { - const database = newTestDatabase(); - await database.runTransactionAsync(async tx => { - try { - await getRowCountFromStreamingSql(tx!, {sql: invalidSql}); - assert.fail('missing expected error'); - } catch (e) { - assert.strictEqual( - (e as ServiceError).message, - `${grpc.status.NOT_FOUND} NOT_FOUND: ${fooNotFoundErr.message}` - ); - } - await tx.run(selectSql); - await tx.commit(); - }); - await database.close(); - - const beginTxnRequest = spannerMock - .getRequests() - .filter(val => (val as v1.BeginTransactionRequest).options?.readWrite) - .map(req => req as v1.BeginTransactionRequest); - assert.deepStrictEqual(beginTxnRequest.length, 1); - }); - - it('should use beginTransaction for streaming on retry for unknown reason with excludeTxnFromChangeStreams', async () => { - const database = newTestDatabase(); - await database.runTransactionAsync( - { - excludeTxnFromChangeStreams: true, - }, - async tx => { - try { - await getRowCountFromStreamingSql(tx!, {sql: invalidSql}); - assert.fail('missing expected error'); - } catch (e) { - assert.strictEqual( - (e as ServiceError).message, - `${grpc.status.NOT_FOUND} NOT_FOUND: ${fooNotFoundErr.message}` - ); - } - await tx.run(selectSql); - await tx.commit(); - } - ); - await database.close(); - - const beginTxnRequest = spannerMock - .getRequests() - .filter(val => (val as v1.BeginTransactionRequest).options?.readWrite) - .map(req => req as v1.BeginTransactionRequest); - assert.deepStrictEqual(beginTxnRequest.length, 1); - assert.strictEqual( - beginTxnRequest[0].options?.excludeTxnFromChangeStreams, - true - ); - }); - it('should fail if beginTransaction fails', async () => { const database = newTestDatabase(); const err = {