From 18c36712219957942ec6fdc98718caa6582461c9 Mon Sep 17 00:00:00 2001 From: DavidWells Date: Tue, 10 Dec 2024 17:59:01 -0800 Subject: [PATCH] fix: #453 param parser --- packages/analytics-utils/package.json | 3 ++ packages/analytics-utils/src/paramsParse.js | 4 +- .../analytics-utils/tests/paramParse.test.js | 47 +++++++++++++------ pnpm-lock.yaml | 22 ++++++--- 4 files changed, 55 insertions(+), 21 deletions(-) diff --git a/packages/analytics-utils/package.json b/packages/analytics-utils/package.json index 4d5bb3b0..da9495a6 100644 --- a/packages/analytics-utils/package.json +++ b/packages/analytics-utils/package.json @@ -26,6 +26,7 @@ "unpkg": "dist/analytics-utils.umd.js", "sideEffects": false, "scripts": { + "test": "uvu tests -r esm", "start": "npm run sync && concurrently 'npm:watch:dev' 'npm:copy' 'npm:serve'", "serve": "servor dist index.html 8081 --reload --browse", "copy": "watchlist examples -- npm run sync", @@ -43,8 +44,10 @@ "devDependencies": { "concurrently": "^6.1.0", "microbundle": "^0.13.0", + "esm": "^3.2.25", "servor": "^4.0.2", "typescript": "^4.2.3", + "uvu": "^0.5.1", "watchlist": "^0.2.3" }, "dependencies": { diff --git a/packages/analytics-utils/src/paramsParse.js b/packages/analytics-utils/src/paramsParse.js index 6198bdaa..e591d524 100644 --- a/packages/analytics-utils/src/paramsParse.js +++ b/packages/analytics-utils/src/paramsParse.js @@ -41,7 +41,9 @@ function getParamsAsObject(query) { var v = decodeUri(temp[2]) if (k.substring(k.length - 2) === '[]') { k = k.substring(0, k.length - 2); - (params[k] || (params[k] = [])).push(v) + var arrVal = params[k] || (params[k] = []) + params[k] = Array.isArray(arrVal) ? arrVal : [] + params[k].push(v) } else { params[k] = (v === '') ? true : v } diff --git a/packages/analytics-utils/tests/paramParse.test.js b/packages/analytics-utils/tests/paramParse.test.js index 8b704c55..7ede340c 100644 --- a/packages/analytics-utils/tests/paramParse.test.js +++ b/packages/analytics-utils/tests/paramParse.test.js @@ -1,28 +1,45 @@ -import test from 'ava' -import {parseParam} from '../dist/paramsParse' +import { test } from 'uvu' +import * as assert from 'uvu/assert' +import { paramsParse } from '../src/paramsParse' -test('test simple params', t => { +function toPlainObject(obj) { + return JSON.parse(JSON.stringify(obj)) +} + +function _paramsParse(url) { + return toPlainObject(paramsParse(url)) +} + +test('test simple params', () => { const url = 'http://localhost:3000/?hi=there&wow=lol' - const parsed = parseParam(url) - t.deepEqual(parsed, { + const parsed = _paramsParse(url) + assert.equal(parsed, { hi: 'there', wow: 'lol', }) }) -test('test boolean params', t => { +test('test boolean params', () => { const url = 'http://localhost:3000/?hi&no=false' - const parsed = parseParam(url) - t.deepEqual(parsed, { + const parsed = _paramsParse(url) + assert.equal(parsed, { hi: true, no: 'false', }) }) -test('test utm params', t => { +test('Duplicate param keys', () => { + const url = 'http://localhost:3000/?foo=&foo[]=' + const parsed = _paramsParse(url) + assert.equal(parsed, { + foo: [''], + }) +}) + +test('test utm params', () => { const url = 'http://localhost:3000/http://glocal.dev/?utm_source=the_source&utm_medium=camp%20med&utm_term=Bought%20keyword&utm_content=Funny%20Text&utm_campaign=400kpromo' - const parsed = parseParam(url) - t.deepEqual(parsed, { + const parsed = _paramsParse(url) + assert.equal(parsed, { utm_campaign: '400kpromo', utm_content: 'Funny Text', utm_medium: 'camp med', @@ -31,12 +48,12 @@ test('test utm params', t => { }) }) -test('test deeply nested url values', t => { +test('test deeply nested url values', () => { const url = 'http://localhost:3000/?Target=Offer&Method=findAll&filters[has_goals_enabled][TRUE]=1&filters[status]=active&filters[otherthing]&filters[wow]arr[]=yaz&filters[wow]arr[]=naz&filters[wow]arr[]=[other]&fields[]=id&fields[]=name&fields[]=default_goal_name&yes' - const parsed = parseParam(url) - t.deepEqual(parsed, { + const parsed = _paramsParse(url) + assert.equal(parsed, { Target: 'Offer', Method: 'findAll', fields: ['id', 'name', 'default_goal_name'], @@ -49,3 +66,5 @@ test('test deeply nested url values', t => { }, }) }) + +test.run() diff --git a/pnpm-lock.yaml b/pnpm-lock.yaml index ce18951e..553cc7d4 100644 --- a/pnpm-lock.yaml +++ b/pnpm-lock.yaml @@ -142,7 +142,7 @@ importers: packages/analytics: dependencies: '@analytics/core': - specifier: ^0.12.9 + specifier: ^0.12.15 version: link:../analytics-core '@analytics/storage-utils': specifier: ^0.4.2 @@ -307,7 +307,7 @@ importers: specifier: ^0.1.2 version: link:../analytics-util-queue '@analytics/session-utils': - specifier: ^0.1.19 + specifier: ^0.2.0 version: link:../analytics-util-session '@analytics/type-utils': specifier: ^0.3.1 @@ -342,7 +342,7 @@ importers: version: 7.15.3(@babel/core@7.15.8) aws-sdk-client-mock: specifier: ^0.5.5 - version: 0.5.5(@aws-sdk/client-s3@3.511.0)(@aws-sdk/types@3.38.0) + version: 0.5.5(@aws-sdk/client-s3@3.511.0)(@aws-sdk/types@3.511.0) c8: specifier: ^7.10.0 version: 7.10.0 @@ -1127,6 +1127,9 @@ importers: concurrently: specifier: ^6.1.0 version: 6.3.0 + esm: + specifier: ^3.2.25 + version: 3.2.25 microbundle: specifier: ^0.13.0 version: 0.13.3(acorn@8.7.0) @@ -1136,6 +1139,9 @@ importers: typescript: specifier: ^4.2.3 version: 4.4.4 + uvu: + specifier: ^0.5.1 + version: 0.5.2 watchlist: specifier: ^0.2.3 version: 0.2.3 @@ -2261,6 +2267,7 @@ packages: /@aws-sdk/types@3.38.0: resolution: {integrity: sha512-Opux3HLwMlWb7GIJxERsOnmbHrT2A1gsd8aF5zHapWPPH5Z0rYsgTIq64qgim896XlKlOw6/YzhD5CdyNjlQWg==} engines: {node: '>= 10.0.0'} + dev: false /@aws-sdk/types@3.511.0: resolution: {integrity: sha512-P03ufufxmkvd7nO46oOeEqYIMPJ8qMCKxAsfJk1JBVPQ1XctVntbail4/UFnrnzij8DTl4Mk/D62uGo7+RolXA==} @@ -5843,6 +5850,7 @@ packages: /@humanwhocodes/config-array@0.11.14: resolution: {integrity: sha512-3T8LkOmg45BV5FICb15QQMsyUSWrQ8AygVfC7ZG32zOalnqrilm018ZVCw0eapXux8FtA33q8PSRSstjee3jSg==} engines: {node: '>=10.10.0'} + deprecated: Use @eslint/config-array instead dependencies: '@humanwhocodes/object-schema': 2.0.2 debug: 4.3.2(supports-color@8.1.1) @@ -5858,6 +5866,7 @@ packages: /@humanwhocodes/object-schema@2.0.2: resolution: {integrity: sha512-6EwiSjwWYP7pTckG6I5eyFANjPhmPjUX9JRLUSfNPC7FX7zK9gyZAfUEaECL6ALTpGX5AjnBq3C9XmVWPitNpw==} + deprecated: Use @eslint/object-schema instead dev: true /@istanbuljs/schema@0.1.3: @@ -8964,14 +8973,14 @@ packages: - supports-color dev: true - /aws-sdk-client-mock@0.5.5(@aws-sdk/client-s3@3.511.0)(@aws-sdk/types@3.38.0): + /aws-sdk-client-mock@0.5.5(@aws-sdk/client-s3@3.511.0)(@aws-sdk/types@3.511.0): resolution: {integrity: sha512-djwyYj4vRAXGGH0nycd04/qxj4lK4UscK12dgRgYLigFzQ8EdM0+eZoFobbjXnXoPBG+YeN57UqrEbE1YW1qag==} peerDependencies: '@aws-sdk/client-s3': ^3.0.0 '@aws-sdk/types': ^3.0.0 dependencies: '@aws-sdk/client-s3': 3.511.0 - '@aws-sdk/types': 3.38.0 + '@aws-sdk/types': 3.511.0 '@types/sinon': 10.0.2 sinon: 11.1.2 tslib: 2.3.1 @@ -11674,6 +11683,7 @@ packages: /eslint@8.56.0: resolution: {integrity: sha512-Go19xM6T9puCOWntie1/P997aXxFsOi37JIHRWI514Hc6ZnaHGKY9xFhrU65RT6CcBEzZoGG1e6Nq+DT04ZtZQ==} engines: {node: ^12.22.0 || ^14.17.0 || >=16.0.0} + deprecated: This version is no longer supported. Please see https://eslint.org/version-support for other options. hasBin: true dependencies: '@eslint-community/eslint-utils': 4.4.0(eslint@8.56.0) @@ -12380,7 +12390,7 @@ packages: resolution: {integrity: sha512-oWb1Z6mkHIskLzEJ/XWX0srkpkTQ7vaopMQkyaEIoq0fmtFVxOthb8cCxeT+p3ynTdkk/RZwbgG4brR5BeWECw==} engines: {node: '>= 4.0'} os: [darwin] - deprecated: The v1 package contains DANGEROUS / INSECURE binaries. Upgrade to safe fsevents v2 + deprecated: Upgrade to fsevents v2 to mitigate potential security issues requiresBuild: true dependencies: bindings: 1.5.0