Skip to content

Commit

Permalink
Merge pull request #595 from blockchain-certificates/fix/explorer-api…
Browse files Browse the repository at this point in the history
…-overwrite

fix(ExplorerAPIs): [#548] throw error early when overwriting explorer is malformed
  • Loading branch information
Julien Fraichot authored Jun 2, 2020
2 parents f38df54 + 9914519 commit 308009f
Show file tree
Hide file tree
Showing 2 changed files with 30 additions and 5 deletions.
20 changes: 15 additions & 5 deletions src/explorers/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -17,6 +17,14 @@ export interface TDefaultExplorersPerBlockchain {
function cleanupExplorerAPIs (explorerAPIs: ExplorerAPI[], indexes: number[]): void {
indexes.forEach(index => explorerAPIs.splice(index, 1)); // remove modified explorer to avoid setting them in the custom option later
}

function validateOverwritingExplorer (explorerAPI: ExplorerAPI): boolean {
if (explorerAPI.key && !explorerAPI.keyPropertyName) {
throw new Error(`Property keyPropertyName is not set for ${explorerAPI.serviceName}. Cannot pass the key property to the service.`);
}
return true;
}

const overwrittenIndexes: number[] = [];

export function overwriteDefaultExplorers (explorerAPIs: ExplorerAPI[] = [], defaultExplorers: ExplorerAPI[] = [], lastSetOfExplorers = false): ExplorerAPI[] {
Expand All @@ -30,11 +38,13 @@ export function overwriteDefaultExplorers (explorerAPIs: ExplorerAPI[] = [], def
if (userSetExplorerAPIsName.includes(defaultExplorerAPI.serviceName)) {
const immutableExplorerAPI = Object.assign({}, defaultExplorerAPI);
const customSetExplorerAPI = explorerAPIs.find(customExplorerAPI => customExplorerAPI.serviceName === defaultExplorerAPI.serviceName);
const overwrittenExplorerAPI = Object.assign(immutableExplorerAPI, customSetExplorerAPI);
overwrittenExplorers.push(overwrittenExplorerAPI);
const explorerAPIsIndex = explorerAPIs.findIndex(explorerAPI => explorerAPI.serviceName === overwrittenExplorerAPI.serviceName);
if (!overwrittenIndexes.includes(explorerAPIsIndex)) {
overwrittenIndexes.push(explorerAPIsIndex);
if (validateOverwritingExplorer(customSetExplorerAPI)) {
const overwrittenExplorerAPI = Object.assign(immutableExplorerAPI, customSetExplorerAPI);
overwrittenExplorers.push(overwrittenExplorerAPI);
const explorerAPIsIndex = explorerAPIs.findIndex(explorerAPI => explorerAPI.serviceName === overwrittenExplorerAPI.serviceName);
if (!overwrittenIndexes.includes(explorerAPIsIndex)) {
overwrittenIndexes.push(explorerAPIsIndex);
}
}
} else {
overwrittenExplorers.push(defaultExplorerAPI);
Expand Down
15 changes: 15 additions & 0 deletions test/application/explorers/explorer.test.ts
Original file line number Diff line number Diff line change
Expand Up @@ -83,6 +83,21 @@ describe('Blockchain Explorers test suite', function () {
const expectedOutput = [Object.assign(mockDefaultExplorer, fixtureExplorer), BlockcypherAPI];
expect(output).toEqual(expectedOutput);
});

describe('and the explorer overwrite is malformed', function () {
describe('when a key is set but no keyPropertyName', function () {
it('should throw an error', function () {
const fixtureExplorer: ExplorerAPI = {
serviceName: TRANSACTION_APIS.bitpay,
key: 'a-custom-key'
};

expect(() => {
overwriteDefaultExplorers([fixtureExplorer], [BitpayAPI, BlockcypherAPI]);
}).toThrow('Property keyPropertyName is not set for bitpay. Cannot pass the key property to the service.');
});
});
});
});

describe('given it was passed no default explorer match', function () {
Expand Down

0 comments on commit 308009f

Please sign in to comment.