From 308e2b3a6c5e655859bd7cbac9255c1113872542 Mon Sep 17 00:00:00 2001 From: Dmitry Lobanov Date: Thu, 17 Sep 2020 20:59:41 +0200 Subject: [PATCH] fix: error handler in updating an array --- build/airtable.browser.js | 5 ++--- src/table.ts | 4 ++-- test/update.test.js | 30 ++++++++++++++++++++++++++++++ 3 files changed, 34 insertions(+), 5 deletions(-) diff --git a/build/airtable.browser.js b/build/airtable.browser.js index 2d3b4828..fd6577af 100644 --- a/build/airtable.browser.js +++ b/build/airtable.browser.js @@ -885,13 +885,12 @@ var Table = /** @class */ (function () { done = optsOrDone || recordDataOrOptsOrDone; var method = isDestructiveUpdate ? 'put' : 'patch'; var requestData = assign_1.default({ records: recordsData }, opts); - this._base.runAction(method, "/" + this._urlEncodedNameOrId() + "/", {}, requestData, function (err, resp, _a) { - var records = _a.records; + this._base.runAction(method, "/" + this._urlEncodedNameOrId() + "/", {}, requestData, function (err, resp, body) { if (err) { done(err); return; } - var result = records.map(function (record) { + var result = body.records.map(function (record) { return new record_1.default(_this, record.id, record); }); done(null, result); diff --git a/src/table.ts b/src/table.ts index f410fcd8..068d2a95 100644 --- a/src/table.ts +++ b/src/table.ts @@ -242,13 +242,13 @@ class Table { `/${this._urlEncodedNameOrId()}/`, {}, requestData, - (err, resp, {records}) => { + (err, resp, body) => { if (err) { done(err); return; } - const result = records.map(record => { + const result = body.records.map(record => { return new Record(this, record.id, record); }); done(null, result); diff --git a/test/update.test.js b/test/update.test.js index abeb5c7a..46f1f9e6 100644 --- a/test/update.test.js +++ b/test/update.test.js @@ -223,6 +223,36 @@ describe('record updates', function() { } ); }); + + it('can throw an error if a multi-record update call fails due to network error', function(done) { + testExpressApp.set('handler override', function(req, res) { + res.status(522).end(); + }); + + return airtable + .base('app123') + .table('Table') + .update([ + { + id: 'rec123', + fields: {foo: 'boo'}, + }, + { + id: 'rec456', + fields: {bar: 'yar'}, + }, + ]) + .then( + function() { + throw new Error('Promise unexpectly fufilled.'); + }, + function(err) { + expect(err.statusCode).toBe(522); + expect(err.message).toBe('An unexpected error occurred'); + done(); + } + ); + }); }); describe('destructive updates', function() {