|
| 1 | +import { test } from '@agoric/zoe/tools/prepare-test-env-ava.js'; |
| 2 | + |
| 3 | +import { addressTools } from '../../src/utils/address.js'; |
| 4 | + |
| 5 | +const FIXTURES = { |
| 6 | + AGORIC_WITH_DYDX: |
| 7 | + 'agoric1bech32addr?EUD=dydx183dejcnmkka5dzcu9xw6mywq0p2m5peks28men', |
| 8 | + AGORIC_WITH_OSMO: |
| 9 | + 'agoric1bech32addr?EUD=osmo183dejcnmkka5dzcu9xw6mywq0p2m5peks28men', |
| 10 | + AGORIC_WITH_MULTIPLE: |
| 11 | + 'agoric1bech32addr?EUD=osmo183dejcnmkka5dzcu9xw6mywq0p2m5peks28men&CID=dydx-mainnet-1', |
| 12 | + AGORIC_NO_PARAMS: 'agoric1bech32addr', |
| 13 | + INVALID_MULTIPLE_QUESTION: 'agoric1bech32addr?param1=value1?param2=value2', |
| 14 | + INVALID_PARAM_FORMAT: 'agoric1bech32addr?invalidparam', |
| 15 | +} as const; |
| 16 | + |
| 17 | +// hasQueryParams tests |
| 18 | +test('hasQueryParams: returns true when address has parameters', t => { |
| 19 | + t.true(addressTools.hasQueryParams(FIXTURES.AGORIC_WITH_DYDX)); |
| 20 | + t.true(addressTools.hasQueryParams(FIXTURES.AGORIC_WITH_OSMO)); |
| 21 | + t.true(addressTools.hasQueryParams(FIXTURES.AGORIC_WITH_MULTIPLE)); |
| 22 | +}); |
| 23 | + |
| 24 | +test('hasQueryParams: returns false when address has no parameters', t => { |
| 25 | + t.false(addressTools.hasQueryParams(FIXTURES.AGORIC_NO_PARAMS)); |
| 26 | +}); |
| 27 | + |
| 28 | +test('hasQueryParams: returns true for invalid parameter formats (only checks for ?)', t => { |
| 29 | + t.true(addressTools.hasQueryParams(FIXTURES.INVALID_MULTIPLE_QUESTION)); |
| 30 | + t.true(addressTools.hasQueryParams(FIXTURES.INVALID_PARAM_FORMAT)); |
| 31 | +}); |
| 32 | + |
| 33 | +// getQueryParams tests - positive cases |
| 34 | +test('getQueryParams: correctly parses address with single EUD parameter', t => { |
| 35 | + const result = addressTools.getQueryParams(FIXTURES.AGORIC_WITH_DYDX); |
| 36 | + t.deepEqual(result, { |
| 37 | + address: 'agoric1bech32addr', |
| 38 | + params: { |
| 39 | + EUD: 'dydx183dejcnmkka5dzcu9xw6mywq0p2m5peks28men', |
| 40 | + }, |
| 41 | + }); |
| 42 | +}); |
| 43 | + |
| 44 | +test('getQueryParams: correctly parses address with multiple parameters', t => { |
| 45 | + const result = addressTools.getQueryParams(FIXTURES.AGORIC_WITH_MULTIPLE); |
| 46 | + t.deepEqual(result, { |
| 47 | + address: 'agoric1bech32addr', |
| 48 | + params: { |
| 49 | + EUD: 'osmo183dejcnmkka5dzcu9xw6mywq0p2m5peks28men', |
| 50 | + CID: 'dydx-mainnet-1', |
| 51 | + }, |
| 52 | + }); |
| 53 | +}); |
| 54 | + |
| 55 | +test('getQueryParams: correctly handles address with no parameters', t => { |
| 56 | + const result = addressTools.getQueryParams(FIXTURES.AGORIC_NO_PARAMS); |
| 57 | + t.deepEqual(result, { |
| 58 | + address: 'agoric1bech32addr', |
| 59 | + params: {}, |
| 60 | + }); |
| 61 | +}); |
| 62 | + |
| 63 | +// getQueryParams tests - negative cases |
| 64 | +test('getQueryParams: throws error for multiple question marks', t => { |
| 65 | + t.throws( |
| 66 | + () => addressTools.getQueryParams(FIXTURES.INVALID_MULTIPLE_QUESTION), |
| 67 | + { |
| 68 | + message: |
| 69 | + 'Invalid input. Must be of the form \'address?params\': "agoric1bech32addr?param1=value1?param2=value2"', |
| 70 | + }, |
| 71 | + ); |
| 72 | +}); |
| 73 | + |
| 74 | +test('getQueryParams: throws error for invalid parameter format', t => { |
| 75 | + t.throws(() => addressTools.getQueryParams(FIXTURES.INVALID_PARAM_FORMAT), { |
| 76 | + message: 'Invalid parameter format in pair: "invalidparam"', |
| 77 | + }); |
| 78 | +}); |
0 commit comments