@7nsane/zift 1.0.9 → 1.2.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (590) hide show
  1. package/bin/zift.js +62 -69
  2. package/package.json +1 -1
  3. package/src/collector.js +34 -5
  4. package/audit-axios/axios-1.13.6.tgz +0 -0
  5. package/zift-user-test/node_modules/.package-lock.json +0 -819
  6. package/zift-user-test/node_modules/accepts/HISTORY.md +0 -250
  7. package/zift-user-test/node_modules/accepts/LICENSE +0 -23
  8. package/zift-user-test/node_modules/accepts/README.md +0 -140
  9. package/zift-user-test/node_modules/accepts/index.js +0 -238
  10. package/zift-user-test/node_modules/accepts/package.json +0 -47
  11. package/zift-user-test/node_modules/body-parser/LICENSE +0 -23
  12. package/zift-user-test/node_modules/body-parser/README.md +0 -494
  13. package/zift-user-test/node_modules/body-parser/index.js +0 -71
  14. package/zift-user-test/node_modules/body-parser/lib/read.js +0 -247
  15. package/zift-user-test/node_modules/body-parser/lib/types/json.js +0 -158
  16. package/zift-user-test/node_modules/body-parser/lib/types/raw.js +0 -42
  17. package/zift-user-test/node_modules/body-parser/lib/types/text.js +0 -36
  18. package/zift-user-test/node_modules/body-parser/lib/types/urlencoded.js +0 -142
  19. package/zift-user-test/node_modules/body-parser/lib/utils.js +0 -98
  20. package/zift-user-test/node_modules/body-parser/package.json +0 -52
  21. package/zift-user-test/node_modules/bytes/History.md +0 -97
  22. package/zift-user-test/node_modules/bytes/LICENSE +0 -23
  23. package/zift-user-test/node_modules/bytes/Readme.md +0 -152
  24. package/zift-user-test/node_modules/bytes/index.js +0 -170
  25. package/zift-user-test/node_modules/bytes/package.json +0 -42
  26. package/zift-user-test/node_modules/call-bind-apply-helpers/.eslintrc +0 -17
  27. package/zift-user-test/node_modules/call-bind-apply-helpers/.github/FUNDING.yml +0 -12
  28. package/zift-user-test/node_modules/call-bind-apply-helpers/.nycrc +0 -9
  29. package/zift-user-test/node_modules/call-bind-apply-helpers/CHANGELOG.md +0 -30
  30. package/zift-user-test/node_modules/call-bind-apply-helpers/LICENSE +0 -21
  31. package/zift-user-test/node_modules/call-bind-apply-helpers/README.md +0 -62
  32. package/zift-user-test/node_modules/call-bind-apply-helpers/actualApply.d.ts +0 -1
  33. package/zift-user-test/node_modules/call-bind-apply-helpers/actualApply.js +0 -10
  34. package/zift-user-test/node_modules/call-bind-apply-helpers/applyBind.d.ts +0 -19
  35. package/zift-user-test/node_modules/call-bind-apply-helpers/applyBind.js +0 -10
  36. package/zift-user-test/node_modules/call-bind-apply-helpers/functionApply.d.ts +0 -1
  37. package/zift-user-test/node_modules/call-bind-apply-helpers/functionApply.js +0 -4
  38. package/zift-user-test/node_modules/call-bind-apply-helpers/functionCall.d.ts +0 -1
  39. package/zift-user-test/node_modules/call-bind-apply-helpers/functionCall.js +0 -4
  40. package/zift-user-test/node_modules/call-bind-apply-helpers/index.d.ts +0 -64
  41. package/zift-user-test/node_modules/call-bind-apply-helpers/index.js +0 -15
  42. package/zift-user-test/node_modules/call-bind-apply-helpers/package.json +0 -85
  43. package/zift-user-test/node_modules/call-bind-apply-helpers/reflectApply.d.ts +0 -3
  44. package/zift-user-test/node_modules/call-bind-apply-helpers/reflectApply.js +0 -4
  45. package/zift-user-test/node_modules/call-bind-apply-helpers/test/index.js +0 -63
  46. package/zift-user-test/node_modules/call-bind-apply-helpers/tsconfig.json +0 -9
  47. package/zift-user-test/node_modules/call-bound/.eslintrc +0 -13
  48. package/zift-user-test/node_modules/call-bound/.github/FUNDING.yml +0 -12
  49. package/zift-user-test/node_modules/call-bound/.nycrc +0 -9
  50. package/zift-user-test/node_modules/call-bound/CHANGELOG.md +0 -42
  51. package/zift-user-test/node_modules/call-bound/LICENSE +0 -21
  52. package/zift-user-test/node_modules/call-bound/README.md +0 -53
  53. package/zift-user-test/node_modules/call-bound/index.d.ts +0 -94
  54. package/zift-user-test/node_modules/call-bound/index.js +0 -19
  55. package/zift-user-test/node_modules/call-bound/package.json +0 -99
  56. package/zift-user-test/node_modules/call-bound/test/index.js +0 -61
  57. package/zift-user-test/node_modules/call-bound/tsconfig.json +0 -10
  58. package/zift-user-test/node_modules/content-disposition/HISTORY.md +0 -72
  59. package/zift-user-test/node_modules/content-disposition/LICENSE +0 -22
  60. package/zift-user-test/node_modules/content-disposition/README.md +0 -142
  61. package/zift-user-test/node_modules/content-disposition/index.js +0 -458
  62. package/zift-user-test/node_modules/content-disposition/package.json +0 -43
  63. package/zift-user-test/node_modules/content-type/HISTORY.md +0 -29
  64. package/zift-user-test/node_modules/content-type/LICENSE +0 -22
  65. package/zift-user-test/node_modules/content-type/README.md +0 -94
  66. package/zift-user-test/node_modules/content-type/index.js +0 -225
  67. package/zift-user-test/node_modules/content-type/package.json +0 -42
  68. package/zift-user-test/node_modules/cookie/LICENSE +0 -24
  69. package/zift-user-test/node_modules/cookie/README.md +0 -317
  70. package/zift-user-test/node_modules/cookie/SECURITY.md +0 -25
  71. package/zift-user-test/node_modules/cookie/index.js +0 -335
  72. package/zift-user-test/node_modules/cookie/package.json +0 -44
  73. package/zift-user-test/node_modules/cookie-signature/History.md +0 -70
  74. package/zift-user-test/node_modules/cookie-signature/LICENSE +0 -22
  75. package/zift-user-test/node_modules/cookie-signature/Readme.md +0 -23
  76. package/zift-user-test/node_modules/cookie-signature/index.js +0 -47
  77. package/zift-user-test/node_modules/cookie-signature/package.json +0 -24
  78. package/zift-user-test/node_modules/debug/LICENSE +0 -20
  79. package/zift-user-test/node_modules/debug/README.md +0 -481
  80. package/zift-user-test/node_modules/debug/package.json +0 -64
  81. package/zift-user-test/node_modules/debug/src/browser.js +0 -272
  82. package/zift-user-test/node_modules/debug/src/common.js +0 -292
  83. package/zift-user-test/node_modules/debug/src/index.js +0 -10
  84. package/zift-user-test/node_modules/debug/src/node.js +0 -263
  85. package/zift-user-test/node_modules/depd/History.md +0 -103
  86. package/zift-user-test/node_modules/depd/LICENSE +0 -22
  87. package/zift-user-test/node_modules/depd/Readme.md +0 -280
  88. package/zift-user-test/node_modules/depd/index.js +0 -538
  89. package/zift-user-test/node_modules/depd/lib/browser/index.js +0 -77
  90. package/zift-user-test/node_modules/depd/package.json +0 -45
  91. package/zift-user-test/node_modules/dunder-proto/.eslintrc +0 -5
  92. package/zift-user-test/node_modules/dunder-proto/.github/FUNDING.yml +0 -12
  93. package/zift-user-test/node_modules/dunder-proto/.nycrc +0 -13
  94. package/zift-user-test/node_modules/dunder-proto/CHANGELOG.md +0 -24
  95. package/zift-user-test/node_modules/dunder-proto/LICENSE +0 -21
  96. package/zift-user-test/node_modules/dunder-proto/README.md +0 -54
  97. package/zift-user-test/node_modules/dunder-proto/get.d.ts +0 -5
  98. package/zift-user-test/node_modules/dunder-proto/get.js +0 -30
  99. package/zift-user-test/node_modules/dunder-proto/package.json +0 -76
  100. package/zift-user-test/node_modules/dunder-proto/set.d.ts +0 -5
  101. package/zift-user-test/node_modules/dunder-proto/set.js +0 -35
  102. package/zift-user-test/node_modules/dunder-proto/test/get.js +0 -34
  103. package/zift-user-test/node_modules/dunder-proto/test/index.js +0 -4
  104. package/zift-user-test/node_modules/dunder-proto/test/set.js +0 -50
  105. package/zift-user-test/node_modules/dunder-proto/tsconfig.json +0 -9
  106. package/zift-user-test/node_modules/ee-first/LICENSE +0 -22
  107. package/zift-user-test/node_modules/ee-first/README.md +0 -80
  108. package/zift-user-test/node_modules/ee-first/index.js +0 -95
  109. package/zift-user-test/node_modules/ee-first/package.json +0 -29
  110. package/zift-user-test/node_modules/encodeurl/LICENSE +0 -22
  111. package/zift-user-test/node_modules/encodeurl/README.md +0 -109
  112. package/zift-user-test/node_modules/encodeurl/index.js +0 -60
  113. package/zift-user-test/node_modules/encodeurl/package.json +0 -40
  114. package/zift-user-test/node_modules/es-define-property/.eslintrc +0 -13
  115. package/zift-user-test/node_modules/es-define-property/.github/FUNDING.yml +0 -12
  116. package/zift-user-test/node_modules/es-define-property/.nycrc +0 -9
  117. package/zift-user-test/node_modules/es-define-property/CHANGELOG.md +0 -29
  118. package/zift-user-test/node_modules/es-define-property/LICENSE +0 -21
  119. package/zift-user-test/node_modules/es-define-property/README.md +0 -49
  120. package/zift-user-test/node_modules/es-define-property/index.d.ts +0 -3
  121. package/zift-user-test/node_modules/es-define-property/index.js +0 -14
  122. package/zift-user-test/node_modules/es-define-property/package.json +0 -81
  123. package/zift-user-test/node_modules/es-define-property/test/index.js +0 -56
  124. package/zift-user-test/node_modules/es-define-property/tsconfig.json +0 -10
  125. package/zift-user-test/node_modules/es-errors/.eslintrc +0 -5
  126. package/zift-user-test/node_modules/es-errors/.github/FUNDING.yml +0 -12
  127. package/zift-user-test/node_modules/es-errors/CHANGELOG.md +0 -40
  128. package/zift-user-test/node_modules/es-errors/LICENSE +0 -21
  129. package/zift-user-test/node_modules/es-errors/README.md +0 -55
  130. package/zift-user-test/node_modules/es-errors/eval.d.ts +0 -3
  131. package/zift-user-test/node_modules/es-errors/eval.js +0 -4
  132. package/zift-user-test/node_modules/es-errors/index.d.ts +0 -3
  133. package/zift-user-test/node_modules/es-errors/index.js +0 -4
  134. package/zift-user-test/node_modules/es-errors/package.json +0 -80
  135. package/zift-user-test/node_modules/es-errors/range.d.ts +0 -3
  136. package/zift-user-test/node_modules/es-errors/range.js +0 -4
  137. package/zift-user-test/node_modules/es-errors/ref.d.ts +0 -3
  138. package/zift-user-test/node_modules/es-errors/ref.js +0 -4
  139. package/zift-user-test/node_modules/es-errors/syntax.d.ts +0 -3
  140. package/zift-user-test/node_modules/es-errors/syntax.js +0 -4
  141. package/zift-user-test/node_modules/es-errors/test/index.js +0 -19
  142. package/zift-user-test/node_modules/es-errors/tsconfig.json +0 -49
  143. package/zift-user-test/node_modules/es-errors/type.d.ts +0 -3
  144. package/zift-user-test/node_modules/es-errors/type.js +0 -4
  145. package/zift-user-test/node_modules/es-errors/uri.d.ts +0 -3
  146. package/zift-user-test/node_modules/es-errors/uri.js +0 -4
  147. package/zift-user-test/node_modules/es-object-atoms/.eslintrc +0 -16
  148. package/zift-user-test/node_modules/es-object-atoms/.github/FUNDING.yml +0 -12
  149. package/zift-user-test/node_modules/es-object-atoms/CHANGELOG.md +0 -37
  150. package/zift-user-test/node_modules/es-object-atoms/LICENSE +0 -21
  151. package/zift-user-test/node_modules/es-object-atoms/README.md +0 -63
  152. package/zift-user-test/node_modules/es-object-atoms/RequireObjectCoercible.d.ts +0 -3
  153. package/zift-user-test/node_modules/es-object-atoms/RequireObjectCoercible.js +0 -11
  154. package/zift-user-test/node_modules/es-object-atoms/ToObject.d.ts +0 -7
  155. package/zift-user-test/node_modules/es-object-atoms/ToObject.js +0 -10
  156. package/zift-user-test/node_modules/es-object-atoms/index.d.ts +0 -3
  157. package/zift-user-test/node_modules/es-object-atoms/index.js +0 -4
  158. package/zift-user-test/node_modules/es-object-atoms/isObject.d.ts +0 -3
  159. package/zift-user-test/node_modules/es-object-atoms/isObject.js +0 -6
  160. package/zift-user-test/node_modules/es-object-atoms/package.json +0 -80
  161. package/zift-user-test/node_modules/es-object-atoms/test/index.js +0 -38
  162. package/zift-user-test/node_modules/es-object-atoms/tsconfig.json +0 -6
  163. package/zift-user-test/node_modules/escape-html/LICENSE +0 -24
  164. package/zift-user-test/node_modules/escape-html/Readme.md +0 -43
  165. package/zift-user-test/node_modules/escape-html/index.js +0 -78
  166. package/zift-user-test/node_modules/escape-html/package.json +0 -24
  167. package/zift-user-test/node_modules/etag/HISTORY.md +0 -83
  168. package/zift-user-test/node_modules/etag/LICENSE +0 -22
  169. package/zift-user-test/node_modules/etag/README.md +0 -159
  170. package/zift-user-test/node_modules/etag/index.js +0 -131
  171. package/zift-user-test/node_modules/etag/package.json +0 -47
  172. package/zift-user-test/node_modules/express/LICENSE +0 -24
  173. package/zift-user-test/node_modules/express/Readme.md +0 -276
  174. package/zift-user-test/node_modules/express/index.js +0 -11
  175. package/zift-user-test/node_modules/express/lib/application.js +0 -631
  176. package/zift-user-test/node_modules/express/lib/express.js +0 -81
  177. package/zift-user-test/node_modules/express/lib/request.js +0 -514
  178. package/zift-user-test/node_modules/express/lib/response.js +0 -1053
  179. package/zift-user-test/node_modules/express/lib/utils.js +0 -271
  180. package/zift-user-test/node_modules/express/lib/view.js +0 -205
  181. package/zift-user-test/node_modules/express/package.json +0 -99
  182. package/zift-user-test/node_modules/finalhandler/HISTORY.md +0 -239
  183. package/zift-user-test/node_modules/finalhandler/LICENSE +0 -22
  184. package/zift-user-test/node_modules/finalhandler/README.md +0 -150
  185. package/zift-user-test/node_modules/finalhandler/index.js +0 -293
  186. package/zift-user-test/node_modules/finalhandler/package.json +0 -47
  187. package/zift-user-test/node_modules/forwarded/HISTORY.md +0 -21
  188. package/zift-user-test/node_modules/forwarded/LICENSE +0 -22
  189. package/zift-user-test/node_modules/forwarded/README.md +0 -57
  190. package/zift-user-test/node_modules/forwarded/index.js +0 -90
  191. package/zift-user-test/node_modules/forwarded/package.json +0 -45
  192. package/zift-user-test/node_modules/fresh/HISTORY.md +0 -80
  193. package/zift-user-test/node_modules/fresh/LICENSE +0 -23
  194. package/zift-user-test/node_modules/fresh/README.md +0 -117
  195. package/zift-user-test/node_modules/fresh/index.js +0 -136
  196. package/zift-user-test/node_modules/fresh/package.json +0 -46
  197. package/zift-user-test/node_modules/function-bind/.eslintrc +0 -21
  198. package/zift-user-test/node_modules/function-bind/.github/FUNDING.yml +0 -12
  199. package/zift-user-test/node_modules/function-bind/.github/SECURITY.md +0 -3
  200. package/zift-user-test/node_modules/function-bind/.nycrc +0 -13
  201. package/zift-user-test/node_modules/function-bind/CHANGELOG.md +0 -136
  202. package/zift-user-test/node_modules/function-bind/LICENSE +0 -20
  203. package/zift-user-test/node_modules/function-bind/README.md +0 -46
  204. package/zift-user-test/node_modules/function-bind/implementation.js +0 -84
  205. package/zift-user-test/node_modules/function-bind/index.js +0 -5
  206. package/zift-user-test/node_modules/function-bind/package.json +0 -87
  207. package/zift-user-test/node_modules/function-bind/test/.eslintrc +0 -9
  208. package/zift-user-test/node_modules/function-bind/test/index.js +0 -252
  209. package/zift-user-test/node_modules/get-intrinsic/.eslintrc +0 -42
  210. package/zift-user-test/node_modules/get-intrinsic/.github/FUNDING.yml +0 -12
  211. package/zift-user-test/node_modules/get-intrinsic/.nycrc +0 -9
  212. package/zift-user-test/node_modules/get-intrinsic/CHANGELOG.md +0 -186
  213. package/zift-user-test/node_modules/get-intrinsic/LICENSE +0 -21
  214. package/zift-user-test/node_modules/get-intrinsic/README.md +0 -71
  215. package/zift-user-test/node_modules/get-intrinsic/index.js +0 -378
  216. package/zift-user-test/node_modules/get-intrinsic/package.json +0 -97
  217. package/zift-user-test/node_modules/get-intrinsic/test/GetIntrinsic.js +0 -274
  218. package/zift-user-test/node_modules/get-proto/.eslintrc +0 -10
  219. package/zift-user-test/node_modules/get-proto/.github/FUNDING.yml +0 -12
  220. package/zift-user-test/node_modules/get-proto/.nycrc +0 -9
  221. package/zift-user-test/node_modules/get-proto/CHANGELOG.md +0 -21
  222. package/zift-user-test/node_modules/get-proto/LICENSE +0 -21
  223. package/zift-user-test/node_modules/get-proto/Object.getPrototypeOf.d.ts +0 -5
  224. package/zift-user-test/node_modules/get-proto/Object.getPrototypeOf.js +0 -6
  225. package/zift-user-test/node_modules/get-proto/README.md +0 -50
  226. package/zift-user-test/node_modules/get-proto/Reflect.getPrototypeOf.d.ts +0 -3
  227. package/zift-user-test/node_modules/get-proto/Reflect.getPrototypeOf.js +0 -4
  228. package/zift-user-test/node_modules/get-proto/index.d.ts +0 -5
  229. package/zift-user-test/node_modules/get-proto/index.js +0 -27
  230. package/zift-user-test/node_modules/get-proto/package.json +0 -81
  231. package/zift-user-test/node_modules/get-proto/test/index.js +0 -68
  232. package/zift-user-test/node_modules/get-proto/tsconfig.json +0 -9
  233. package/zift-user-test/node_modules/gopd/.eslintrc +0 -16
  234. package/zift-user-test/node_modules/gopd/.github/FUNDING.yml +0 -12
  235. package/zift-user-test/node_modules/gopd/CHANGELOG.md +0 -45
  236. package/zift-user-test/node_modules/gopd/LICENSE +0 -21
  237. package/zift-user-test/node_modules/gopd/README.md +0 -40
  238. package/zift-user-test/node_modules/gopd/gOPD.d.ts +0 -1
  239. package/zift-user-test/node_modules/gopd/gOPD.js +0 -4
  240. package/zift-user-test/node_modules/gopd/index.d.ts +0 -5
  241. package/zift-user-test/node_modules/gopd/index.js +0 -15
  242. package/zift-user-test/node_modules/gopd/package.json +0 -77
  243. package/zift-user-test/node_modules/gopd/test/index.js +0 -36
  244. package/zift-user-test/node_modules/gopd/tsconfig.json +0 -9
  245. package/zift-user-test/node_modules/has-symbols/.eslintrc +0 -11
  246. package/zift-user-test/node_modules/has-symbols/.github/FUNDING.yml +0 -12
  247. package/zift-user-test/node_modules/has-symbols/.nycrc +0 -9
  248. package/zift-user-test/node_modules/has-symbols/CHANGELOG.md +0 -91
  249. package/zift-user-test/node_modules/has-symbols/LICENSE +0 -21
  250. package/zift-user-test/node_modules/has-symbols/README.md +0 -46
  251. package/zift-user-test/node_modules/has-symbols/index.d.ts +0 -3
  252. package/zift-user-test/node_modules/has-symbols/index.js +0 -14
  253. package/zift-user-test/node_modules/has-symbols/package.json +0 -111
  254. package/zift-user-test/node_modules/has-symbols/shams.d.ts +0 -3
  255. package/zift-user-test/node_modules/has-symbols/shams.js +0 -45
  256. package/zift-user-test/node_modules/has-symbols/test/index.js +0 -22
  257. package/zift-user-test/node_modules/has-symbols/test/shams/core-js.js +0 -29
  258. package/zift-user-test/node_modules/has-symbols/test/shams/get-own-property-symbols.js +0 -29
  259. package/zift-user-test/node_modules/has-symbols/test/tests.js +0 -58
  260. package/zift-user-test/node_modules/has-symbols/tsconfig.json +0 -10
  261. package/zift-user-test/node_modules/hasown/.eslintrc +0 -5
  262. package/zift-user-test/node_modules/hasown/.github/FUNDING.yml +0 -12
  263. package/zift-user-test/node_modules/hasown/.nycrc +0 -13
  264. package/zift-user-test/node_modules/hasown/CHANGELOG.md +0 -40
  265. package/zift-user-test/node_modules/hasown/LICENSE +0 -21
  266. package/zift-user-test/node_modules/hasown/README.md +0 -40
  267. package/zift-user-test/node_modules/hasown/index.d.ts +0 -3
  268. package/zift-user-test/node_modules/hasown/index.js +0 -8
  269. package/zift-user-test/node_modules/hasown/package.json +0 -92
  270. package/zift-user-test/node_modules/hasown/tsconfig.json +0 -6
  271. package/zift-user-test/node_modules/http-errors/HISTORY.md +0 -186
  272. package/zift-user-test/node_modules/http-errors/LICENSE +0 -23
  273. package/zift-user-test/node_modules/http-errors/README.md +0 -169
  274. package/zift-user-test/node_modules/http-errors/index.js +0 -290
  275. package/zift-user-test/node_modules/http-errors/package.json +0 -54
  276. package/zift-user-test/node_modules/iconv-lite/LICENSE +0 -21
  277. package/zift-user-test/node_modules/iconv-lite/README.md +0 -138
  278. package/zift-user-test/node_modules/iconv-lite/encodings/dbcs-codec.js +0 -532
  279. package/zift-user-test/node_modules/iconv-lite/encodings/dbcs-data.js +0 -185
  280. package/zift-user-test/node_modules/iconv-lite/encodings/index.js +0 -23
  281. package/zift-user-test/node_modules/iconv-lite/encodings/internal.js +0 -218
  282. package/zift-user-test/node_modules/iconv-lite/encodings/sbcs-codec.js +0 -75
  283. package/zift-user-test/node_modules/iconv-lite/encodings/sbcs-data-generated.js +0 -451
  284. package/zift-user-test/node_modules/iconv-lite/encodings/sbcs-data.js +0 -178
  285. package/zift-user-test/node_modules/iconv-lite/encodings/tables/big5-added.json +0 -122
  286. package/zift-user-test/node_modules/iconv-lite/encodings/tables/cp936.json +0 -264
  287. package/zift-user-test/node_modules/iconv-lite/encodings/tables/cp949.json +0 -273
  288. package/zift-user-test/node_modules/iconv-lite/encodings/tables/cp950.json +0 -177
  289. package/zift-user-test/node_modules/iconv-lite/encodings/tables/eucjp.json +0 -182
  290. package/zift-user-test/node_modules/iconv-lite/encodings/tables/gb18030-ranges.json +0 -1
  291. package/zift-user-test/node_modules/iconv-lite/encodings/tables/gbk-added.json +0 -56
  292. package/zift-user-test/node_modules/iconv-lite/encodings/tables/shiftjis.json +0 -125
  293. package/zift-user-test/node_modules/iconv-lite/encodings/utf16.js +0 -187
  294. package/zift-user-test/node_modules/iconv-lite/encodings/utf32.js +0 -307
  295. package/zift-user-test/node_modules/iconv-lite/encodings/utf7.js +0 -283
  296. package/zift-user-test/node_modules/iconv-lite/lib/bom-handling.js +0 -48
  297. package/zift-user-test/node_modules/iconv-lite/lib/helpers/merge-exports.js +0 -13
  298. package/zift-user-test/node_modules/iconv-lite/lib/index.d.ts +0 -129
  299. package/zift-user-test/node_modules/iconv-lite/lib/index.js +0 -182
  300. package/zift-user-test/node_modules/iconv-lite/lib/streams.js +0 -105
  301. package/zift-user-test/node_modules/iconv-lite/package.json +0 -70
  302. package/zift-user-test/node_modules/iconv-lite/types/encodings.d.ts +0 -423
  303. package/zift-user-test/node_modules/inherits/LICENSE +0 -16
  304. package/zift-user-test/node_modules/inherits/README.md +0 -42
  305. package/zift-user-test/node_modules/inherits/inherits.js +0 -9
  306. package/zift-user-test/node_modules/inherits/inherits_browser.js +0 -27
  307. package/zift-user-test/node_modules/inherits/package.json +0 -29
  308. package/zift-user-test/node_modules/ipaddr.js/LICENSE +0 -19
  309. package/zift-user-test/node_modules/ipaddr.js/README.md +0 -233
  310. package/zift-user-test/node_modules/ipaddr.js/ipaddr.min.js +0 -1
  311. package/zift-user-test/node_modules/ipaddr.js/lib/ipaddr.js +0 -673
  312. package/zift-user-test/node_modules/ipaddr.js/lib/ipaddr.js.d.ts +0 -68
  313. package/zift-user-test/node_modules/ipaddr.js/package.json +0 -35
  314. package/zift-user-test/node_modules/is-promise/LICENSE +0 -19
  315. package/zift-user-test/node_modules/is-promise/index.d.ts +0 -2
  316. package/zift-user-test/node_modules/is-promise/index.js +0 -6
  317. package/zift-user-test/node_modules/is-promise/index.mjs +0 -3
  318. package/zift-user-test/node_modules/is-promise/package.json +0 -30
  319. package/zift-user-test/node_modules/is-promise/readme.md +0 -33
  320. package/zift-user-test/node_modules/math-intrinsics/.eslintrc +0 -16
  321. package/zift-user-test/node_modules/math-intrinsics/.github/FUNDING.yml +0 -12
  322. package/zift-user-test/node_modules/math-intrinsics/CHANGELOG.md +0 -24
  323. package/zift-user-test/node_modules/math-intrinsics/LICENSE +0 -21
  324. package/zift-user-test/node_modules/math-intrinsics/README.md +0 -50
  325. package/zift-user-test/node_modules/math-intrinsics/abs.d.ts +0 -1
  326. package/zift-user-test/node_modules/math-intrinsics/abs.js +0 -4
  327. package/zift-user-test/node_modules/math-intrinsics/constants/maxArrayLength.d.ts +0 -3
  328. package/zift-user-test/node_modules/math-intrinsics/constants/maxArrayLength.js +0 -4
  329. package/zift-user-test/node_modules/math-intrinsics/constants/maxSafeInteger.d.ts +0 -3
  330. package/zift-user-test/node_modules/math-intrinsics/constants/maxSafeInteger.js +0 -5
  331. package/zift-user-test/node_modules/math-intrinsics/constants/maxValue.d.ts +0 -3
  332. package/zift-user-test/node_modules/math-intrinsics/constants/maxValue.js +0 -5
  333. package/zift-user-test/node_modules/math-intrinsics/floor.d.ts +0 -1
  334. package/zift-user-test/node_modules/math-intrinsics/floor.js +0 -4
  335. package/zift-user-test/node_modules/math-intrinsics/isFinite.d.ts +0 -3
  336. package/zift-user-test/node_modules/math-intrinsics/isFinite.js +0 -12
  337. package/zift-user-test/node_modules/math-intrinsics/isInteger.d.ts +0 -3
  338. package/zift-user-test/node_modules/math-intrinsics/isInteger.js +0 -16
  339. package/zift-user-test/node_modules/math-intrinsics/isNaN.d.ts +0 -1
  340. package/zift-user-test/node_modules/math-intrinsics/isNaN.js +0 -6
  341. package/zift-user-test/node_modules/math-intrinsics/isNegativeZero.d.ts +0 -3
  342. package/zift-user-test/node_modules/math-intrinsics/isNegativeZero.js +0 -6
  343. package/zift-user-test/node_modules/math-intrinsics/max.d.ts +0 -1
  344. package/zift-user-test/node_modules/math-intrinsics/max.js +0 -4
  345. package/zift-user-test/node_modules/math-intrinsics/min.d.ts +0 -1
  346. package/zift-user-test/node_modules/math-intrinsics/min.js +0 -4
  347. package/zift-user-test/node_modules/math-intrinsics/mod.d.ts +0 -3
  348. package/zift-user-test/node_modules/math-intrinsics/mod.js +0 -9
  349. package/zift-user-test/node_modules/math-intrinsics/package.json +0 -86
  350. package/zift-user-test/node_modules/math-intrinsics/pow.d.ts +0 -1
  351. package/zift-user-test/node_modules/math-intrinsics/pow.js +0 -4
  352. package/zift-user-test/node_modules/math-intrinsics/round.d.ts +0 -1
  353. package/zift-user-test/node_modules/math-intrinsics/round.js +0 -4
  354. package/zift-user-test/node_modules/math-intrinsics/sign.d.ts +0 -3
  355. package/zift-user-test/node_modules/math-intrinsics/sign.js +0 -11
  356. package/zift-user-test/node_modules/math-intrinsics/test/index.js +0 -192
  357. package/zift-user-test/node_modules/math-intrinsics/tsconfig.json +0 -3
  358. package/zift-user-test/node_modules/media-typer/HISTORY.md +0 -50
  359. package/zift-user-test/node_modules/media-typer/LICENSE +0 -22
  360. package/zift-user-test/node_modules/media-typer/README.md +0 -93
  361. package/zift-user-test/node_modules/media-typer/index.js +0 -143
  362. package/zift-user-test/node_modules/media-typer/package.json +0 -33
  363. package/zift-user-test/node_modules/merge-descriptors/index.d.ts +0 -11
  364. package/zift-user-test/node_modules/merge-descriptors/index.js +0 -26
  365. package/zift-user-test/node_modules/merge-descriptors/license +0 -11
  366. package/zift-user-test/node_modules/merge-descriptors/package.json +0 -50
  367. package/zift-user-test/node_modules/merge-descriptors/readme.md +0 -55
  368. package/zift-user-test/node_modules/mime-db/HISTORY.md +0 -541
  369. package/zift-user-test/node_modules/mime-db/LICENSE +0 -23
  370. package/zift-user-test/node_modules/mime-db/README.md +0 -109
  371. package/zift-user-test/node_modules/mime-db/db.json +0 -9342
  372. package/zift-user-test/node_modules/mime-db/index.js +0 -12
  373. package/zift-user-test/node_modules/mime-db/package.json +0 -56
  374. package/zift-user-test/node_modules/mime-types/HISTORY.md +0 -428
  375. package/zift-user-test/node_modules/mime-types/LICENSE +0 -23
  376. package/zift-user-test/node_modules/mime-types/README.md +0 -126
  377. package/zift-user-test/node_modules/mime-types/index.js +0 -211
  378. package/zift-user-test/node_modules/mime-types/mimeScore.js +0 -57
  379. package/zift-user-test/node_modules/mime-types/package.json +0 -49
  380. package/zift-user-test/node_modules/ms/index.js +0 -162
  381. package/zift-user-test/node_modules/ms/license.md +0 -21
  382. package/zift-user-test/node_modules/ms/package.json +0 -38
  383. package/zift-user-test/node_modules/ms/readme.md +0 -59
  384. package/zift-user-test/node_modules/negotiator/HISTORY.md +0 -114
  385. package/zift-user-test/node_modules/negotiator/LICENSE +0 -24
  386. package/zift-user-test/node_modules/negotiator/README.md +0 -212
  387. package/zift-user-test/node_modules/negotiator/index.js +0 -83
  388. package/zift-user-test/node_modules/negotiator/lib/charset.js +0 -169
  389. package/zift-user-test/node_modules/negotiator/lib/encoding.js +0 -205
  390. package/zift-user-test/node_modules/negotiator/lib/language.js +0 -179
  391. package/zift-user-test/node_modules/negotiator/lib/mediaType.js +0 -294
  392. package/zift-user-test/node_modules/negotiator/package.json +0 -43
  393. package/zift-user-test/node_modules/object-inspect/.eslintrc +0 -53
  394. package/zift-user-test/node_modules/object-inspect/.github/FUNDING.yml +0 -12
  395. package/zift-user-test/node_modules/object-inspect/.nycrc +0 -13
  396. package/zift-user-test/node_modules/object-inspect/CHANGELOG.md +0 -424
  397. package/zift-user-test/node_modules/object-inspect/LICENSE +0 -21
  398. package/zift-user-test/node_modules/object-inspect/example/all.js +0 -23
  399. package/zift-user-test/node_modules/object-inspect/example/circular.js +0 -6
  400. package/zift-user-test/node_modules/object-inspect/example/fn.js +0 -5
  401. package/zift-user-test/node_modules/object-inspect/example/inspect.js +0 -10
  402. package/zift-user-test/node_modules/object-inspect/index.js +0 -544
  403. package/zift-user-test/node_modules/object-inspect/package-support.json +0 -20
  404. package/zift-user-test/node_modules/object-inspect/package.json +0 -105
  405. package/zift-user-test/node_modules/object-inspect/readme.markdown +0 -84
  406. package/zift-user-test/node_modules/object-inspect/test/bigint.js +0 -58
  407. package/zift-user-test/node_modules/object-inspect/test/browser/dom.js +0 -15
  408. package/zift-user-test/node_modules/object-inspect/test/circular.js +0 -16
  409. package/zift-user-test/node_modules/object-inspect/test/deep.js +0 -12
  410. package/zift-user-test/node_modules/object-inspect/test/element.js +0 -53
  411. package/zift-user-test/node_modules/object-inspect/test/err.js +0 -48
  412. package/zift-user-test/node_modules/object-inspect/test/fakes.js +0 -29
  413. package/zift-user-test/node_modules/object-inspect/test/fn.js +0 -76
  414. package/zift-user-test/node_modules/object-inspect/test/global.js +0 -17
  415. package/zift-user-test/node_modules/object-inspect/test/has.js +0 -15
  416. package/zift-user-test/node_modules/object-inspect/test/holes.js +0 -15
  417. package/zift-user-test/node_modules/object-inspect/test/indent-option.js +0 -271
  418. package/zift-user-test/node_modules/object-inspect/test/inspect.js +0 -139
  419. package/zift-user-test/node_modules/object-inspect/test/lowbyte.js +0 -12
  420. package/zift-user-test/node_modules/object-inspect/test/number.js +0 -58
  421. package/zift-user-test/node_modules/object-inspect/test/quoteStyle.js +0 -26
  422. package/zift-user-test/node_modules/object-inspect/test/toStringTag.js +0 -40
  423. package/zift-user-test/node_modules/object-inspect/test/undef.js +0 -12
  424. package/zift-user-test/node_modules/object-inspect/test/values.js +0 -261
  425. package/zift-user-test/node_modules/object-inspect/test-core-js.js +0 -26
  426. package/zift-user-test/node_modules/object-inspect/util.inspect.js +0 -1
  427. package/zift-user-test/node_modules/on-finished/HISTORY.md +0 -98
  428. package/zift-user-test/node_modules/on-finished/LICENSE +0 -23
  429. package/zift-user-test/node_modules/on-finished/README.md +0 -162
  430. package/zift-user-test/node_modules/on-finished/index.js +0 -234
  431. package/zift-user-test/node_modules/on-finished/package.json +0 -39
  432. package/zift-user-test/node_modules/once/LICENSE +0 -15
  433. package/zift-user-test/node_modules/once/README.md +0 -79
  434. package/zift-user-test/node_modules/once/once.js +0 -42
  435. package/zift-user-test/node_modules/once/package.json +0 -33
  436. package/zift-user-test/node_modules/parseurl/HISTORY.md +0 -58
  437. package/zift-user-test/node_modules/parseurl/LICENSE +0 -24
  438. package/zift-user-test/node_modules/parseurl/README.md +0 -133
  439. package/zift-user-test/node_modules/parseurl/index.js +0 -158
  440. package/zift-user-test/node_modules/parseurl/package.json +0 -40
  441. package/zift-user-test/node_modules/path-to-regexp/LICENSE +0 -21
  442. package/zift-user-test/node_modules/path-to-regexp/Readme.md +0 -224
  443. package/zift-user-test/node_modules/path-to-regexp/dist/index.d.ts +0 -144
  444. package/zift-user-test/node_modules/path-to-regexp/dist/index.js +0 -409
  445. package/zift-user-test/node_modules/path-to-regexp/dist/index.js.map +0 -1
  446. package/zift-user-test/node_modules/path-to-regexp/package.json +0 -64
  447. package/zift-user-test/node_modules/proxy-addr/HISTORY.md +0 -161
  448. package/zift-user-test/node_modules/proxy-addr/LICENSE +0 -22
  449. package/zift-user-test/node_modules/proxy-addr/README.md +0 -139
  450. package/zift-user-test/node_modules/proxy-addr/index.js +0 -327
  451. package/zift-user-test/node_modules/proxy-addr/package.json +0 -47
  452. package/zift-user-test/node_modules/qs/.editorconfig +0 -46
  453. package/zift-user-test/node_modules/qs/.github/FUNDING.yml +0 -12
  454. package/zift-user-test/node_modules/qs/.github/SECURITY.md +0 -11
  455. package/zift-user-test/node_modules/qs/.github/THREAT_MODEL.md +0 -78
  456. package/zift-user-test/node_modules/qs/.nycrc +0 -13
  457. package/zift-user-test/node_modules/qs/CHANGELOG.md +0 -806
  458. package/zift-user-test/node_modules/qs/LICENSE.md +0 -29
  459. package/zift-user-test/node_modules/qs/README.md +0 -758
  460. package/zift-user-test/node_modules/qs/dist/qs.js +0 -141
  461. package/zift-user-test/node_modules/qs/eslint.config.mjs +0 -56
  462. package/zift-user-test/node_modules/qs/lib/formats.js +0 -23
  463. package/zift-user-test/node_modules/qs/lib/index.js +0 -11
  464. package/zift-user-test/node_modules/qs/lib/parse.js +0 -373
  465. package/zift-user-test/node_modules/qs/lib/stringify.js +0 -356
  466. package/zift-user-test/node_modules/qs/lib/utils.js +0 -342
  467. package/zift-user-test/node_modules/qs/package.json +0 -94
  468. package/zift-user-test/node_modules/qs/test/empty-keys-cases.js +0 -267
  469. package/zift-user-test/node_modules/qs/test/parse.js +0 -1568
  470. package/zift-user-test/node_modules/qs/test/stringify.js +0 -1310
  471. package/zift-user-test/node_modules/qs/test/utils.js +0 -404
  472. package/zift-user-test/node_modules/range-parser/HISTORY.md +0 -56
  473. package/zift-user-test/node_modules/range-parser/LICENSE +0 -23
  474. package/zift-user-test/node_modules/range-parser/README.md +0 -84
  475. package/zift-user-test/node_modules/range-parser/index.js +0 -162
  476. package/zift-user-test/node_modules/range-parser/package.json +0 -44
  477. package/zift-user-test/node_modules/raw-body/LICENSE +0 -22
  478. package/zift-user-test/node_modules/raw-body/README.md +0 -223
  479. package/zift-user-test/node_modules/raw-body/index.d.ts +0 -85
  480. package/zift-user-test/node_modules/raw-body/index.js +0 -336
  481. package/zift-user-test/node_modules/raw-body/package.json +0 -46
  482. package/zift-user-test/node_modules/router/HISTORY.md +0 -228
  483. package/zift-user-test/node_modules/router/LICENSE +0 -23
  484. package/zift-user-test/node_modules/router/README.md +0 -416
  485. package/zift-user-test/node_modules/router/index.js +0 -748
  486. package/zift-user-test/node_modules/router/lib/layer.js +0 -247
  487. package/zift-user-test/node_modules/router/lib/route.js +0 -242
  488. package/zift-user-test/node_modules/router/package.json +0 -44
  489. package/zift-user-test/node_modules/safer-buffer/LICENSE +0 -21
  490. package/zift-user-test/node_modules/safer-buffer/Porting-Buffer.md +0 -268
  491. package/zift-user-test/node_modules/safer-buffer/Readme.md +0 -156
  492. package/zift-user-test/node_modules/safer-buffer/dangerous.js +0 -58
  493. package/zift-user-test/node_modules/safer-buffer/package.json +0 -34
  494. package/zift-user-test/node_modules/safer-buffer/safer.js +0 -77
  495. package/zift-user-test/node_modules/safer-buffer/tests.js +0 -406
  496. package/zift-user-test/node_modules/send/LICENSE +0 -23
  497. package/zift-user-test/node_modules/send/README.md +0 -317
  498. package/zift-user-test/node_modules/send/index.js +0 -997
  499. package/zift-user-test/node_modules/send/package.json +0 -63
  500. package/zift-user-test/node_modules/serve-static/LICENSE +0 -25
  501. package/zift-user-test/node_modules/serve-static/README.md +0 -253
  502. package/zift-user-test/node_modules/serve-static/index.js +0 -208
  503. package/zift-user-test/node_modules/serve-static/package.json +0 -44
  504. package/zift-user-test/node_modules/setprototypeof/LICENSE +0 -13
  505. package/zift-user-test/node_modules/setprototypeof/README.md +0 -31
  506. package/zift-user-test/node_modules/setprototypeof/index.d.ts +0 -2
  507. package/zift-user-test/node_modules/setprototypeof/index.js +0 -17
  508. package/zift-user-test/node_modules/setprototypeof/package.json +0 -38
  509. package/zift-user-test/node_modules/setprototypeof/test/index.js +0 -24
  510. package/zift-user-test/node_modules/side-channel/.editorconfig +0 -9
  511. package/zift-user-test/node_modules/side-channel/.eslintrc +0 -12
  512. package/zift-user-test/node_modules/side-channel/.github/FUNDING.yml +0 -12
  513. package/zift-user-test/node_modules/side-channel/.nycrc +0 -13
  514. package/zift-user-test/node_modules/side-channel/CHANGELOG.md +0 -110
  515. package/zift-user-test/node_modules/side-channel/LICENSE +0 -21
  516. package/zift-user-test/node_modules/side-channel/README.md +0 -61
  517. package/zift-user-test/node_modules/side-channel/index.d.ts +0 -14
  518. package/zift-user-test/node_modules/side-channel/index.js +0 -43
  519. package/zift-user-test/node_modules/side-channel/package.json +0 -85
  520. package/zift-user-test/node_modules/side-channel/test/index.js +0 -104
  521. package/zift-user-test/node_modules/side-channel/tsconfig.json +0 -9
  522. package/zift-user-test/node_modules/side-channel-list/.editorconfig +0 -9
  523. package/zift-user-test/node_modules/side-channel-list/.eslintrc +0 -11
  524. package/zift-user-test/node_modules/side-channel-list/.github/FUNDING.yml +0 -12
  525. package/zift-user-test/node_modules/side-channel-list/.nycrc +0 -13
  526. package/zift-user-test/node_modules/side-channel-list/CHANGELOG.md +0 -15
  527. package/zift-user-test/node_modules/side-channel-list/LICENSE +0 -21
  528. package/zift-user-test/node_modules/side-channel-list/README.md +0 -62
  529. package/zift-user-test/node_modules/side-channel-list/index.d.ts +0 -13
  530. package/zift-user-test/node_modules/side-channel-list/index.js +0 -113
  531. package/zift-user-test/node_modules/side-channel-list/list.d.ts +0 -14
  532. package/zift-user-test/node_modules/side-channel-list/package.json +0 -77
  533. package/zift-user-test/node_modules/side-channel-list/test/index.js +0 -104
  534. package/zift-user-test/node_modules/side-channel-list/tsconfig.json +0 -9
  535. package/zift-user-test/node_modules/side-channel-map/.editorconfig +0 -9
  536. package/zift-user-test/node_modules/side-channel-map/.eslintrc +0 -11
  537. package/zift-user-test/node_modules/side-channel-map/.github/FUNDING.yml +0 -12
  538. package/zift-user-test/node_modules/side-channel-map/.nycrc +0 -13
  539. package/zift-user-test/node_modules/side-channel-map/CHANGELOG.md +0 -22
  540. package/zift-user-test/node_modules/side-channel-map/LICENSE +0 -21
  541. package/zift-user-test/node_modules/side-channel-map/README.md +0 -62
  542. package/zift-user-test/node_modules/side-channel-map/index.d.ts +0 -15
  543. package/zift-user-test/node_modules/side-channel-map/index.js +0 -68
  544. package/zift-user-test/node_modules/side-channel-map/package.json +0 -80
  545. package/zift-user-test/node_modules/side-channel-map/test/index.js +0 -114
  546. package/zift-user-test/node_modules/side-channel-map/tsconfig.json +0 -9
  547. package/zift-user-test/node_modules/side-channel-weakmap/.editorconfig +0 -9
  548. package/zift-user-test/node_modules/side-channel-weakmap/.eslintrc +0 -12
  549. package/zift-user-test/node_modules/side-channel-weakmap/.github/FUNDING.yml +0 -12
  550. package/zift-user-test/node_modules/side-channel-weakmap/.nycrc +0 -13
  551. package/zift-user-test/node_modules/side-channel-weakmap/CHANGELOG.md +0 -28
  552. package/zift-user-test/node_modules/side-channel-weakmap/LICENSE +0 -21
  553. package/zift-user-test/node_modules/side-channel-weakmap/README.md +0 -62
  554. package/zift-user-test/node_modules/side-channel-weakmap/index.d.ts +0 -15
  555. package/zift-user-test/node_modules/side-channel-weakmap/index.js +0 -84
  556. package/zift-user-test/node_modules/side-channel-weakmap/package.json +0 -87
  557. package/zift-user-test/node_modules/side-channel-weakmap/test/index.js +0 -114
  558. package/zift-user-test/node_modules/side-channel-weakmap/tsconfig.json +0 -9
  559. package/zift-user-test/node_modules/statuses/HISTORY.md +0 -87
  560. package/zift-user-test/node_modules/statuses/LICENSE +0 -23
  561. package/zift-user-test/node_modules/statuses/README.md +0 -139
  562. package/zift-user-test/node_modules/statuses/codes.json +0 -65
  563. package/zift-user-test/node_modules/statuses/index.js +0 -146
  564. package/zift-user-test/node_modules/statuses/package.json +0 -49
  565. package/zift-user-test/node_modules/toidentifier/HISTORY.md +0 -9
  566. package/zift-user-test/node_modules/toidentifier/LICENSE +0 -21
  567. package/zift-user-test/node_modules/toidentifier/README.md +0 -61
  568. package/zift-user-test/node_modules/toidentifier/index.js +0 -32
  569. package/zift-user-test/node_modules/toidentifier/package.json +0 -38
  570. package/zift-user-test/node_modules/type-is/HISTORY.md +0 -292
  571. package/zift-user-test/node_modules/type-is/LICENSE +0 -23
  572. package/zift-user-test/node_modules/type-is/README.md +0 -198
  573. package/zift-user-test/node_modules/type-is/index.js +0 -250
  574. package/zift-user-test/node_modules/type-is/package.json +0 -47
  575. package/zift-user-test/node_modules/unpipe/HISTORY.md +0 -4
  576. package/zift-user-test/node_modules/unpipe/LICENSE +0 -22
  577. package/zift-user-test/node_modules/unpipe/README.md +0 -43
  578. package/zift-user-test/node_modules/unpipe/index.js +0 -69
  579. package/zift-user-test/node_modules/unpipe/package.json +0 -27
  580. package/zift-user-test/node_modules/vary/HISTORY.md +0 -39
  581. package/zift-user-test/node_modules/vary/LICENSE +0 -22
  582. package/zift-user-test/node_modules/vary/README.md +0 -101
  583. package/zift-user-test/node_modules/vary/index.js +0 -149
  584. package/zift-user-test/node_modules/vary/package.json +0 -43
  585. package/zift-user-test/node_modules/wrappy/LICENSE +0 -15
  586. package/zift-user-test/node_modules/wrappy/README.md +0 -36
  587. package/zift-user-test/node_modules/wrappy/package.json +0 -29
  588. package/zift-user-test/node_modules/wrappy/wrappy.js +0 -33
  589. package/zift-user-test/package-lock.json +0 -827
  590. package/zift-user-test/package.json +0 -16
