Skip to content

Commit

Permalink
Improved API response validation (aws#287)
Browse files Browse the repository at this point in the history
  • Loading branch information
willarmiros authored May 5, 2020
1 parent bfbc97d commit 6d35667
Show file tree
Hide file tree
Showing 2 changed files with 29 additions and 2 deletions.
12 changes: 10 additions & 2 deletions packages/core/lib/middleware/sampling/service_connector.js
Original file line number Diff line number Diff line change
Expand Up @@ -43,6 +43,10 @@ var ServiceConnector = {
callback(err);
}

if (dataObj === null) {
callback(new Error('AWS X-Ray GetSamplingRules API returned null response'));
}

var newRules = assembleRules(dataObj);
callback(null, newRules);
});
Expand Down Expand Up @@ -79,6 +83,10 @@ var ServiceConnector = {
callback(err);
}

if (dataObj === null || !dataObj['LastRuleModification']) {
callback(new Error('AWS X-Ray SamplingTargets API returned invalid response'));
}

var targetsMapping = assembleTargets(dataObj);
var ruleFreshness = dateToEpoch(dataObj['LastRuleModification']);
callback(null, targetsMapping, ruleFreshness);
Expand Down Expand Up @@ -117,7 +125,7 @@ var constructStatisticsDocs = function constructStatisticsDocs(rules) {

var assembleRules = function assembleRules(data) {
var newRules = [];
var ruleList = data['SamplingRuleRecords'];
var ruleList = data['SamplingRuleRecords'] || [];
ruleList.forEach(function(ruleRecord) {
ruleRecord = ruleRecord['SamplingRule'];
// For forward compatibility reason right now it only
Expand All @@ -141,7 +149,7 @@ var assembleRules = function assembleRules(data) {
};

var assembleTargets = function assembleTargets(data) {
var docs = data['SamplingTargetDocuments'];
var docs = data['SamplingTargetDocuments'] || [];
var targetsMapping = {};

docs.forEach(function(doc) {
Expand Down
19 changes: 19 additions & 0 deletions packages/core/test/unit/sampling/service_connector.test.js
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@ var assert = require('chai').assert;
var expect = require('chai').expect;
var chai = require('chai');
var sinon = require('sinon');
var rewire = require('rewire');

var DaemonConfig = require('../../../lib/daemon_config');
var ServiceConnector = require('../../../lib/middleware/sampling/service_connector');
Expand Down Expand Up @@ -179,6 +180,24 @@ describe('ServiceConnector', function() {
done();
});
});

it('handles invalid responses from the API gracefully', function() {
var rewiredConnector = rewire('../../../lib/middleware/sampling/service_connector');
var assembleRules = rewiredConnector.__get__('assembleRules');

var res = assembleRules({});
assert.isArray(res);
});
});

describe('fetchSamplingTargets', function() {
it('handles invalid responses from the API gracefully', function() {
var rewiredConnector = rewire('../../../lib/middleware/sampling/service_connector');
var assembleTargets = rewiredConnector.__get__('assembleTargets');

var res = assembleTargets({});
assert.deepEqual(res, {});
});
});

describe('DaemonConfig', function() {
Expand Down

0 comments on commit 6d35667

Please sign in to comment.