From 974985a35fb3ca84e7885d5b8f026da12715b1cd Mon Sep 17 00:00:00 2001 From: Szymon Lesisz Date: Thu, 18 Mar 2021 13:01:18 +0100 Subject: [PATCH 1/2] test: add methods params unit tests --- jest.config.unit.js | 8 +- src/js/core/methods/__fixtures__/params.js | 90 ++++++++++++++++++++ src/js/core/methods/__tests__/params.test.js | 30 +++++++ 3 files changed, 127 insertions(+), 1 deletion(-) create mode 100644 src/js/core/methods/__fixtures__/params.js create mode 100644 src/js/core/methods/__tests__/params.test.js diff --git a/jest.config.unit.js b/jest.config.unit.js index 2c94f4b1b..c3f994e02 100644 --- a/jest.config.unit.js +++ b/jest.config.unit.js @@ -5,10 +5,16 @@ module.exports = { rootDir: './', moduleFileExtensions: ['js'], - testMatch: ['**/src/js/**/*.test.(js)'], + testMatch: ['**/src/js/**/*.test.js'], testPathIgnorePatterns: ['/node_modules/', '/src/js/device/_old/'], coverageDirectory: './coverage/', collectCoverage: true, + collectCoverageFrom: [ + '/src/js/**', + '!**/constants/**', + '!**/__tests__/**', + '!**/__fixtures__/**', + ], modulePathIgnorePatterns: ['node_modules'], setupFiles: ['./tests/jest.setup.js'], transform: { diff --git a/src/js/core/methods/__fixtures__/params.js b/src/js/core/methods/__fixtures__/params.js new file mode 100644 index 000000000..e9ff00740 --- /dev/null +++ b/src/js/core/methods/__fixtures__/params.js @@ -0,0 +1,90 @@ +export const fixtures = { + applySettings: [ + { + description: 'success', + params: { language: 'en' }, + typedCall: () => ({ + message: 'Success', + }), + response: 'Success', + }, + ], + applyFlags: [ + { + description: 'missing flags param', + params: { foo: 1 }, + error: 'Parameter "flags" is missing.', + }, + { + description: 'flags param invalid type', + params: { flags: '1' }, + error: 'Parameter "flags" has invalid type. "number" expected.', + }, + { + description: 'success', + params: { flags: 1 }, + }, + ], + backupDevice: [], + binanceGetAddress: [], + binanceGetPublicKey: [], + binanceSignTransaction: [], + blockchainDisconnect: [], + blockchainEstimateFee: [], + blockchainGetAccountBalanceHistory: [], + blockchainGetCurrentFiatRates: [], + blockchainGetFiatRatesForTimestamps: [], + blockchainGetTransactions: [], + blockchainSetCustomBackend: [], + blockchainSubscribe: [], + blockchainSubscribeFiatRates: [], + blockchainUnsubscribe: [], + blockchainUnsubscribeFiatRates: [], + cardanoGetAddress: [], + cardanoGetPublicKey: [], + cardanoSignTransaction: [], + changePin: [], + cipherKeyValue: [], + composeTransaction: [], + customMessage: [], + debugLinkDecision: [], + debugLinkGetState: [], + eosGetPublicKey: [], + eosSignTransaction: [], + ethereumGetAddress: [], + ethereumGetPublicKey: [], + ethereumSignMessage: [], + ethereumSignTransaction: [], + ethereumVerifyMessage: [], + firmwareUpdate: [], + getAccountInfo: [], + getAddress: [], + getCoinInfo: [], + getDeviceState: [], + getFeatures: [], + getPublicKey: [], + getSettings: [], + liskGetAddress: [], + liskGetPublicKey: [], + liskSignMessage: [], + liskSignTransaction: [], + liskVerifyMessage: [], + loadDevice: [], + nemGetAddress: [], + nemSignTransaction: [], + pushTransaction: [], + recoveryDevice: [], + requestLogin: [], + resetDevice: [], + rippleGetAddress: [], + rippleSignTransaction: [], + signMessage: [], + signTransaction: [], + stellarGetAddress: [], + stellarSignTransaction: [], + tezosGetAddress: [], + tezosGetPublicKey: [], + tezosSignTransaction: [], + verifyMessage: [], + wipeDevice: [], +}; diff --git a/src/js/core/methods/__tests__/params.test.js b/src/js/core/methods/__tests__/params.test.js new file mode 100644 index 000000000..bb015f75e --- /dev/null +++ b/src/js/core/methods/__tests__/params.test.js @@ -0,0 +1,30 @@ +import { find } from '../index'; +import { fixtures } from '../__fixtures__/params'; +import coinsJSON from '../../../../data/coins.json'; +import { parseCoinsJson } from '../../../data/CoinInfo'; + +describe('core/methods params validation', () => { + beforeAll(() => { + parseCoinsJson(coinsJSON); + }); + Object.keys(fixtures).forEach(key => { + fixtures[key].forEach(f => { + it(`${key}: ${f.description}`, () => { + try { + const method = find({ + id: 0, + payload: { + method: key, + ...f.params, + }, + }); + method.device = { + unavailableCapabilities: {}, + }; + } catch (error) { + expect(error.message).toBe(f.error); + } + }); + }); + }); +}); From 28467ab016c4f39609135200018958f8fc665540 Mon Sep 17 00:00:00 2001 From: Szymon Lesisz Date: Thu, 18 Mar 2021 13:46:31 +0100 Subject: [PATCH 2/2] fixup! test: add methods params unit tests --- src/js/core/methods/__fixtures__/params.js | 9 +++++---- 1 file changed, 5 insertions(+), 4 deletions(-) diff --git a/src/js/core/methods/__fixtures__/params.js b/src/js/core/methods/__fixtures__/params.js index e9ff00740..2e336907a 100644 --- a/src/js/core/methods/__fixtures__/params.js +++ b/src/js/core/methods/__fixtures__/params.js @@ -1,12 +1,13 @@ export const fixtures = { applySettings: [ + { + description: 'language param invalid type', + params: { language: 1 }, + error: 'Parameter "language" has invalid type. "string" expected.', + }, { description: 'success', params: { language: 'en' }, - typedCall: () => ({ - message: 'Success', - }), - response: 'Success', }, ], applyFlags: [