@@ -1,1568 +0,0 @@
1
- 'use strict';
2
-
3
- var test = require('tape');
4
- var hasPropertyDescriptors = require('has-property-descriptors')();
5
- var iconv = require('iconv-lite');
6
- var mockProperty = require('mock-property');
7
- var hasOverrideMistake = require('has-override-mistake')();
8
- var SaferBuffer = require('safer-buffer').Buffer;
9
- var v = require('es-value-fixtures');
10
- var inspect = require('object-inspect');
11
- var emptyTestCases = require('./empty-keys-cases').emptyTestCases;
12
- var hasProto = require('has-proto')();
13
-
14
- var qs = require('../');
15
- var utils = require('../lib/utils');
16
-
17
- test('parse()', function (t) {
18
- t.test('parses a simple string', function (st) {
19
- st.deepEqual(qs.parse('0=foo'), { 0: 'foo' });
20
- st.deepEqual(qs.parse('foo=c++'), { foo: 'c ' });
21
- st.deepEqual(qs.parse('a[>=]=23'), { a: { '>=': '23' } });
22
- st.deepEqual(qs.parse('a[<=>]==23'), { a: { '<=>': '=23' } });
23
- st.deepEqual(qs.parse('a[==]=23'), { a: { '==': '23' } });
24
- st.deepEqual(qs.parse('foo', { strictNullHandling: true }), { foo: null });
25
- st.deepEqual(qs.parse('foo'), { foo: '' });
26
- st.deepEqual(qs.parse('foo='), { foo: '' });
27
- st.deepEqual(qs.parse('foo=bar'), { foo: 'bar' });
28
- st.deepEqual(qs.parse(' foo = bar = baz '), { ' foo ': ' bar = baz ' });
29
- st.deepEqual(qs.parse('foo=bar=baz'), { foo: 'bar=baz' });
30
- st.deepEqual(qs.parse('foo=bar&bar=baz'), { foo: 'bar', bar: 'baz' });
31
- st.deepEqual(qs.parse('foo2=bar2&baz2='), { foo2: 'bar2', baz2: '' });
32
- st.deepEqual(qs.parse('foo=bar&baz', { strictNullHandling: true }), { foo: 'bar', baz: null });
33
- st.deepEqual(qs.parse('foo=bar&baz'), { foo: 'bar', baz: '' });
34
- st.deepEqual(qs.parse('cht=p3&chd=t:60,40&chs=250x100&chl=Hello|World'), {
35
- cht: 'p3',
36
- chd: 't:60,40',
37
- chs: '250x100',
38
- chl: 'Hello|World'
39
- });
40
- st.end();
41
- });
42
-
43
- t.test('comma: false', function (st) {
44
- st.deepEqual(qs.parse('a[]=b&a[]=c'), { a: ['b', 'c'] });
45
- st.deepEqual(qs.parse('a[0]=b&a[1]=c'), { a: ['b', 'c'] });
46
- st.deepEqual(qs.parse('a=b,c'), { a: 'b,c' });
47
- st.deepEqual(qs.parse('a=b&a=c'), { a: ['b', 'c'] });
48
- st.end();
49
- });
50
-
51
- t.test('comma: true', function (st) {
52
- st.deepEqual(qs.parse('a[]=b&a[]=c', { comma: true }), { a: ['b', 'c'] });
53
- st.deepEqual(qs.parse('a[0]=b&a[1]=c', { comma: true }), { a: ['b', 'c'] });
54
- st.deepEqual(qs.parse('a=b,c', { comma: true }), { a: ['b', 'c'] });
55
- st.deepEqual(qs.parse('a=b&a=c', { comma: true }), { a: ['b', 'c'] });
56
- st.end();
57
- });
58
-
59
- t.test('allows enabling dot notation', function (st) {
60
- st.deepEqual(qs.parse('a.b=c'), { 'a.b': 'c' });
61
- st.deepEqual(qs.parse('a.b=c', { allowDots: true }), { a: { b: 'c' } });
62
-
63
- st.end();
64
- });
65
-
66
- t.test('decode dot keys correctly', function (st) {
67
- st.deepEqual(
68
- qs.parse('name%252Eobj.first=John&name%252Eobj.last=Doe', { allowDots: false, decodeDotInKeys: false }),
69
- { 'name%2Eobj.first': 'John', 'name%2Eobj.last': 'Doe' },
70
- 'with allowDots false and decodeDotInKeys false'
71
- );
72
- st.deepEqual(
73
- qs.parse('name.obj.first=John&name.obj.last=Doe', { allowDots: true, decodeDotInKeys: false }),
74
- { name: { obj: { first: 'John', last: 'Doe' } } },
75
- 'with allowDots false and decodeDotInKeys false'
76
- );
77
- st.deepEqual(
78
- qs.parse('name%252Eobj.first=John&name%252Eobj.last=Doe', { allowDots: true, decodeDotInKeys: false }),
79
- { 'name%2Eobj': { first: 'John', last: 'Doe' } },
80
- 'with allowDots true and decodeDotInKeys false'
81
- );
82
- st.deepEqual(
83
- qs.parse('name%252Eobj.first=John&name%252Eobj.last=Doe', { allowDots: true, decodeDotInKeys: true }),
84
- { 'name.obj': { first: 'John', last: 'Doe' } },
85
- 'with allowDots true and decodeDotInKeys true'
86
- );
87
-
88
- st.deepEqual(
89
- qs.parse(
90
- 'name%252Eobj%252Esubobject.first%252Egodly%252Ename=John&name%252Eobj%252Esubobject.last=Doe',
91
- { allowDots: false, decodeDotInKeys: false }
92
- ),
93
- { 'name%2Eobj%2Esubobject.first%2Egodly%2Ename': 'John', 'name%2Eobj%2Esubobject.last': 'Doe' },
94
- 'with allowDots false and decodeDotInKeys false'
95
- );
96
- st.deepEqual(
97
- qs.parse(
98
- 'name.obj.subobject.first.godly.name=John&name.obj.subobject.last=Doe',
99
- { allowDots: true, decodeDotInKeys: false }
100
- ),
101
- { name: { obj: { subobject: { first: { godly: { name: 'John' } }, last: 'Doe' } } } },
102
- 'with allowDots true and decodeDotInKeys false'
103
- );
104
- st.deepEqual(
105
- qs.parse(
106
- 'name%252Eobj%252Esubobject.first%252Egodly%252Ename=John&name%252Eobj%252Esubobject.last=Doe',
107
- { allowDots: true, decodeDotInKeys: true }
108
- ),
109
- { 'name.obj.subobject': { 'first.godly.name': 'John', last: 'Doe' } },
110
- 'with allowDots true and decodeDotInKeys true'
111
- );
112
- st.deepEqual(
113
- qs.parse('name%252Eobj.first=John&name%252Eobj.last=Doe'),
114
- { 'name%2Eobj.first': 'John', 'name%2Eobj.last': 'Doe' },
115
- 'with allowDots and decodeDotInKeys undefined'
116
- );
117
-
118
- st.end();
119
- });
120
-
121
- t.test('decodes dot in key of object, and allow enabling dot notation when decodeDotInKeys is set to true and allowDots is undefined', function (st) {
122
- st.deepEqual(
123
- qs.parse(
124
- 'name%252Eobj%252Esubobject.first%252Egodly%252Ename=John&name%252Eobj%252Esubobject.last=Doe',
125
- { decodeDotInKeys: true }
126
- ),
127
- { 'name.obj.subobject': { 'first.godly.name': 'John', last: 'Doe' } },
128
- 'with allowDots undefined and decodeDotInKeys true'
129
- );
130
-
131
- st.end();
132
- });
133
-
134
- t.test('throws when decodeDotInKeys is not of type boolean', function (st) {
135
- st['throws'](
136
- function () { qs.parse('foo[]&bar=baz', { decodeDotInKeys: 'foobar' }); },
137
- TypeError
138
- );
139
-
140
- st['throws'](
141
- function () { qs.parse('foo[]&bar=baz', { decodeDotInKeys: 0 }); },
142
- TypeError
143
- );
144
- st['throws'](
145
- function () { qs.parse('foo[]&bar=baz', { decodeDotInKeys: NaN }); },
146
- TypeError
147
- );
148
-
149
- st['throws'](
150
- function () { qs.parse('foo[]&bar=baz', { decodeDotInKeys: null }); },
151
- TypeError
152
- );
153
-
154
- st.end();
155
- });
156
-
157
- t.test('allows empty arrays in obj values', function (st) {
158
- st.deepEqual(qs.parse('foo[]&bar=baz', { allowEmptyArrays: true }), { foo: [], bar: 'baz' });
159
- st.deepEqual(qs.parse('foo[]&bar=baz', { allowEmptyArrays: false }), { foo: [''], bar: 'baz' });
160
-
161
- st.end();
162
- });
163
-
164
- t.test('throws when allowEmptyArrays is not of type boolean', function (st) {
165
- st['throws'](
166
- function () { qs.parse('foo[]&bar=baz', { allowEmptyArrays: 'foobar' }); },
167
- TypeError
168
- );
169
-
170
- st['throws'](
171
- function () { qs.parse('foo[]&bar=baz', { allowEmptyArrays: 0 }); },
172
- TypeError
173
- );
174
- st['throws'](
175
- function () { qs.parse('foo[]&bar=baz', { allowEmptyArrays: NaN }); },
176
- TypeError
177
- );
178
-
179
- st['throws'](
180
- function () { qs.parse('foo[]&bar=baz', { allowEmptyArrays: null }); },
181
- TypeError
182
- );
183
-
184
- st.end();
185
- });
186
-
187
- t.test('allowEmptyArrays + strictNullHandling', function (st) {
188
- st.deepEqual(
189
- qs.parse('testEmptyArray[]', { strictNullHandling: true, allowEmptyArrays: true }),
190
- { testEmptyArray: [] }
191
- );
192
-
193
- st.end();
194
- });
195
-
196
- t.deepEqual(qs.parse('a[b]=c'), { a: { b: 'c' } }, 'parses a single nested string');
197
- t.deepEqual(qs.parse('a[b][c]=d'), { a: { b: { c: 'd' } } }, 'parses a double nested string');
198
- t.deepEqual(
199
- qs.parse('a[b][c][d][e][f][g][h]=i'),
200
- { a: { b: { c: { d: { e: { f: { '[g][h]': 'i' } } } } } } },
201
- 'defaults to a depth of 5'
202
- );
203
-
204
- t.test('only parses one level when depth = 1', function (st) {
205
- st.deepEqual(qs.parse('a[b][c]=d', { depth: 1 }), { a: { b: { '[c]': 'd' } } });
206
- st.deepEqual(qs.parse('a[b][c][d]=e', { depth: 1 }), { a: { b: { '[c][d]': 'e' } } });
207
- st.end();
208
- });
209
-
210
- t.test('uses original key when depth = 0', function (st) {
211
- st.deepEqual(qs.parse('a[0]=b&a[1]=c', { depth: 0 }), { 'a[0]': 'b', 'a[1]': 'c' });
212
- st.deepEqual(qs.parse('a[0][0]=b&a[0][1]=c&a[1]=d&e=2', { depth: 0 }), { 'a[0][0]': 'b', 'a[0][1]': 'c', 'a[1]': 'd', e: '2' });
213
- st.end();
214
- });
215
-
216
- t.test('uses original key when depth = false', function (st) {
217
- st.deepEqual(qs.parse('a[0]=b&a[1]=c', { depth: false }), { 'a[0]': 'b', 'a[1]': 'c' });
218
- st.deepEqual(qs.parse('a[0][0]=b&a[0][1]=c&a[1]=d&e=2', { depth: false }), { 'a[0][0]': 'b', 'a[0][1]': 'c', 'a[1]': 'd', e: '2' });
219
- st.end();
220
- });
221
-
222
- t.deepEqual(qs.parse('a=b&a=c'), { a: ['b', 'c'] }, 'parses a simple array');
223
-
224
- t.test('parses an explicit array', function (st) {
225
- st.deepEqual(qs.parse('a[]=b'), { a: ['b'] });
226
- st.deepEqual(qs.parse('a[]=b&a[]=c'), { a: ['b', 'c'] });
227
- st.deepEqual(qs.parse('a[]=b&a[]=c&a[]=d'), { a: ['b', 'c', 'd'] });
228
- st.end();
229
- });
230
-
231
- t.test('parses a mix of simple and explicit arrays', function (st) {
232
- st.deepEqual(qs.parse('a=b&a[]=c'), { a: ['b', 'c'] });
233
- st.deepEqual(qs.parse('a[]=b&a=c'), { a: ['b', 'c'] });
234
- st.deepEqual(qs.parse('a[0]=b&a=c'), { a: ['b', 'c'] });
235
- st.deepEqual(qs.parse('a=b&a[0]=c'), { a: ['b', 'c'] });
236
-
237
- st.deepEqual(qs.parse('a[1]=b&a=c', { arrayLimit: 20 }), { a: ['b', 'c'] });
238
- st.deepEqual(qs.parse('a[]=b&a=c', { arrayLimit: 0 }), { a: { 0: 'b', 1: 'c' } });
239
- st.deepEqual(qs.parse('a[]=b&a=c'), { a: ['b', 'c'] });
240
-
241
- st.deepEqual(qs.parse('a=b&a[1]=c', { arrayLimit: 20 }), { a: ['b', 'c'] });
242
- st.deepEqual(qs.parse('a=b&a[]=c', { arrayLimit: 0 }), { a: { 0: 'b', 1: 'c' } });
243
- st.deepEqual(qs.parse('a=b&a[]=c'), { a: ['b', 'c'] });
244
-
245
- st.end();
246
- });
247
-
248
- t.test('parses a nested array', function (st) {
249
- st.deepEqual(qs.parse('a[b][]=c&a[b][]=d'), { a: { b: ['c', 'd'] } });
250
- st.deepEqual(qs.parse('a[>=]=25'), { a: { '>=': '25' } });
251
- st.end();
252
- });
253
-
254
- t.test('allows to specify array indices', function (st) {
255
- st.deepEqual(qs.parse('a[1]=c&a[0]=b&a[2]=d'), { a: ['b', 'c', 'd'] });
256
- st.deepEqual(qs.parse('a[1]=c&a[0]=b'), { a: ['b', 'c'] });
257
- st.deepEqual(qs.parse('a[1]=c', { arrayLimit: 20 }), { a: ['c'] });
258
- st.deepEqual(qs.parse('a[1]=c', { arrayLimit: 0 }), { a: { 1: 'c' } });
259
- st.deepEqual(qs.parse('a[1]=c'), { a: ['c'] });
260
- st.end();
261
- });
262
-
263
- t.test('limits specific array indices to arrayLimit', function (st) {
264
- st.deepEqual(qs.parse('a[19]=a', { arrayLimit: 20 }), { a: ['a'] });
265
- st.deepEqual(qs.parse('a[20]=a', { arrayLimit: 20 }), { a: { 20: 'a' } });
266
-
267
- st.deepEqual(qs.parse('a[19]=a'), { a: ['a'] });
268
- st.deepEqual(qs.parse('a[20]=a'), { a: { 20: 'a' } });
269
- st.end();
270
- });
271
-
272
- t.deepEqual(qs.parse('a[12b]=c'), { a: { '12b': 'c' } }, 'supports keys that begin with a number');
273
-
274
- t.test('supports encoded = signs', function (st) {
275
- st.deepEqual(qs.parse('he%3Dllo=th%3Dere'), { 'he=llo': 'th=ere' });
276
- st.end();
277
- });
278
-
279
- t.test('is ok with url encoded strings', function (st) {
280
- st.deepEqual(qs.parse('a[b%20c]=d'), { a: { 'b c': 'd' } });
281
- st.deepEqual(qs.parse('a[b]=c%20d'), { a: { b: 'c d' } });
282
- st.end();
283
- });
284
-
285
- t.test('allows brackets in the value', function (st) {
286
- st.deepEqual(qs.parse('pets=["tobi"]'), { pets: '["tobi"]' });
287
- st.deepEqual(qs.parse('operators=[">=", "<="]'), { operators: '[">=", "<="]' });
288
- st.end();
289
- });
290
-
291
- t.test('allows empty values', function (st) {
292
- st.deepEqual(qs.parse(''), {});
293
- st.deepEqual(qs.parse(null), {});
294
- st.deepEqual(qs.parse(undefined), {});
295
- st.end();
296
- });
297
-
298
- t.test('transforms arrays to objects', function (st) {
299
- st.deepEqual(qs.parse('foo[0]=bar&foo[bad]=baz'), { foo: { 0: 'bar', bad: 'baz' } });
300
- st.deepEqual(qs.parse('foo[bad]=baz&foo[0]=bar'), { foo: { bad: 'baz', 0: 'bar' } });
301
- st.deepEqual(qs.parse('foo[bad]=baz&foo[]=bar'), { foo: { bad: 'baz', 0: 'bar' } });
302
- st.deepEqual(qs.parse('foo[]=bar&foo[bad]=baz'), { foo: { 0: 'bar', bad: 'baz' } });
303
- st.deepEqual(qs.parse('foo[bad]=baz&foo[]=bar&foo[]=foo'), { foo: { bad: 'baz', 0: 'bar', 1: 'foo' } });
304
- st.deepEqual(qs.parse('foo[0][a]=a&foo[0][b]=b&foo[1][a]=aa&foo[1][b]=bb'), { foo: [{ a: 'a', b: 'b' }, { a: 'aa', b: 'bb' }] });
305
-
306
- st.deepEqual(qs.parse('a[]=b&a[t]=u&a[hasOwnProperty]=c', { allowPrototypes: false }), { a: { 0: 'b', t: 'u' } });
307
- st.deepEqual(qs.parse('a[]=b&a[t]=u&a[hasOwnProperty]=c', { allowPrototypes: true }), { a: { 0: 'b', t: 'u', hasOwnProperty: 'c' } });
308
- st.deepEqual(qs.parse('a[]=b&a[hasOwnProperty]=c&a[x]=y', { allowPrototypes: false }), { a: { 0: 'b', x: 'y' } });
309
- st.deepEqual(qs.parse('a[]=b&a[hasOwnProperty]=c&a[x]=y', { allowPrototypes: true }), { a: { 0: 'b', hasOwnProperty: 'c', x: 'y' } });
310
- st.end();
311
- });
312
-
313
- t.test('transforms arrays to objects (dot notation)', function (st) {
314
- st.deepEqual(qs.parse('foo[0].baz=bar&fool.bad=baz', { allowDots: true }), { foo: [{ baz: 'bar' }], fool: { bad: 'baz' } });
315
- st.deepEqual(qs.parse('foo[0].baz=bar&fool.bad.boo=baz', { allowDots: true }), { foo: [{ baz: 'bar' }], fool: { bad: { boo: 'baz' } } });
316
- st.deepEqual(qs.parse('foo[0][0].baz=bar&fool.bad=baz', { allowDots: true }), { foo: [[{ baz: 'bar' }]], fool: { bad: 'baz' } });
317
- st.deepEqual(qs.parse('foo[0].baz[0]=15&foo[0].bar=2', { allowDots: true }), { foo: [{ baz: ['15'], bar: '2' }] });
318
- st.deepEqual(qs.parse('foo[0].baz[0]=15&foo[0].baz[1]=16&foo[0].bar=2', { allowDots: true }), { foo: [{ baz: ['15', '16'], bar: '2' }] });
319
- st.deepEqual(qs.parse('foo.bad=baz&foo[0]=bar', { allowDots: true }), { foo: { bad: 'baz', 0: 'bar' } });
320
- st.deepEqual(qs.parse('foo.bad=baz&foo[]=bar', { allowDots: true }), { foo: { bad: 'baz', 0: 'bar' } });
321
- st.deepEqual(qs.parse('foo[]=bar&foo.bad=baz', { allowDots: true }), { foo: { 0: 'bar', bad: 'baz' } });
322
- st.deepEqual(qs.parse('foo.bad=baz&foo[]=bar&foo[]=foo', { allowDots: true }), { foo: { bad: 'baz', 0: 'bar', 1: 'foo' } });
323
- st.deepEqual(qs.parse('foo[0].a=a&foo[0].b=b&foo[1].a=aa&foo[1].b=bb', { allowDots: true }), { foo: [{ a: 'a', b: 'b' }, { a: 'aa', b: 'bb' }] });
324
- st.end();
325
- });
326
-
327
- t.test('correctly prunes undefined values when converting an array to an object', function (st) {
328
- st.deepEqual(qs.parse('a[2]=b&a[99999999]=c'), { a: { 2: 'b', 99999999: 'c' } });
329
- st.end();
330
- });
331
-
332
- t.test('supports malformed uri characters', function (st) {
333
- st.deepEqual(qs.parse('{%:%}', { strictNullHandling: true }), { '{%:%}': null });
334
- st.deepEqual(qs.parse('{%:%}='), { '{%:%}': '' });
335
- st.deepEqual(qs.parse('foo=%:%}'), { foo: '%:%}' });
336
- st.end();
337
- });
338
-
339
- t.test('doesn\'t produce empty keys', function (st) {
340
- st.deepEqual(qs.parse('_r=1&'), { _r: '1' });
341
- st.end();
342
- });
343
-
344
- t.test('cannot access Object prototype', function (st) {
345
- qs.parse('constructor[prototype][bad]=bad');
346
- qs.parse('bad[constructor][prototype][bad]=bad');
347
- st.equal(typeof Object.prototype.bad, 'undefined');
348
- st.end();
349
- });
350
-
351
- t.test('parses arrays of objects', function (st) {
352
- st.deepEqual(qs.parse('a[][b]=c'), { a: [{ b: 'c' }] });
353
- st.deepEqual(qs.parse('a[0][b]=c'), { a: [{ b: 'c' }] });
354
- st.end();
355
- });
356
-
357
- t.test('allows for empty strings in arrays', function (st) {
358
- st.deepEqual(qs.parse('a[]=b&a[]=&a[]=c'), { a: ['b', '', 'c'] });
359
-
360
- st.deepEqual(
361
- qs.parse('a[0]=b&a[1]&a[2]=c&a[19]=', { strictNullHandling: true, arrayLimit: 20 }),
362
- { a: ['b', null, 'c', ''] },
363
- 'with arrayLimit 20 + array indices: null then empty string works'
364
- );
365
- st.deepEqual(
366
- qs.parse('a[]=b&a[]&a[]=c&a[]=', { strictNullHandling: true, arrayLimit: 0 }),
367
- { a: { 0: 'b', 1: null, 2: 'c', 3: '' } },
368
- 'with arrayLimit 0 + array brackets: null then empty string works'
369
- );
370
-
371
- st.deepEqual(
372
- qs.parse('a[0]=b&a[1]=&a[2]=c&a[19]', { strictNullHandling: true, arrayLimit: 20 }),
373
- { a: ['b', '', 'c', null] },
374
- 'with arrayLimit 20 + array indices: empty string then null works'
375
- );
376
- st.deepEqual(
377
- qs.parse('a[]=b&a[]=&a[]=c&a[]', { strictNullHandling: true, arrayLimit: 0 }),
378
- { a: { 0: 'b', 1: '', 2: 'c', 3: null } },
379
- 'with arrayLimit 0 + array brackets: empty string then null works'
380
- );
381
-
382
- st.deepEqual(
383
- qs.parse('a[]=&a[]=b&a[]=c'),
384
- { a: ['', 'b', 'c'] },
385
- 'array brackets: empty strings work'
386
- );
387
- st.end();
388
- });
389
-
390
- t.test('compacts sparse arrays', function (st) {
391
- st.deepEqual(qs.parse('a[10]=1&a[2]=2', { arrayLimit: 20 }), { a: ['2', '1'] });
392
- st.deepEqual(qs.parse('a[1][b][2][c]=1', { arrayLimit: 20 }), { a: [{ b: [{ c: '1' }] }] });
393
- st.deepEqual(qs.parse('a[1][2][3][c]=1', { arrayLimit: 20 }), { a: [[[{ c: '1' }]]] });
394
- st.deepEqual(qs.parse('a[1][2][3][c][1]=1', { arrayLimit: 20 }), { a: [[[{ c: ['1'] }]]] });
395
- st.end();
396
- });
397
-
398
- t.test('parses sparse arrays', function (st) {
399
- /* eslint no-sparse-arrays: 0 */
400
- st.deepEqual(qs.parse('a[4]=1&a[1]=2', { allowSparse: true }), { a: [, '2', , , '1'] });
401
- st.deepEqual(qs.parse('a[1][b][2][c]=1', { allowSparse: true }), { a: [, { b: [, , { c: '1' }] }] });
402
- st.deepEqual(qs.parse('a[1][2][3][c]=1', { allowSparse: true }), { a: [, [, , [, , , { c: '1' }]]] });
403
- st.deepEqual(qs.parse('a[1][2][3][c][1]=1', { allowSparse: true }), { a: [, [, , [, , , { c: [, '1'] }]]] });
404
- st.end();
405
- });
406
-
407
- t.test('parses semi-parsed strings', function (st) {
408
- st.deepEqual(qs.parse({ 'a[b]': 'c' }), { a: { b: 'c' } });
409
- st.deepEqual(qs.parse({ 'a[b]': 'c', 'a[d]': 'e' }), { a: { b: 'c', d: 'e' } });
410
- st.end();
411
- });
412
-
413
- t.test('parses buffers correctly', function (st) {
414
- var b = SaferBuffer.from('test');
415
- st.deepEqual(qs.parse({ a: b }), { a: b });
416
- st.end();
417
- });
418
-
419
- t.test('parses jquery-param strings', function (st) {
420
- // readable = 'filter[0][]=int1&filter[0][]==&filter[0][]=77&filter[]=and&filter[2][]=int2&filter[2][]==&filter[2][]=8'
421
- var encoded = 'filter%5B0%5D%5B%5D=int1&filter%5B0%5D%5B%5D=%3D&filter%5B0%5D%5B%5D=77&filter%5B%5D=and&filter%5B2%5D%5B%5D=int2&filter%5B2%5D%5B%5D=%3D&filter%5B2%5D%5B%5D=8';
422
- var expected = { filter: [['int1', '=', '77'], 'and', ['int2', '=', '8']] };
423
- st.deepEqual(qs.parse(encoded), expected);
424
- st.end();
425
- });
426
-
427
- t.test('continues parsing when no parent is found', function (st) {
428
- st.deepEqual(qs.parse('[]=&a=b'), { 0: '', a: 'b' });
429
- st.deepEqual(qs.parse('[]&a=b', { strictNullHandling: true }), { 0: null, a: 'b' });
430
- st.deepEqual(qs.parse('[foo]=bar'), { foo: 'bar' });
431
- st.end();
432
- });
433
-
434
- t.test('does not error when parsing a very long array', function (st) {
435
- var str = 'a[]=a';
436
- while (Buffer.byteLength(str) < 128 * 1024) {
437
- str = str + '&' + str;
438
- }
439
-
440
- st.doesNotThrow(function () {
441
- qs.parse(str);
442
- });
443
-
444
- st.end();
445
- });
446
-
447
- t.test('does not throw when a native prototype has an enumerable property', function (st) {
448
- st.intercept(Object.prototype, 'crash', { value: '' });
449
- st.intercept(Array.prototype, 'crash', { value: '' });
450
-
451
- st.doesNotThrow(qs.parse.bind(null, 'a=b'));
452
- st.deepEqual(qs.parse('a=b'), { a: 'b' });
453
- st.doesNotThrow(qs.parse.bind(null, 'a[][b]=c'));
454
- st.deepEqual(qs.parse('a[][b]=c'), { a: [{ b: 'c' }] });
455
-
456
- st.end();
457
- });
458
-
459
- t.test('parses a string with an alternative string delimiter', function (st) {
460
- st.deepEqual(qs.parse('a=b;c=d', { delimiter: ';' }), { a: 'b', c: 'd' });
461
- st.end();
462
- });
463
-
464
- t.test('parses a string with an alternative RegExp delimiter', function (st) {
465
- st.deepEqual(qs.parse('a=b; c=d', { delimiter: /[;,] */ }), { a: 'b', c: 'd' });
466
- st.end();
467
- });
468
-
469
- t.test('does not use non-splittable objects as delimiters', function (st) {
470
- st.deepEqual(qs.parse('a=b&c=d', { delimiter: true }), { a: 'b', c: 'd' });
471
- st.end();
472
- });
473
-
474
- t.test('allows overriding parameter limit', function (st) {
475
- st.deepEqual(qs.parse('a=b&c=d', { parameterLimit: 1 }), { a: 'b' });
476
- st.end();
477
- });
478
-
479
- t.test('allows setting the parameter limit to Infinity', function (st) {
480
- st.deepEqual(qs.parse('a=b&c=d', { parameterLimit: Infinity }), { a: 'b', c: 'd' });
481
- st.end();
482
- });
483
-
484
- t.test('allows overriding array limit', function (st) {
485
- st.deepEqual(qs.parse('a[0]=b', { arrayLimit: -1 }), { a: { 0: 'b' } });
486
- st.deepEqual(qs.parse('a[0]=b', { arrayLimit: 0 }), { a: { 0: 'b' } });
487
-
488
- st.deepEqual(qs.parse('a[-1]=b', { arrayLimit: -1 }), { a: { '-1': 'b' } });
489
- st.deepEqual(qs.parse('a[-1]=b', { arrayLimit: 0 }), { a: { '-1': 'b' } });
490
-
491
- st.deepEqual(qs.parse('a[0]=b&a[1]=c', { arrayLimit: -1 }), { a: { 0: 'b', 1: 'c' } });
492
- st.deepEqual(qs.parse('a[0]=b&a[1]=c', { arrayLimit: 0 }), { a: { 0: 'b', 1: 'c' } });
493
-
494
- st.end();
495
- });
496
-
497
- t.test('allows disabling array parsing', function (st) {
498
- var indices = qs.parse('a[0]=b&a[1]=c', { parseArrays: false });
499
- st.deepEqual(indices, { a: { 0: 'b', 1: 'c' } });
500
- st.equal(Array.isArray(indices.a), false, 'parseArrays:false, indices case is not an array');
501
-
502
- var emptyBrackets = qs.parse('a[]=b', { parseArrays: false });
503
- st.deepEqual(emptyBrackets, { a: { 0: 'b' } });
504
- st.equal(Array.isArray(emptyBrackets.a), false, 'parseArrays:false, empty brackets case is not an array');
505
-
506
- st.end();
507
- });
508
-
509
- t.test('allows for query string prefix', function (st) {
510
- st.deepEqual(qs.parse('?foo=bar', { ignoreQueryPrefix: true }), { foo: 'bar' });
511
- st.deepEqual(qs.parse('foo=bar', { ignoreQueryPrefix: true }), { foo: 'bar' });
512
- st.deepEqual(qs.parse('?foo=bar', { ignoreQueryPrefix: false }), { '?foo': 'bar' });
513
-
514
- st.end();
515
- });
516
-
517
- t.test('parses an object', function (st) {
518
- var input = {
519
- 'user[name]': { 'pop[bob]': 3 },
520
- 'user[email]': null
521
- };
522
-
523
- var expected = {
524
- user: {
525
- name: { 'pop[bob]': 3 },
526
- email: null
527
- }
528
- };
529
-
530
- var result = qs.parse(input);
531
-
532
- st.deepEqual(result, expected);
533
- st.end();
534
- });
535
-
536
- t.test('parses string with comma as array divider', function (st) {
537
- st.deepEqual(qs.parse('foo=bar,tee', { comma: true }), { foo: ['bar', 'tee'] });
538
- st.deepEqual(qs.parse('foo[bar]=coffee,tee', { comma: true }), { foo: { bar: ['coffee', 'tee'] } });
539
- st.deepEqual(qs.parse('foo=', { comma: true }), { foo: '' });
540
- st.deepEqual(qs.parse('foo', { comma: true }), { foo: '' });
541
- st.deepEqual(qs.parse('foo', { comma: true, strictNullHandling: true }), { foo: null });
542
-
543
- // test cases inversed from from stringify tests
544
- st.deepEqual(qs.parse('a[0]=c'), { a: ['c'] });
545
- st.deepEqual(qs.parse('a[]=c'), { a: ['c'] });
546
- st.deepEqual(qs.parse('a[]=c', { comma: true }), { a: ['c'] });
547
-
548
- st.deepEqual(qs.parse('a[0]=c&a[1]=d'), { a: ['c', 'd'] });
549
- st.deepEqual(qs.parse('a[]=c&a[]=d'), { a: ['c', 'd'] });
550
- st.deepEqual(qs.parse('a=c,d', { comma: true }), { a: ['c', 'd'] });
551
-
552
- st.end();
553
- });
554
-
555
- t.test('parses values with comma as array divider', function (st) {
556
- st.deepEqual(qs.parse({ foo: 'bar,tee' }, { comma: false }), { foo: 'bar,tee' });
557
- st.deepEqual(qs.parse({ foo: 'bar,tee' }, { comma: true }), { foo: ['bar', 'tee'] });
558
- st.end();
559
- });
560
-
561
- t.test('use number decoder, parses string that has one number with comma option enabled', function (st) {
562
- var decoder = function (str, defaultDecoder, charset, type) {
563
- if (!isNaN(Number(str))) {
564
- return parseFloat(str);
565
- }
566
- return defaultDecoder(str, defaultDecoder, charset, type);
567
- };
568
-
569
- st.deepEqual(qs.parse('foo=1', { comma: true, decoder: decoder }), { foo: 1 });
570
- st.deepEqual(qs.parse('foo=0', { comma: true, decoder: decoder }), { foo: 0 });
571
-
572
- st.end();
573
- });
574
-
575
- t.test('parses brackets holds array of arrays when having two parts of strings with comma as array divider', function (st) {
576
- st.deepEqual(qs.parse('foo[]=1,2,3&foo[]=4,5,6', { comma: true }), { foo: [['1', '2', '3'], ['4', '5', '6']] });
577
- st.deepEqual(qs.parse('foo[]=1,2,3&foo[]=', { comma: true }), { foo: [['1', '2', '3'], ''] });
578
- st.deepEqual(qs.parse('foo[]=1,2,3&foo[]=,', { comma: true }), { foo: [['1', '2', '3'], ['', '']] });
579
- st.deepEqual(qs.parse('foo[]=1,2,3&foo[]=a', { comma: true }), { foo: [['1', '2', '3'], 'a'] });
580
-
581
- st.end();
582
- });
583
-
584
- t.test('parses url-encoded brackets holds array of arrays when having two parts of strings with comma as array divider', function (st) {
585
- st.deepEqual(qs.parse('foo%5B%5D=1,2,3&foo%5B%5D=4,5,6', { comma: true }), { foo: [['1', '2', '3'], ['4', '5', '6']] });
586
- st.deepEqual(qs.parse('foo%5B%5D=1,2,3&foo%5B%5D=', { comma: true }), { foo: [['1', '2', '3'], ''] });
587
- st.deepEqual(qs.parse('foo%5B%5D=1,2,3&foo%5B%5D=,', { comma: true }), { foo: [['1', '2', '3'], ['', '']] });
588
- st.deepEqual(qs.parse('foo%5B%5D=1,2,3&foo%5B%5D=a', { comma: true }), { foo: [['1', '2', '3'], 'a'] });
589
-
590
- st.end();
591
- });
592
-
593
- t.test('parses comma delimited array while having percent-encoded comma treated as normal text', function (st) {
594
- st.deepEqual(qs.parse('foo=a%2Cb', { comma: true }), { foo: 'a,b' });
595
- st.deepEqual(qs.parse('foo=a%2C%20b,d', { comma: true }), { foo: ['a, b', 'd'] });
596
- st.deepEqual(qs.parse('foo=a%2C%20b,c%2C%20d', { comma: true }), { foo: ['a, b', 'c, d'] });
597
-
598
- st.end();
599
- });
600
-
601
- t.test('parses an object in dot notation', function (st) {
602
- var input = {
603
- 'user.name': { 'pop[bob]': 3 },
604
- 'user.email.': null
605
- };
606
-
607
- var expected = {
608
- user: {
609
- name: { 'pop[bob]': 3 },
610
- email: null
611
- }
612
- };
613
-
614
- var result = qs.parse(input, { allowDots: true });
615
-
616
- st.deepEqual(result, expected);
617
- st.end();
618
- });
619
-
620
- t.test('parses an object and not child values', function (st) {
621
- var input = {
622
- 'user[name]': { 'pop[bob]': { test: 3 } },
623
- 'user[email]': null
624
- };
625
-
626
- var expected = {
627
- user: {
628
- name: { 'pop[bob]': { test: 3 } },
629
- email: null
630
- }
631
- };
632
-
633
- var result = qs.parse(input);
634
-
635
- st.deepEqual(result, expected);
636
- st.end();
637
- });
638
-
639
- t.test('does not blow up when Buffer global is missing', function (st) {
640
- var restore = mockProperty(global, 'Buffer', { 'delete': true });
641
-
642
- var result = qs.parse('a=b&c=d');
643
-
644
- restore();
645
-
646
- st.deepEqual(result, { a: 'b', c: 'd' });
647
- st.end();
648
- });
649
-
650
- t.test('does not crash when parsing circular references', function (st) {
651
- var a = {};
652
- a.b = a;
653
-
654
- var parsed;
655
-
656
- st.doesNotThrow(function () {
657
- parsed = qs.parse({ 'foo[bar]': 'baz', 'foo[baz]': a });
658
- });
659
-
660
- st.equal('foo' in parsed, true, 'parsed has "foo" property');
661
- st.equal('bar' in parsed.foo, true);
662
- st.equal('baz' in parsed.foo, true);
663
- st.equal(parsed.foo.bar, 'baz');
664
- st.deepEqual(parsed.foo.baz, a);
665
- st.end();
666
- });
667
-
668
- t.test('does not crash when parsing deep objects', function (st) {
669
- var parsed;
670
- var str = 'foo';
671
-
672
- for (var i = 0; i < 5000; i++) {
673
- str += '[p]';
674
- }
675
-
676
- str += '=bar';
677
-
678
- st.doesNotThrow(function () {
679
- parsed = qs.parse(str, { depth: 5000 });
680
- });
681
-
682
- st.equal('foo' in parsed, true, 'parsed has "foo" property');
683
-
684
- var depth = 0;
685
- var ref = parsed.foo;
686
- while ((ref = ref.p)) {
687
- depth += 1;
688
- }
689
-
690
- st.equal(depth, 5000, 'parsed is 5000 properties deep');
691
-
692
- st.end();
693
- });
694
-
695
- t.test('parses null objects correctly', { skip: !hasProto }, function (st) {
696
- var a = { __proto__: null, b: 'c' };
697
-
698
- st.deepEqual(qs.parse(a), { b: 'c' });
699
- var result = qs.parse({ a: a });
700
- st.equal('a' in result, true, 'result has "a" property');
701
- st.deepEqual(result.a, a);
702
- st.end();
703
- });
704
-
705
- t.test('parses dates correctly', function (st) {
706
- var now = new Date();
707
- st.deepEqual(qs.parse({ a: now }), { a: now });
708
- st.end();
709
- });
710
-
711
- t.test('parses regular expressions correctly', function (st) {
712
- var re = /^test$/;
713
- st.deepEqual(qs.parse({ a: re }), { a: re });
714
- st.end();
715
- });
716
-
717
- t.test('does not allow overwriting prototype properties', function (st) {
718
- st.deepEqual(qs.parse('a[hasOwnProperty]=b', { allowPrototypes: false }), {});
719
- st.deepEqual(qs.parse('hasOwnProperty=b', { allowPrototypes: false }), {});
720
-
721
- st.deepEqual(
722
- qs.parse('toString', { allowPrototypes: false }),
723
- {},
724
- 'bare "toString" results in {}'
725
- );
726
-
727
- st.end();
728
- });
729
-
730
- t.test('can allow overwriting prototype properties', function (st) {
731
- st.deepEqual(qs.parse('a[hasOwnProperty]=b', { allowPrototypes: true }), { a: { hasOwnProperty: 'b' } });
732
- st.deepEqual(qs.parse('hasOwnProperty=b', { allowPrototypes: true }), { hasOwnProperty: 'b' });
733
-
734
- st.deepEqual(
735
- qs.parse('toString', { allowPrototypes: true }),
736
- { toString: '' },
737
- 'bare "toString" results in { toString: "" }'
738
- );
739
-
740
- st.end();
741
- });
742
-
743
- t.test('does not crash when the global Object prototype is frozen', { skip: !hasPropertyDescriptors || !hasOverrideMistake }, function (st) {
744
- // We can't actually freeze the global Object prototype as that will interfere with other tests, and once an object is frozen, it
745
- // can't be unfrozen. Instead, we add a new non-writable property to simulate this.
746
- st.teardown(mockProperty(Object.prototype, 'frozenProp', { value: 'foo', nonWritable: true, nonEnumerable: true }));
747
-
748
- st['throws'](
749
- function () {
750
- var obj = {};
751
- obj.frozenProp = 'bar';
752
- },
753
- // node < 6 has a different error message
754
- /^TypeError: Cannot assign to read only property 'frozenProp' of (?:object '#<Object>'|#<Object>)/,
755
- 'regular assignment of an inherited non-writable property throws'
756
- );
757
-
758
- var parsed;
759
- st.doesNotThrow(
760
- function () {
761
- parsed = qs.parse('frozenProp', { allowPrototypes: false });
762
- },
763
- 'parsing a nonwritable Object.prototype property does not throw'
764
- );
765
-
766
- st.deepEqual(parsed, {}, 'bare "frozenProp" results in {}');
767
-
768
- st.end();
769
- });
770
-
771
- t.test('params starting with a closing bracket', function (st) {
772
- st.deepEqual(qs.parse(']=toString'), { ']': 'toString' });
773
- st.deepEqual(qs.parse(']]=toString'), { ']]': 'toString' });
774
- st.deepEqual(qs.parse(']hello]=toString'), { ']hello]': 'toString' });
775
- st.end();
776
- });
777
-
778
- t.test('params starting with a starting bracket', function (st) {
779
- st.deepEqual(qs.parse('[=toString'), { '[': 'toString' });
780
- st.deepEqual(qs.parse('[[=toString'), { '[[': 'toString' });
781
- st.deepEqual(qs.parse('[hello[=toString'), { '[hello[': 'toString' });
782
- st.end();
783
- });
784
-
785
- t.test('add keys to objects', function (st) {
786
- st.deepEqual(
787
- qs.parse('a[b]=c&a=d', { strictMerge: false }),
788
- { a: { b: 'c', d: true } },
789
- 'can add keys to objects'
790
- );
791
-
792
- st.deepEqual(
793
- qs.parse('a[b]=c&a=toString', { strictMerge: false }),
794
- { a: { b: 'c' } },
795
- 'can not overwrite prototype'
796
- );
797
-
798
- st.deepEqual(
799
- qs.parse('a[b]=c&a=toString', { strictMerge: false, allowPrototypes: true }),
800
- { a: { b: 'c', toString: true } },
801
- 'can overwrite prototype with allowPrototypes true'
802
- );
803
-
804
- st.deepEqual(
805
- qs.parse('a[b]=c&a=toString', { strictMerge: false, plainObjects: true }),
806
- { __proto__: null, a: { __proto__: null, b: 'c', toString: true } },
807
- 'can overwrite prototype with plainObjects true'
808
- );
809
-
810
- st.end();
811
- });
812
-
813
- t.test('strictMerge wraps object and primitive into an array', function (st) {
814
- st.deepEqual(
815
- qs.parse('a[b]=c&a=d'),
816
- { a: [{ b: 'c' }, 'd'] },
817
- 'object then primitive produces array'
818
- );
819
-
820
- st.deepEqual(
821
- qs.parse('a=d&a[b]=c'),
822
- { a: ['d', { b: 'c' }] },
823
- 'primitive then object produces array'
824
- );
825
-
826
- st.deepEqual(
827
- qs.parse('a[b]=c&a=toString'),
828
- { a: [{ b: 'c' }, 'toString'] },
829
- 'prototype-colliding value is preserved in array'
830
- );
831
-
832
- st.deepEqual(
833
- qs.parse('a[b]=c&a=toString', { plainObjects: true }),
834
- { __proto__: null, a: [{ __proto__: null, b: 'c' }, 'toString'] },
835
- 'plainObjects preserved in array wrapping'
836
- );
837
-
838
- st.end();
839
- });
840
-
841
- t.test('dunder proto is ignored', function (st) {
842
- var payload = 'categories[__proto__]=login&categories[__proto__]&categories[length]=42';
843
- var result = qs.parse(payload, { allowPrototypes: true });
844
-
845
- st.deepEqual(
846
- result,
847
- {
848
- categories: {
849
- length: '42'
850
- }
851
- },
852
- 'silent [[Prototype]] payload'
853
- );
854
-
855
- var plainResult = qs.parse(payload, { allowPrototypes: true, plainObjects: true });
856
-
857
- st.deepEqual(
858
- plainResult,
859
- {
860
- __proto__: null,
861
- categories: {
862
- __proto__: null,
863
- length: '42'
864
- }
865
- },
866
- 'silent [[Prototype]] payload: plain objects'
867
- );
868
-
869
- var query = qs.parse('categories[__proto__]=cats&categories[__proto__]=dogs&categories[some][json]=toInject', { allowPrototypes: true });
870
-
871
- st.notOk(Array.isArray(query.categories), 'is not an array');
872
- st.notOk(query.categories instanceof Array, 'is not instanceof an array');
873
- st.deepEqual(query.categories, { some: { json: 'toInject' } });
874
- st.equal(JSON.stringify(query.categories), '{"some":{"json":"toInject"}}', 'stringifies as a non-array');
875
-
876
- st.deepEqual(
877
- qs.parse('foo[__proto__][hidden]=value&foo[bar]=stuffs', { allowPrototypes: true }),
878
- {
879
- foo: {
880
- bar: 'stuffs'
881
- }
882
- },
883
- 'hidden values'
884
- );
885
-
886
- st.deepEqual(
887
- qs.parse('foo[__proto__][hidden]=value&foo[bar]=stuffs', { allowPrototypes: true, plainObjects: true }),
888
- {
889
- __proto__: null,
890
- foo: {
891
- __proto__: null,
892
- bar: 'stuffs'
893
- }
894
- },
895
- 'hidden values: plain objects'
896
- );
897
-
898
- st.end();
899
- });
900
-
901
- t.test('can return null objects', { skip: !hasProto }, function (st) {
902
- var expected = {
903
- __proto__: null,
904
- a: {
905
- __proto__: null,
906
- b: 'c',
907
- hasOwnProperty: 'd'
908
- }
909
- };
910
- st.deepEqual(qs.parse('a[b]=c&a[hasOwnProperty]=d', { plainObjects: true }), expected);
911
- st.deepEqual(qs.parse(null, { plainObjects: true }), { __proto__: null });
912
- var expectedArray = {
913
- __proto__: null,
914
- a: {
915
- __proto__: null,
916
- 0: 'b',
917
- c: 'd'
918
- }
919
- };
920
- st.deepEqual(qs.parse('a[]=b&a[c]=d', { plainObjects: true }), expectedArray);
921
- st.end();
922
- });
923
-
924
- t.test('can parse with custom encoding', function (st) {
925
- st.deepEqual(qs.parse('%8c%a7=%91%e5%8d%e3%95%7b', {
926
- decoder: function (str) {
927
- var reg = /%([0-9A-F]{2})/ig;
928
- var result = [];
929
- var parts = reg.exec(str);
930
- while (parts) {
931
- result.push(parseInt(parts[1], 16));
932
- parts = reg.exec(str);
933
- }
934
- return String(iconv.decode(SaferBuffer.from(result), 'shift_jis'));
935
- }
936
- }), { 県: '大阪府' });
937
- st.end();
938
- });
939
-
940
- t.test('receives the default decoder as a second argument', function (st) {
941
- st.plan(1);
942
- qs.parse('a', {
943
- decoder: function (str, defaultDecoder) {
944
- st.equal(defaultDecoder, utils.decode);
945
- }
946
- });
947
- st.end();
948
- });
949
-
950
- t.test('throws error with wrong decoder', function (st) {
951
- st['throws'](function () {
952
- qs.parse({}, { decoder: 'string' });
953
- }, new TypeError('Decoder has to be a function.'));
954
- st.end();
955
- });
956
-
957
- t.test('does not mutate the options argument', function (st) {
958
- var options = {};
959
- qs.parse('a[b]=true', options);
960
- st.deepEqual(options, {});
961
- st.end();
962
- });
963
-
964
- t.test('throws if an invalid charset is specified', function (st) {
965
- st['throws'](function () {
966
- qs.parse('a=b', { charset: 'foobar' });
967
- }, new TypeError('The charset option must be either utf-8, iso-8859-1, or undefined'));
968
- st.end();
969
- });
970
-
971
- t.test('parses an iso-8859-1 string if asked to', function (st) {
972
- st.deepEqual(qs.parse('%A2=%BD', { charset: 'iso-8859-1' }), { '¢': '½' });
973
- st.end();
974
- });
975
-
976
- var urlEncodedCheckmarkInUtf8 = '%E2%9C%93';
977
- var urlEncodedOSlashInUtf8 = '%C3%B8';
978
- var urlEncodedNumCheckmark = '%26%2310003%3B';
979
- var urlEncodedNumSmiley = '%26%239786%3B';
980
-
981
- t.test('prefers an utf-8 charset specified by the utf8 sentinel to a default charset of iso-8859-1', function (st) {
982
- st.deepEqual(qs.parse('utf8=' + urlEncodedCheckmarkInUtf8 + '&' + urlEncodedOSlashInUtf8 + '=' + urlEncodedOSlashInUtf8, { charsetSentinel: true, charset: 'iso-8859-1' }), { ø: 'ø' });
983
- st.end();
984
- });
985
-
986
- t.test('prefers an iso-8859-1 charset specified by the utf8 sentinel to a default charset of utf-8', function (st) {
987
- st.deepEqual(qs.parse('utf8=' + urlEncodedNumCheckmark + '&' + urlEncodedOSlashInUtf8 + '=' + urlEncodedOSlashInUtf8, { charsetSentinel: true, charset: 'utf-8' }), { 'ø': 'ø' });
988
- st.end();
989
- });
990
-
991
- t.test('does not require the utf8 sentinel to be defined before the parameters whose decoding it affects', function (st) {
992
- st.deepEqual(qs.parse('a=' + urlEncodedOSlashInUtf8 + '&utf8=' + urlEncodedNumCheckmark, { charsetSentinel: true, charset: 'utf-8' }), { a: 'ø' });
993
- st.end();
994
- });
995
-
996
- t.test('ignores an utf8 sentinel with an unknown value', function (st) {
997
- st.deepEqual(qs.parse('utf8=foo&' + urlEncodedOSlashInUtf8 + '=' + urlEncodedOSlashInUtf8, { charsetSentinel: true, charset: 'utf-8' }), { ø: 'ø' });
998
- st.end();
999
- });
1000
-
1001
- t.test('uses the utf8 sentinel to switch to utf-8 when no default charset is given', function (st) {
1002
- st.deepEqual(qs.parse('utf8=' + urlEncodedCheckmarkInUtf8 + '&' + urlEncodedOSlashInUtf8 + '=' + urlEncodedOSlashInUtf8, { charsetSentinel: true }), { ø: 'ø' });
1003
- st.end();
1004
- });
1005
-
1006
- t.test('uses the utf8 sentinel to switch to iso-8859-1 when no default charset is given', function (st) {
1007
- st.deepEqual(qs.parse('utf8=' + urlEncodedNumCheckmark + '&' + urlEncodedOSlashInUtf8 + '=' + urlEncodedOSlashInUtf8, { charsetSentinel: true }), { 'ø': 'ø' });
1008
- st.end();
1009
- });
1010
-
1011
- t.test('interprets numeric entities in iso-8859-1 when `interpretNumericEntities`', function (st) {
1012
- st.deepEqual(qs.parse('foo=' + urlEncodedNumSmiley, { charset: 'iso-8859-1', interpretNumericEntities: true }), { foo: '☺' });
1013
- st.end();
1014
- });
1015
-
1016
- t.test('handles a custom decoder returning `null`, in the `iso-8859-1` charset, when `interpretNumericEntities`', function (st) {
1017
- st.deepEqual(qs.parse('foo=&bar=' + urlEncodedNumSmiley, {
1018
- charset: 'iso-8859-1',
1019
- decoder: function (str, defaultDecoder, charset) {
1020
- return str ? defaultDecoder(str, defaultDecoder, charset) : null;
1021
- },
1022
- interpretNumericEntities: true
1023
- }), { foo: null, bar: '☺' });
1024
- st.end();
1025
- });
1026
-
1027
- t.test('handles a custom decoder returning `null`, with a string key of `null`', function (st) {
1028
- st.deepEqual(
1029
- qs.parse('null=1&ToNull=2', {
1030
- decoder: function (str, defaultDecoder, charset) {
1031
- return str === 'ToNull' ? null : defaultDecoder(str, defaultDecoder, charset);
1032
- }
1033
- }),
1034
- { 'null': '1' },
1035
- '"null" key is not overridden by `null` decoder result'
1036
- );
1037
-
1038
- st.end();
1039
- });
1040
-
1041
- t.test('does not interpret numeric entities in iso-8859-1 when `interpretNumericEntities` is absent', function (st) {
1042
- st.deepEqual(qs.parse('foo=' + urlEncodedNumSmiley, { charset: 'iso-8859-1' }), { foo: '&#9786;' });
1043
- st.end();
1044
- });
1045
-
1046
- t.test('does not interpret numeric entities when the charset is utf-8, even when `interpretNumericEntities`', function (st) {
1047
- st.deepEqual(qs.parse('foo=' + urlEncodedNumSmiley, { charset: 'utf-8', interpretNumericEntities: true }), { foo: '&#9786;' });
1048
- st.end();
1049
- });
1050
-
1051
- t.test('interpretNumericEntities with comma:true and iso charset does not crash', function (st) {
1052
- st.deepEqual(
1053
- qs.parse('b&a[]=1,' + urlEncodedNumSmiley, { comma: true, charset: 'iso-8859-1', interpretNumericEntities: true }),
1054
- { b: '', a: ['1,☺'] }
1055
- );
1056
-
1057
- st.end();
1058
- });
1059
-
1060
- t.test('does not interpret %uXXXX syntax in iso-8859-1 mode', function (st) {
1061
- st.deepEqual(qs.parse('%u263A=%u263A', { charset: 'iso-8859-1' }), { '%u263A': '%u263A' });
1062
- st.end();
1063
- });
1064
-
1065
- t.test('allows for decoding keys and values differently', function (st) {
1066
- var decoder = function (str, defaultDecoder, charset, type) {
1067
- if (type === 'key') {
1068
- return defaultDecoder(str, defaultDecoder, charset, type).toLowerCase();
1069
- }
1070
- if (type === 'value') {
1071
- return defaultDecoder(str, defaultDecoder, charset, type).toUpperCase();
1072
- }
1073
- throw 'this should never happen! type: ' + type;
1074
- };
1075
-
1076
- st.deepEqual(qs.parse('KeY=vAlUe', { decoder: decoder }), { key: 'VALUE' });
1077
- st.end();
1078
- });
1079
-
1080
- t.test('parameter limit tests', function (st) {
1081
- st.test('does not throw error when within parameter limit', function (sst) {
1082
- var result = qs.parse('a=1&b=2&c=3', { parameterLimit: 5, throwOnLimitExceeded: true });
1083
- sst.deepEqual(result, { a: '1', b: '2', c: '3' }, 'parses without errors');
1084
- sst.end();
1085
- });
1086
-
1087
- st.test('throws error when throwOnLimitExceeded is present but not boolean', function (sst) {
1088
- sst['throws'](
1089
- function () {
1090
- qs.parse('a=1&b=2&c=3&d=4&e=5&f=6', { parameterLimit: 3, throwOnLimitExceeded: 'true' });
1091
- },
1092
- new TypeError('`throwOnLimitExceeded` option must be a boolean'),
1093
- 'throws error when throwOnLimitExceeded is present and not boolean'
1094
- );
1095
- sst.end();
1096
- });
1097
-
1098
- st.test('throws error when parameter limit exceeded', function (sst) {
1099
- sst['throws'](
1100
- function () {
1101
- qs.parse('a=1&b=2&c=3&d=4&e=5&f=6', { parameterLimit: 3, throwOnLimitExceeded: true });
1102
- },
1103
- new RangeError('Parameter limit exceeded. Only 3 parameters allowed.'),
1104
- 'throws error when parameter limit is exceeded'
1105
- );
1106
- sst.end();
1107
- });
1108
-
1109
- st.test('silently truncates when throwOnLimitExceeded is not given', function (sst) {
1110
- var result = qs.parse('a=1&b=2&c=3&d=4&e=5', { parameterLimit: 3 });
1111
- sst.deepEqual(result, { a: '1', b: '2', c: '3' }, 'parses and truncates silently');
1112
- sst.end();
1113
- });
1114
-
1115
- st.test('silently truncates when parameter limit exceeded without error', function (sst) {
1116
- var result = qs.parse('a=1&b=2&c=3&d=4&e=5', { parameterLimit: 3, throwOnLimitExceeded: false });
1117
- sst.deepEqual(result, { a: '1', b: '2', c: '3' }, 'parses and truncates silently');
1118
- sst.end();
1119
- });
1120
-
1121
- st.test('allows unlimited parameters when parameterLimit set to Infinity', function (sst) {
1122
- var result = qs.parse('a=1&b=2&c=3&d=4&e=5&f=6', { parameterLimit: Infinity });
1123
- sst.deepEqual(result, { a: '1', b: '2', c: '3', d: '4', e: '5', f: '6' }, 'parses all parameters without truncation');
1124
- sst.end();
1125
- });
1126
-
1127
- st.end();
1128
- });
1129
-
1130
- t.test('array limit tests', function (st) {
1131
- st.test('does not throw error when array is within limit', function (sst) {
1132
- var result = qs.parse('a[]=1&a[]=2&a[]=3', { arrayLimit: 5, throwOnLimitExceeded: true });
1133
- sst.deepEqual(result, { a: ['1', '2', '3'] }, 'parses array without errors');
1134
- sst.end();
1135
- });
1136
-
1137
- st.test('throws error when throwOnLimitExceeded is present but not boolean for array limit', function (sst) {
1138
- sst['throws'](
1139
- function () {
1140
- qs.parse('a[]=1&a[]=2&a[]=3&a[]=4', { arrayLimit: 3, throwOnLimitExceeded: 'true' });
1141
- },
1142
- new TypeError('`throwOnLimitExceeded` option must be a boolean'),
1143
- 'throws error when throwOnLimitExceeded is present and not boolean for array limit'
1144
- );
1145
- sst.end();
1146
- });
1147
-
1148
- st.test('throws error when array limit exceeded', function (sst) {
1149
- // 4 elements exceeds limit of 3
1150
- sst['throws'](
1151
- function () {
1152
- qs.parse('a[]=1&a[]=2&a[]=3&a[]=4', { arrayLimit: 3, throwOnLimitExceeded: true });
1153
- },
1154
- new RangeError('Array limit exceeded. Only 3 elements allowed in an array.'),
1155
- 'throws error when array limit is exceeded'
1156
- );
1157
- sst.end();
1158
- });
1159
-
1160
- st.test('does not throw when at limit', function (sst) {
1161
- // 3 elements = limit of 3, should not throw
1162
- var result = qs.parse('a[]=1&a[]=2&a[]=3', { arrayLimit: 3, throwOnLimitExceeded: true });
1163
- sst.ok(Array.isArray(result.a), 'result is an array');
1164
- sst.deepEqual(result.a, ['1', '2', '3'], 'all values present');
1165
- sst.end();
1166
- });
1167
-
1168
- st.test('converts array to object if length is greater than limit', function (sst) {
1169
- var result = qs.parse('a[1]=1&a[2]=2&a[3]=3&a[4]=4&a[5]=5&a[6]=6', { arrayLimit: 5 });
1170
-
1171
- sst.deepEqual(result, { a: { 1: '1', 2: '2', 3: '3', 4: '4', 5: '5', 6: '6' } }, 'parses into object if array length is greater than limit');
1172
- sst.end();
1173
- });
1174
-
1175
- st.test('throws error when indexed notation exceeds arrayLimit with throwOnLimitExceeded', function (sst) {
1176
- sst['throws'](
1177
- function () {
1178
- qs.parse('a[1001]=b', { arrayLimit: 1000, throwOnLimitExceeded: true });
1179
- },
1180
- new RangeError('Array limit exceeded. Only 1000 elements allowed in an array.'),
1181
- 'throws error for a single index exceeding arrayLimit'
1182
- );
1183
-
1184
- sst['throws'](
1185
- function () {
1186
- qs.parse('a[0]=1&a[1]=2&a[2]=3&a[10]=4', { arrayLimit: 6, throwOnLimitExceeded: true, allowSparse: true });
1187
- },
1188
- new RangeError('Array limit exceeded. Only 6 elements allowed in an array.'),
1189
- 'throws error when a sparse index exceeds arrayLimit'
1190
- );
1191
-
1192
- sst.end();
1193
- });
1194
-
1195
- st.test('does not throw for indexed notation within arrayLimit with throwOnLimitExceeded', function (sst) {
1196
- var result = qs.parse('a[4]=b', { arrayLimit: 5, throwOnLimitExceeded: true, allowSparse: true });
1197
- sst.ok(Array.isArray(result.a), 'result is an array');
1198
- sst.equal(result.a.length, 5, 'array has correct length');
1199
- sst.equal(result.a[4], 'b', 'value at index 4 is correct');
1200
- sst.end();
1201
- });
1202
-
1203
- st.test('silently converts to object for indexed notation exceeding arrayLimit without throwOnLimitExceeded', function (sst) {
1204
- var result = qs.parse('a[1001]=b', { arrayLimit: 1000 });
1205
- sst.deepEqual(result, { a: { 1001: 'b' } }, 'converts to object without throwing');
1206
- sst.end();
1207
- });
1208
-
1209
- st.end();
1210
- });
1211
-
1212
- t.end();
1213
- });
1214
-
1215
- test('parses empty keys', function (t) {
1216
- emptyTestCases.forEach(function (testCase) {
1217
- t.test('skips empty string key with ' + testCase.input, function (st) {
1218
- st.deepEqual(qs.parse(testCase.input), testCase.noEmptyKeys);
1219
-
1220
- st.end();
1221
- });
1222
- });
1223
- });
1224
-
1225
- test('`duplicates` option', function (t) {
1226
- v.nonStrings.concat('not a valid option').forEach(function (invalidOption) {
1227
- if (typeof invalidOption !== 'undefined') {
1228
- t['throws'](
1229
- function () { qs.parse('', { duplicates: invalidOption }); },
1230
- TypeError,
1231
- 'throws on invalid option: ' + inspect(invalidOption)
1232
- );
1233
- }
1234
- });
1235
-
1236
- t.deepEqual(
1237
- qs.parse('foo=bar&foo=baz'),
1238
- { foo: ['bar', 'baz'] },
1239
- 'duplicates: default, combine'
1240
- );
1241
-
1242
- t.deepEqual(
1243
- qs.parse('foo=bar&foo=baz', { duplicates: 'combine' }),
1244
- { foo: ['bar', 'baz'] },
1245
- 'duplicates: combine'
1246
- );
1247
-
1248
- t.deepEqual(
1249
- qs.parse('foo=bar&foo=baz', { duplicates: 'first' }),
1250
- { foo: 'bar' },
1251
- 'duplicates: first'
1252
- );
1253
-
1254
- t.deepEqual(
1255
- qs.parse('foo=bar&foo=baz', { duplicates: 'last' }),
1256
- { foo: 'baz' },
1257
- 'duplicates: last'
1258
- );
1259
-
1260
- t.test('bracket notation always combines regardless of duplicates', function (st) {
1261
- st.deepEqual(
1262
- qs.parse('a=1&a=2&b[]=1&b[]=2', { duplicates: 'last' }),
1263
- { a: '2', b: ['1', '2'] },
1264
- 'duplicates last: unbracketed takes last, bracketed combines'
1265
- );
1266
-
1267
- st.deepEqual(
1268
- qs.parse('b[]=1&b[]=2', { duplicates: 'last' }),
1269
- { b: ['1', '2'] },
1270
- 'duplicates last: bracketed always combines'
1271
- );
1272
-
1273
- st.deepEqual(
1274
- qs.parse('b[]=1&b[]=2', { duplicates: 'first' }),
1275
- { b: ['1', '2'] },
1276
- 'duplicates first: bracketed always combines'
1277
- );
1278
-
1279
- st.deepEqual(
1280
- qs.parse('a=1&a=2&b[]=1&b[]=2', { duplicates: 'first' }),
1281
- { a: '1', b: ['1', '2'] },
1282
- 'duplicates first: unbracketed takes first, bracketed combines'
1283
- );
1284
-
1285
- st.end();
1286
- });
1287
-
1288
- t.end();
1289
- });
1290
-
1291
- test('qs strictDepth option - throw cases', function (t) {
1292
- t.test('throws an exception when depth exceeds the limit with strictDepth: true', function (st) {
1293
- st['throws'](
1294
- function () {
1295
- qs.parse('a[b][c][d][e][f][g][h][i]=j', { depth: 1, strictDepth: true });
1296
- },
1297
- RangeError,
1298
- 'throws RangeError'
1299
- );
1300
- st.end();
1301
- });
1302
-
1303
- t.test('throws an exception for multiple nested arrays with strictDepth: true', function (st) {
1304
- st['throws'](
1305
- function () {
1306
- qs.parse('a[0][1][2][3][4]=b', { depth: 3, strictDepth: true });
1307
- },
1308
- RangeError,
1309
- 'throws RangeError'
1310
- );
1311
- st.end();
1312
- });
1313
-
1314
- t.test('throws an exception for nested objects and arrays with strictDepth: true', function (st) {
1315
- st['throws'](
1316
- function () {
1317
- qs.parse('a[b][c][0][d][e]=f', { depth: 3, strictDepth: true });
1318
- },
1319
- RangeError,
1320
- 'throws RangeError'
1321
- );
1322
- st.end();
1323
- });
1324
-
1325
- t.test('throws an exception for different types of values with strictDepth: true', function (st) {
1326
- st['throws'](
1327
- function () {
1328
- qs.parse('a[b][c][d][e]=true&a[b][c][d][f]=42', { depth: 3, strictDepth: true });
1329
- },
1330
- RangeError,
1331
- 'throws RangeError'
1332
- );
1333
- st.end();
1334
- });
1335
-
1336
- });
1337
-
1338
- test('qs strictDepth option - non-throw cases', function (t) {
1339
- t.test('when depth is 0 and strictDepth true, do not throw', function (st) {
1340
- st.doesNotThrow(
1341
- function () {
1342
- qs.parse('a[b][c][d][e]=true&a[b][c][d][f]=42', { depth: 0, strictDepth: true });
1343
- },
1344
- RangeError,
1345
- 'does not throw RangeError'
1346
- );
1347
- st.end();
1348
- });
1349
-
1350
- t.test('parses successfully when depth is within the limit with strictDepth: true', function (st) {
1351
- st.doesNotThrow(
1352
- function () {
1353
- var result = qs.parse('a[b]=c', { depth: 1, strictDepth: true });
1354
- st.deepEqual(result, { a: { b: 'c' } }, 'parses correctly');
1355
- }
1356
- );
1357
- st.end();
1358
- });
1359
-
1360
- t.test('does not throw an exception when depth exceeds the limit with strictDepth: false', function (st) {
1361
- st.doesNotThrow(
1362
- function () {
1363
- var result = qs.parse('a[b][c][d][e][f][g][h][i]=j', { depth: 1 });
1364
- st.deepEqual(result, { a: { b: { '[c][d][e][f][g][h][i]': 'j' } } }, 'parses with depth limit');
1365
- }
1366
- );
1367
- st.end();
1368
- });
1369
-
1370
- t.test('parses successfully when depth is within the limit with strictDepth: false', function (st) {
1371
- st.doesNotThrow(
1372
- function () {
1373
- var result = qs.parse('a[b]=c', { depth: 1 });
1374
- st.deepEqual(result, { a: { b: 'c' } }, 'parses correctly');
1375
- }
1376
- );
1377
- st.end();
1378
- });
1379
-
1380
- t.test('does not throw when depth is exactly at the limit with strictDepth: true', function (st) {
1381
- st.doesNotThrow(
1382
- function () {
1383
- var result = qs.parse('a[b][c]=d', { depth: 2, strictDepth: true });
1384
- st.deepEqual(result, { a: { b: { c: 'd' } } }, 'parses correctly');
1385
- }
1386
- );
1387
- st.end();
1388
- });
1389
- });
1390
-
1391
- test('DOS', function (t) {
1392
- var arr = [];
1393
- for (var i = 0; i < 105; i++) {
1394
- arr[arr.length] = 'x';
1395
- }
1396
- var attack = 'a[]=' + arr.join('&a[]=');
1397
- var result = qs.parse(attack, { arrayLimit: 100 });
1398
-
1399
- t.notOk(Array.isArray(result.a), 'arrayLimit is respected: result is an object, not an array');
1400
- t.equal(Object.keys(result.a).length, 105, 'all values are preserved');
1401
-
1402
- t.end();
1403
- });
1404
-
1405
- test('arrayLimit boundary conditions', function (t) {
1406
- // arrayLimit is the max number of elements allowed in an array
1407
- t.test('exactly at the limit stays as array', function (st) {
1408
- // 3 elements = limit of 3
1409
- var result = qs.parse('a[]=1&a[]=2&a[]=3', { arrayLimit: 3 });
1410
- st.ok(Array.isArray(result.a), 'result is an array when count equals limit');
1411
- st.deepEqual(result.a, ['1', '2', '3'], 'all values present');
1412
- st.end();
1413
- });
1414
-
1415
- t.test('one over the limit converts to object', function (st) {
1416
- // 4 elements exceeds limit of 3
1417
- var result = qs.parse('a[]=1&a[]=2&a[]=3&a[]=4', { arrayLimit: 3 });
1418
- st.notOk(Array.isArray(result.a), 'result is not an array when over limit');
1419
- st.deepEqual(result.a, { 0: '1', 1: '2', 2: '3', 3: '4' }, 'all values preserved as object');
1420
- st.end();
1421
- });
1422
-
1423
- t.test('arrayLimit 1 with one value', function (st) {
1424
- // 1 element = limit of 1
1425
- var result = qs.parse('a[]=1', { arrayLimit: 1 });
1426
- st.ok(Array.isArray(result.a), 'result is an array when count equals limit');
1427
- st.deepEqual(result.a, ['1'], 'value preserved as array');
1428
- st.end();
1429
- });
1430
-
1431
- t.test('arrayLimit 1 with two values converts to object', function (st) {
1432
- // 2 elements exceeds limit of 1
1433
- var result = qs.parse('a[]=1&a[]=2', { arrayLimit: 1 });
1434
- st.notOk(Array.isArray(result.a), 'result is not an array');
1435
- st.deepEqual(result.a, { 0: '1', 1: '2' }, 'all values preserved as object');
1436
- st.end();
1437
- });
1438
-
1439
- t.end();
1440
- });
1441
-
1442
- test('comma + arrayLimit', function (t) {
1443
- t.test('comma-separated values within arrayLimit stay as array', function (st) {
1444
- var result = qs.parse('a=1,2,3', { comma: true, arrayLimit: 5 });
1445
- st.ok(Array.isArray(result.a), 'result is an array');
1446
- st.deepEqual(result.a, ['1', '2', '3'], 'all values present');
1447
- st.end();
1448
- });
1449
-
1450
- t.test('comma-separated values exceeding arrayLimit convert to object', function (st) {
1451
- var result = qs.parse('a=1,2,3,4', { comma: true, arrayLimit: 3 });
1452
- st.notOk(Array.isArray(result.a), 'result is not an array when over limit');
1453
- st.deepEqual(result.a, { 0: '1', 1: '2', 2: '3', 3: '4' }, 'all values preserved as object');
1454
- st.end();
1455
- });
1456
-
1457
- t.test('comma-separated values exceeding arrayLimit with throwOnLimitExceeded throws', function (st) {
1458
- st['throws'](
1459
- function () {
1460
- qs.parse('a=1,2,3,4', { comma: true, arrayLimit: 3, throwOnLimitExceeded: true });
1461
- },
1462
- new RangeError('Array limit exceeded. Only 3 elements allowed in an array.'),
1463
- 'throws error when comma-split exceeds array limit'
1464
- );
1465
- st.end();
1466
- });
1467
-
1468
- t.test('comma-separated values at exactly arrayLimit stay as array', function (st) {
1469
- var result = qs.parse('a=1,2,3', { comma: true, arrayLimit: 3 });
1470
- st.ok(Array.isArray(result.a), 'result is an array when exactly at limit');
1471
- st.deepEqual(result.a, ['1', '2', '3'], 'all values present');
1472
- st.end();
1473
- });
1474
-
1475
- t.end();
1476
- });
1477
-
1478
- test('mixed array and object notation', function (t) {
1479
- t.test('array brackets with object key - under limit', function (st) {
1480
- st.deepEqual(
1481
- qs.parse('a[]=b&a[c]=d'),
1482
- { a: { 0: 'b', c: 'd' } },
1483
- 'mixing [] and [key] converts to object'
1484
- );
1485
- st.end();
1486
- });
1487
-
1488
- t.test('array index with object key - under limit', function (st) {
1489
- st.deepEqual(
1490
- qs.parse('a[0]=b&a[c]=d'),
1491
- { a: { 0: 'b', c: 'd' } },
1492
- 'mixing [0] and [key] produces object'
1493
- );
1494
- st.end();
1495
- });
1496
-
1497
- t.test('plain value with array brackets - under limit', function (st) {
1498
- st.deepEqual(
1499
- qs.parse('a=b&a[]=c', { arrayLimit: 20 }),
1500
- { a: ['b', 'c'] },
1501
- 'plain value combined with [] stays as array under limit'
1502
- );
1503
- st.end();
1504
- });
1505
-
1506
- t.test('array brackets with plain value - under limit', function (st) {
1507
- st.deepEqual(
1508
- qs.parse('a[]=b&a=c', { arrayLimit: 20 }),
1509
- { a: ['b', 'c'] },
1510
- '[] combined with plain value stays as array under limit'
1511
- );
1512
- st.end();
1513
- });
1514
-
1515
- t.test('plain value with array index - under limit', function (st) {
1516
- st.deepEqual(
1517
- qs.parse('a=b&a[0]=c', { arrayLimit: 20 }),
1518
- { a: ['b', 'c'] },
1519
- 'plain value combined with [0] stays as array under limit'
1520
- );
1521
- st.end();
1522
- });
1523
-
1524
- t.test('multiple plain values with duplicates combine', function (st) {
1525
- st.deepEqual(
1526
- qs.parse('a=b&a=c&a=d', { arrayLimit: 20 }),
1527
- { a: ['b', 'c', 'd'] },
1528
- 'duplicate plain keys combine into array'
1529
- );
1530
- st.end();
1531
- });
1532
-
1533
- t.test('multiple plain values exceeding limit', function (st) {
1534
- // 3 elements (indices 0-2), max index 2 > limit 1
1535
- st.deepEqual(
1536
- qs.parse('a=b&a=c&a=d', { arrayLimit: 1 }),
1537
- { a: { 0: 'b', 1: 'c', 2: 'd' } },
1538
- 'duplicate plain keys convert to object when exceeding limit'
1539
- );
1540
- st.end();
1541
- });
1542
-
1543
- t.test('mixed notation produces consistent results when arrayLimit is exceeded', function (st) {
1544
- var expected = { a: { 0: 'b', 1: 'c', 2: 'd' } };
1545
-
1546
- st.deepEqual(
1547
- qs.parse('a[]=b&a[1]=c&a=d', { arrayLimit: -1 }),
1548
- expected,
1549
- 'arrayLimit -1'
1550
- );
1551
-
1552
- st.deepEqual(
1553
- qs.parse('a[]=b&a[1]=c&a=d', { arrayLimit: 0 }),
1554
- expected,
1555
- 'arrayLimit 0'
1556
- );
1557
-
1558
- st.deepEqual(
1559
- qs.parse('a[]=b&a[1]=c&a=d', { arrayLimit: 1 }),
1560
- expected,
1561
- 'arrayLimit 1'
1562
- );
1563
-
1564
- st.end();
1565
- });
1566
-
1567
- t.end();
1568
- });