@contrast/agent-bundle 5.47.0 → 5.48.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 (526) hide show
  1. package/node_modules/@contrast/agent/package.json +10 -10
  2. package/node_modules/@contrast/agentify/package.json +14 -14
  3. package/node_modules/@contrast/architecture-components/package.json +4 -4
  4. package/node_modules/@contrast/assess/lib/configuration-analysis/install/apollo-server.js +1 -1
  5. package/node_modules/@contrast/assess/lib/configuration-analysis/install/graphql-yoga.js +1 -1
  6. package/node_modules/@contrast/assess/lib/dataflow/sinks/install/fs.js +8 -15
  7. package/node_modules/@contrast/assess/package.json +11 -11
  8. package/node_modules/@contrast/config/package.json +2 -2
  9. package/node_modules/@contrast/core/package.json +4 -4
  10. package/node_modules/@contrast/deadzones/package.json +4 -4
  11. package/node_modules/@contrast/dep-hooks/lib/export-handler-registry.js +1 -10
  12. package/node_modules/@contrast/dep-hooks/lib/export-hook-descriptor.js +1 -1
  13. package/node_modules/@contrast/dep-hooks/lib/index.d.ts +1 -1
  14. package/node_modules/@contrast/dep-hooks/lib/index.js +1 -1
  15. package/node_modules/@contrast/dep-hooks/lib/package-finder.d.ts +2 -1
  16. package/node_modules/@contrast/dep-hooks/lib/package-finder.js +11 -2
  17. package/node_modules/@contrast/dep-hooks/package.json +3 -3
  18. package/node_modules/@contrast/esm-hooks/package.json +5 -5
  19. package/node_modules/@contrast/instrumentation/package.json +4 -4
  20. package/node_modules/@contrast/library-analysis/lib/install/library-reporting/dep.json +144 -202
  21. package/node_modules/@contrast/library-analysis/package.json +3 -3
  22. package/node_modules/@contrast/logger/package.json +3 -3
  23. package/node_modules/@contrast/metrics/package.json +5 -5
  24. package/node_modules/@contrast/patcher/package.json +2 -2
  25. package/node_modules/@contrast/protect/lib/input-tracing/install/fs.js +0 -8
  26. package/node_modules/@contrast/protect/package.json +10 -10
  27. package/node_modules/@contrast/reporter/package.json +5 -5
  28. package/node_modules/@contrast/rewriter/package.json +4 -4
  29. package/node_modules/@contrast/route-coverage/lib/index.d.ts +2 -0
  30. package/node_modules/@contrast/route-coverage/lib/index.js +2 -1
  31. package/node_modules/@contrast/route-coverage/lib/install/express.js +535 -0
  32. package/node_modules/@contrast/route-coverage/lib/install/fastify/fastify-express.js +71 -0
  33. package/node_modules/@contrast/route-coverage/lib/install/fastify/fastify-middie.js +67 -0
  34. package/node_modules/@contrast/route-coverage/lib/install/{fastify.js → fastify/fastify.js} +12 -12
  35. package/node_modules/@contrast/route-coverage/lib/install/{express → fastify}/index.js +6 -5
  36. package/node_modules/@contrast/route-coverage/lib/install/koa.js +39 -45
  37. package/node_modules/@contrast/route-coverage/lib/utils/route-info.js +26 -1
  38. package/node_modules/@contrast/route-coverage/package.json +7 -7
  39. package/node_modules/@contrast/scopes/package.json +5 -5
  40. package/node_modules/@contrast/sec-obs/package.json +8 -8
  41. package/node_modules/@contrast/sources/package.json +2 -2
  42. package/node_modules/@contrast/telemetry/package.json +4 -4
  43. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_attributes.d.ts +697 -30
  44. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_attributes.js +697 -30
  45. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_attributes.js.map +1 -1
  46. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_events.d.ts +6 -0
  47. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_events.js +6 -0
  48. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_events.js.map +1 -1
  49. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_metrics.d.ts +877 -49
  50. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_metrics.js +877 -49
  51. package/node_modules/@opentelemetry/semantic-conventions/build/esm/experimental_metrics.js.map +1 -1
  52. package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_attributes.d.ts +13 -4
  53. package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_attributes.js +13 -4
  54. package/node_modules/@opentelemetry/semantic-conventions/build/esm/stable_attributes.js.map +1 -1
  55. package/node_modules/@opentelemetry/semantic-conventions/build/esm/version.d.ts +1 -1
  56. package/node_modules/@opentelemetry/semantic-conventions/build/esm/version.js +1 -1
  57. package/node_modules/@opentelemetry/semantic-conventions/build/esm/version.js.map +1 -1
  58. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_attributes.d.ts +697 -30
  59. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_attributes.js +697 -30
  60. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_attributes.js.map +1 -1
  61. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_events.d.ts +6 -0
  62. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_events.js +6 -0
  63. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_events.js.map +1 -1
  64. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_metrics.d.ts +877 -49
  65. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_metrics.js +877 -49
  66. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/experimental_metrics.js.map +1 -1
  67. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_attributes.d.ts +13 -4
  68. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_attributes.js +13 -4
  69. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/stable_attributes.js.map +1 -1
  70. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/version.d.ts +1 -1
  71. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/version.js +1 -1
  72. package/node_modules/@opentelemetry/semantic-conventions/build/esnext/version.js.map +1 -1
  73. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_attributes.d.ts +697 -30
  74. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_attributes.js +729 -61
  75. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_attributes.js.map +1 -1
  76. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_events.d.ts +6 -0
  77. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_events.js +7 -1
  78. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_events.js.map +1 -1
  79. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_metrics.d.ts +877 -49
  80. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_metrics.js +886 -56
  81. package/node_modules/@opentelemetry/semantic-conventions/build/src/experimental_metrics.js.map +1 -1
  82. package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_attributes.d.ts +13 -4
  83. package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_attributes.js +13 -4
  84. package/node_modules/@opentelemetry/semantic-conventions/build/src/stable_attributes.js.map +1 -1
  85. package/node_modules/@opentelemetry/semantic-conventions/build/src/version.d.ts +1 -1
  86. package/node_modules/@opentelemetry/semantic-conventions/build/src/version.js +1 -1
  87. package/node_modules/@opentelemetry/semantic-conventions/build/src/version.js.map +1 -1
  88. package/node_modules/@opentelemetry/semantic-conventions/package.json +3 -5
  89. package/node_modules/{pino → @pinojs/redact}/.github/dependabot.yml +1 -1
  90. package/node_modules/@pinojs/redact/.github/workflows/ci.yml +48 -0
  91. package/node_modules/@pinojs/redact/.github/workflows/publish-release.yml +43 -0
  92. package/node_modules/{abort-controller → @pinojs/redact}/LICENSE +1 -1
  93. package/node_modules/@pinojs/redact/README.md +350 -0
  94. package/node_modules/@pinojs/redact/benchmarks/basic.js +184 -0
  95. package/node_modules/@pinojs/redact/eslint.config.js +1 -0
  96. package/node_modules/@pinojs/redact/index.d.ts +52 -0
  97. package/node_modules/@pinojs/redact/index.js +529 -0
  98. package/node_modules/@pinojs/redact/index.test-d.ts +22 -0
  99. package/node_modules/@pinojs/redact/package.json +37 -0
  100. package/node_modules/@pinojs/redact/scripts/sync-version.mjs +20 -0
  101. package/node_modules/@pinojs/redact/test/actual-redact-comparison.test.js +211 -0
  102. package/node_modules/@pinojs/redact/test/index.test.js +824 -0
  103. package/node_modules/@pinojs/redact/test/integration.test.js +390 -0
  104. package/node_modules/@pinojs/redact/test/multiple-wildcards.test.js +227 -0
  105. package/node_modules/@pinojs/redact/test/prototype-pollution.test.js +223 -0
  106. package/node_modules/@pinojs/redact/test/selective-clone.test.js +115 -0
  107. package/node_modules/@pinojs/redact/tsconfig.json +19 -0
  108. package/node_modules/@types/node/README.md +1 -1
  109. package/node_modules/@types/node/console.d.ts +3 -2
  110. package/node_modules/@types/node/package.json +2 -2
  111. package/node_modules/@types/node/process.d.ts +7 -0
  112. package/node_modules/@types/node/sqlite.d.ts +107 -0
  113. package/node_modules/@types/node/url.d.ts +32 -8
  114. package/node_modules/axios/CHANGELOG.md +18 -0
  115. package/node_modules/axios/README.md +1 -4
  116. package/node_modules/axios/dist/axios.js +2 -2
  117. package/node_modules/axios/dist/axios.js.map +1 -1
  118. package/node_modules/axios/dist/axios.min.js +2 -2
  119. package/node_modules/axios/dist/axios.min.js.map +1 -1
  120. package/node_modules/axios/dist/browser/axios.cjs +2 -2
  121. package/node_modules/axios/dist/browser/axios.cjs.map +1 -1
  122. package/node_modules/axios/dist/esm/axios.js +2 -2
  123. package/node_modules/axios/dist/esm/axios.js.map +1 -1
  124. package/node_modules/axios/dist/esm/axios.min.js +2 -2
  125. package/node_modules/axios/dist/esm/axios.min.js.map +1 -1
  126. package/node_modules/axios/dist/node/axios.cjs +25 -20
  127. package/node_modules/axios/dist/node/axios.cjs.map +1 -1
  128. package/node_modules/axios/lib/adapters/http.js +22 -18
  129. package/node_modules/axios/lib/env/data.js +1 -1
  130. package/node_modules/axios/package.json +1 -1
  131. package/node_modules/form-data/CHANGELOG.md +60 -2
  132. package/node_modules/form-data/README.md +4 -4
  133. package/node_modules/form-data/lib/form_data.js +2 -2
  134. package/node_modules/form-data/package.json +4 -4
  135. package/node_modules/ipaddr.js/README.md +1 -0
  136. package/node_modules/ipaddr.js/ipaddr.min.js +1 -1
  137. package/node_modules/ipaddr.js/lib/ipaddr.js +11 -0
  138. package/node_modules/ipaddr.js/lib/ipaddr.js.d.ts +1 -0
  139. package/node_modules/ipaddr.js/package.json +2 -3
  140. package/node_modules/nan/.github/workflows/ci.yml +3 -1
  141. package/node_modules/nan/CHANGELOG.md +4 -1
  142. package/node_modules/nan/README.md +2 -2
  143. package/node_modules/nan/nan.h +25 -15
  144. package/node_modules/nan/nan_maybe_43_inl.h +5 -1
  145. package/node_modules/nan/package.json +2 -2
  146. package/node_modules/node-abi/abi_registry.json +8 -1
  147. package/node_modules/node-abi/package.json +1 -1
  148. package/node_modules/pino/CONTRIBUTING.md +4 -0
  149. package/node_modules/pino/LICENSE +1 -1
  150. package/node_modules/pino/README.md +20 -3
  151. package/node_modules/pino/benchmarks/basic.bench.js +1 -1
  152. package/node_modules/pino/benchmarks/child-child.bench.js +1 -1
  153. package/node_modules/pino/benchmarks/child-creation.bench.js +1 -1
  154. package/node_modules/pino/benchmarks/child.bench.js +1 -1
  155. package/node_modules/pino/benchmarks/deep-object.bench.js +1 -1
  156. package/node_modules/pino/benchmarks/internal/just-pino-heavy.bench.js +1 -1
  157. package/node_modules/pino/benchmarks/internal/just-pino.bench.js +1 -1
  158. package/node_modules/pino/benchmarks/internal/redact.bench.js +1 -1
  159. package/node_modules/pino/benchmarks/long-string.bench.js +1 -1
  160. package/node_modules/pino/benchmarks/multi-arg.bench.js +1 -1
  161. package/node_modules/pino/benchmarks/multistream.js +1 -1
  162. package/node_modules/pino/benchmarks/object.bench.js +1 -1
  163. package/node_modules/pino/benchmarks/utils/generate-benchmark-doc.js +2 -2
  164. package/node_modules/pino/benchmarks/utils/runbench.js +3 -3
  165. package/node_modules/pino/benchmarks/utils/wrap-log-level.js +2 -2
  166. package/node_modules/pino/browser.js +76 -36
  167. package/node_modules/pino/build/sync-version.js +18 -3
  168. package/node_modules/pino/docs/api.md +155 -13
  169. package/node_modules/pino/docs/browser.md +16 -1
  170. package/node_modules/pino/docs/bundling.md +5 -3
  171. package/node_modules/pino/docs/diagnostics.md +16 -0
  172. package/node_modules/pino/docs/ecosystem.md +15 -12
  173. package/node_modules/pino/docs/help.md +29 -3
  174. package/node_modules/pino/docs/lts.md +5 -4
  175. package/node_modules/pino/docs/transports.md +442 -271
  176. package/node_modules/pino/docs/web.md +59 -9
  177. package/node_modules/pino/eslint.config.js +19 -0
  178. package/node_modules/pino/examples/transport.js +2 -2
  179. package/node_modules/pino/file.js +1 -1
  180. package/node_modules/pino/lib/meta.js +1 -1
  181. package/node_modules/pino/lib/multistream.js +17 -2
  182. package/node_modules/pino/lib/proto.js +35 -11
  183. package/node_modules/pino/lib/redaction.js +9 -13
  184. package/node_modules/pino/lib/time.js +29 -1
  185. package/node_modules/pino/lib/tools.js +37 -8
  186. package/node_modules/pino/lib/transport-stream.js +10 -4
  187. package/node_modules/pino/lib/transport.js +23 -9
  188. package/node_modules/pino/lib/worker.js +164 -24
  189. package/node_modules/pino/package.json +28 -27
  190. package/node_modules/pino/pino.d.ts +244 -203
  191. package/node_modules/pino/pino.js +7 -3
  192. package/node_modules/pino/test/basic.test.js +181 -169
  193. package/node_modules/pino/test/broken-pipe.test.js +18 -16
  194. package/node_modules/pino/test/browser-child.test.js +26 -0
  195. package/node_modules/pino/test/browser-is-level-enabled.test.js +101 -0
  196. package/node_modules/pino/test/browser-serializers.test.js +0 -2
  197. package/node_modules/pino/test/browser-transmit.test.js +68 -0
  198. package/node_modules/pino/test/browser.test.js +98 -13
  199. package/node_modules/pino/test/complex-objects.test.js +8 -6
  200. package/node_modules/pino/test/crlf.test.js +7 -5
  201. package/node_modules/pino/test/custom-levels.test.js +80 -66
  202. package/node_modules/pino/test/diagnostics.test.js +107 -0
  203. package/node_modules/pino/test/error-key.test.js +37 -0
  204. package/node_modules/pino/test/error.test.js +48 -43
  205. package/node_modules/pino/test/escaping.test.js +8 -6
  206. package/node_modules/pino/test/esm/esm.mjs +5 -3
  207. package/node_modules/pino/test/esm/index.test.js +14 -27
  208. package/node_modules/pino/test/esm/named-exports.mjs +9 -8
  209. package/node_modules/pino/test/exit.test.js +18 -16
  210. package/node_modules/pino/test/fixtures/broken-pipe/basic.js +1 -1
  211. package/node_modules/pino/test/fixtures/broken-pipe/destination.js +1 -1
  212. package/node_modules/pino/test/fixtures/broken-pipe/syncfalse.js +1 -1
  213. package/node_modules/pino/test/fixtures/console-transport.js +1 -1
  214. package/node_modules/pino/test/fixtures/crashing-transport.js +13 -0
  215. package/node_modules/pino/test/fixtures/default-exit.js +1 -1
  216. package/node_modules/pino/test/fixtures/destination-exit.js +1 -1
  217. package/node_modules/pino/test/fixtures/noop-transport.js +1 -1
  218. package/node_modules/pino/test/fixtures/pretty/null-prototype.js +1 -1
  219. package/node_modules/pino/test/fixtures/stdout-hack-protection.js +1 -1
  220. package/node_modules/pino/test/fixtures/syncfalse-child.js +1 -1
  221. package/node_modules/pino/test/fixtures/syncfalse-exit.js +1 -1
  222. package/node_modules/pino/test/fixtures/syncfalse-flush-exit.js +1 -1
  223. package/node_modules/pino/test/fixtures/syncfalse.js +1 -1
  224. package/node_modules/pino/test/fixtures/syntax-error-esm.mjs +2 -0
  225. package/node_modules/pino/test/fixtures/to-file-transport-with-transform.js +3 -3
  226. package/node_modules/pino/test/fixtures/to-file-transport.js +2 -2
  227. package/node_modules/pino/test/fixtures/to-file-transport.mjs +2 -2
  228. package/node_modules/pino/test/fixtures/transport/index.js +2 -2
  229. package/node_modules/pino/test/fixtures/transport-main.js +1 -1
  230. package/node_modules/pino/test/fixtures/transport-transform.js +1 -1
  231. package/node_modules/pino/test/fixtures/transport-uses-pino-config.js +1 -1
  232. package/node_modules/pino/test/fixtures/transport-worker-data.js +1 -1
  233. package/node_modules/pino/test/fixtures/transport-worker.js +2 -2
  234. package/node_modules/pino/test/fixtures/ts/to-file-transport-with-transform.ts +3 -3
  235. package/node_modules/pino/test/fixtures/ts/to-file-transport.ts +2 -2
  236. package/node_modules/pino/test/fixtures/ts/transpile.cjs +1 -1
  237. package/node_modules/pino/test/fixtures/ts/transport-exit-immediately-with-async-dest.ts +1 -1
  238. package/node_modules/pino/test/fixtures/ts/transport-main.ts +1 -1
  239. package/node_modules/pino/test/fixtures/ts/transport-worker.ts +1 -1
  240. package/node_modules/pino/test/formatters.test.js +46 -37
  241. package/node_modules/pino/test/helper.d.ts +1 -1
  242. package/node_modules/pino/test/helper.js +37 -10
  243. package/node_modules/pino/test/hooks.test.js +45 -28
  244. package/node_modules/pino/test/http.test.js +39 -67
  245. package/node_modules/pino/test/internals/version.test.js +11 -9
  246. package/node_modules/pino/test/is-level-enabled.test.js +66 -72
  247. package/node_modules/pino/test/levels.test.js +245 -141
  248. package/node_modules/pino/test/metadata.test.js +45 -31
  249. package/node_modules/pino/test/mixin-merge-strategy.test.js +9 -7
  250. package/node_modules/pino/test/mixin.test.js +63 -40
  251. package/node_modules/pino/test/multistream.test.js +174 -118
  252. package/node_modules/pino/test/redact.test.js +172 -126
  253. package/node_modules/pino/test/serializers.test.js +61 -57
  254. package/node_modules/pino/test/stdout-protection.test.js +14 -12
  255. package/node_modules/pino/test/syncfalse.test.js +29 -34
  256. package/node_modules/pino/test/timestamp-nano.test.js +37 -0
  257. package/node_modules/pino/test/timestamp.test.js +37 -34
  258. package/node_modules/pino/test/transport/big.test.js +11 -12
  259. package/node_modules/pino/test/transport/bundlers-support.test.js +15 -43
  260. package/node_modules/pino/test/transport/caller.test.js +9 -8
  261. package/node_modules/pino/test/transport/core.test.js +175 -145
  262. package/node_modules/pino/test/transport/core.transpiled.test.ts +17 -19
  263. package/node_modules/pino/test/transport/crash.test.js +36 -0
  264. package/node_modules/pino/test/transport/module-link.test.js +21 -19
  265. package/node_modules/pino/test/transport/pipeline.test.js +109 -8
  266. package/node_modules/pino/test/transport/repl.test.js +4 -3
  267. package/node_modules/pino/test/transport/{syncfalse.test.js → sync-false.test.js} +14 -12
  268. package/node_modules/pino/test/transport/sync-true.test.js +57 -0
  269. package/node_modules/pino/test/transport/targets.test.js +25 -5
  270. package/node_modules/pino/test/transport/uses-pino-config.test.js +16 -17
  271. package/node_modules/pino/test/transport-stream.test.js +40 -0
  272. package/node_modules/pino/test/types/{pino-import.test-d.ts → pino-import.test-d.cts} +4 -3
  273. package/node_modules/pino/test/types/pino-multistream.test-d.ts +1 -1
  274. package/node_modules/pino/test/types/pino-top-export.test-d.ts +1 -0
  275. package/node_modules/pino/test/types/pino-transport.test-d.ts +1 -1
  276. package/node_modules/pino/test/types/pino-type-only.test-d.ts +24 -6
  277. package/node_modules/pino/test/types/pino.test-d.ts +161 -6
  278. package/node_modules/pino/test/types/pino.ts +31 -19
  279. package/node_modules/pino/tsconfig.json +1 -1
  280. package/node_modules/pino-abstract-transport/.github/workflows/ci.yml +2 -4
  281. package/node_modules/pino-abstract-transport/index.js +1 -1
  282. package/node_modules/pino-abstract-transport/package.json +2 -3
  283. package/node_modules/pino-abstract-transport/test/base.test.js +1 -1
  284. package/node_modules/pino-abstract-transport/test/worker.test.js +7 -14
  285. package/node_modules/pino-std-serializers/.github/workflows/ci.yml +5 -5
  286. package/node_modules/pino-std-serializers/Readme.md +1 -0
  287. package/node_modules/pino-std-serializers/package.json +9 -8
  288. package/node_modules/pino-std-serializers/test/err-with-cause.test.js +72 -88
  289. package/node_modules/pino-std-serializers/test/err.test.js +76 -91
  290. package/node_modules/pino-std-serializers/test/req.test.js +142 -98
  291. package/node_modules/pino-std-serializers/test/res.test.js +42 -31
  292. package/node_modules/process-warning/.github/dependabot.yml +1 -1
  293. package/node_modules/process-warning/.github/workflows/ci.yml +1 -2
  294. package/node_modules/process-warning/README.md +4 -4
  295. package/node_modules/process-warning/eslint.config.js +6 -0
  296. package/node_modules/process-warning/package.json +39 -8
  297. package/node_modules/process-warning/test/emit-interpolated-string.test.js +11 -6
  298. package/node_modules/process-warning/test/emit-once-only.test.js +11 -6
  299. package/node_modules/process-warning/test/emit-reset.test.js +10 -6
  300. package/node_modules/process-warning/test/emit-set.test.js +10 -5
  301. package/node_modules/process-warning/test/emit-unlimited.test.js +12 -7
  302. package/node_modules/process-warning/test/index.test.js +20 -20
  303. package/node_modules/process-warning/test/issue-88.test.js +8 -3
  304. package/node_modules/process-warning/test/jest.test.js +17 -15
  305. package/node_modules/process-warning/test/no-warnings.test.js +9 -9
  306. package/node_modules/process-warning/test/promise.js +10 -0
  307. package/node_modules/process-warning/types/index.d.ts +5 -5
  308. package/node_modules/thread-stream/.github/workflows/ci.yml +4 -8
  309. package/node_modules/thread-stream/index.d.ts +4 -5
  310. package/node_modules/thread-stream/lib/worker.js +5 -2
  311. package/node_modules/thread-stream/package.json +6 -4
  312. package/node_modules/thread-stream/test/base.test.js +12 -0
  313. package/node_modules/thread-stream/test/never-drain.test.js +3 -1
  314. package/node_modules/thread-stream/test/pkg/pkg.test.js +2 -0
  315. package/node_modules/thread-stream/test/syntax-error.mjs +2 -0
  316. package/node_modules/thread-stream/tsconfig.json +8 -0
  317. package/node_modules/yaml/browser/dist/compose/compose-collection.js +1 -1
  318. package/node_modules/yaml/browser/dist/compose/resolve-block-seq.js +1 -1
  319. package/node_modules/yaml/browser/dist/compose/resolve-flow-collection.js +2 -2
  320. package/node_modules/yaml/browser/dist/errors.js +1 -1
  321. package/node_modules/yaml/browser/dist/nodes/Alias.js +1 -1
  322. package/node_modules/yaml/browser/dist/parse/parser.js +2 -2
  323. package/node_modules/yaml/browser/dist/stringify/stringifyNumber.js +1 -1
  324. package/node_modules/yaml/browser/dist/stringify/stringifyPair.js +1 -1
  325. package/node_modules/yaml/dist/compose/compose-collection.js +1 -1
  326. package/node_modules/yaml/dist/compose/resolve-block-seq.js +1 -1
  327. package/node_modules/yaml/dist/compose/resolve-flow-collection.js +2 -2
  328. package/node_modules/yaml/dist/errors.js +1 -1
  329. package/node_modules/yaml/dist/nodes/Alias.js +1 -1
  330. package/node_modules/yaml/dist/parse/parser.js +2 -2
  331. package/node_modules/yaml/dist/stringify/stringifyNumber.js +1 -1
  332. package/node_modules/yaml/dist/stringify/stringifyPair.js +1 -1
  333. package/node_modules/yaml/package.json +4 -4
  334. package/package.json +2 -2
  335. package/node_modules/@contrast/route-coverage/lib/install/express/express4.js +0 -157
  336. package/node_modules/@contrast/route-coverage/lib/install/express/express5.js +0 -553
  337. package/node_modules/abort-controller/README.md +0 -98
  338. package/node_modules/abort-controller/browser.js +0 -13
  339. package/node_modules/abort-controller/browser.mjs +0 -11
  340. package/node_modules/abort-controller/dist/abort-controller.d.ts +0 -43
  341. package/node_modules/abort-controller/dist/abort-controller.js +0 -127
  342. package/node_modules/abort-controller/dist/abort-controller.js.map +0 -1
  343. package/node_modules/abort-controller/dist/abort-controller.mjs +0 -118
  344. package/node_modules/abort-controller/dist/abort-controller.mjs.map +0 -1
  345. package/node_modules/abort-controller/dist/abort-controller.umd.js +0 -5
  346. package/node_modules/abort-controller/dist/abort-controller.umd.js.map +0 -1
  347. package/node_modules/abort-controller/package.json +0 -97
  348. package/node_modules/abort-controller/polyfill.js +0 -21
  349. package/node_modules/abort-controller/polyfill.mjs +0 -19
  350. package/node_modules/base64-js/LICENSE +0 -21
  351. package/node_modules/base64-js/README.md +0 -34
  352. package/node_modules/base64-js/base64js.min.js +0 -1
  353. package/node_modules/base64-js/index.d.ts +0 -3
  354. package/node_modules/base64-js/index.js +0 -150
  355. package/node_modules/base64-js/package.json +0 -47
  356. package/node_modules/buffer/AUTHORS.md +0 -73
  357. package/node_modules/buffer/LICENSE +0 -21
  358. package/node_modules/buffer/README.md +0 -410
  359. package/node_modules/buffer/index.d.ts +0 -194
  360. package/node_modules/buffer/index.js +0 -2106
  361. package/node_modules/buffer/package.json +0 -93
  362. package/node_modules/event-target-shim/LICENSE +0 -22
  363. package/node_modules/event-target-shim/README.md +0 -293
  364. package/node_modules/event-target-shim/dist/event-target-shim.js +0 -871
  365. package/node_modules/event-target-shim/dist/event-target-shim.js.map +0 -1
  366. package/node_modules/event-target-shim/dist/event-target-shim.mjs +0 -862
  367. package/node_modules/event-target-shim/dist/event-target-shim.mjs.map +0 -1
  368. package/node_modules/event-target-shim/dist/event-target-shim.umd.js +0 -6
  369. package/node_modules/event-target-shim/dist/event-target-shim.umd.js.map +0 -1
  370. package/node_modules/event-target-shim/index.d.ts +0 -399
  371. package/node_modules/event-target-shim/package.json +0 -82
  372. package/node_modules/events/.airtap.yml +0 -15
  373. package/node_modules/events/.github/FUNDING.yml +0 -12
  374. package/node_modules/events/.travis.yml +0 -18
  375. package/node_modules/events/History.md +0 -118
  376. package/node_modules/events/LICENSE +0 -22
  377. package/node_modules/events/Readme.md +0 -50
  378. package/node_modules/events/events.js +0 -497
  379. package/node_modules/events/package.json +0 -37
  380. package/node_modules/events/security.md +0 -10
  381. package/node_modules/events/tests/add-listeners.js +0 -111
  382. package/node_modules/events/tests/check-listener-leaks.js +0 -101
  383. package/node_modules/events/tests/common.js +0 -104
  384. package/node_modules/events/tests/errors.js +0 -13
  385. package/node_modules/events/tests/events-list.js +0 -28
  386. package/node_modules/events/tests/events-once.js +0 -234
  387. package/node_modules/events/tests/index.js +0 -64
  388. package/node_modules/events/tests/legacy-compat.js +0 -16
  389. package/node_modules/events/tests/listener-count.js +0 -37
  390. package/node_modules/events/tests/listeners-side-effects.js +0 -56
  391. package/node_modules/events/tests/listeners.js +0 -168
  392. package/node_modules/events/tests/max-listeners.js +0 -47
  393. package/node_modules/events/tests/method-names.js +0 -35
  394. package/node_modules/events/tests/modify-in-emit.js +0 -90
  395. package/node_modules/events/tests/num-args.js +0 -60
  396. package/node_modules/events/tests/once.js +0 -83
  397. package/node_modules/events/tests/prepend.js +0 -31
  398. package/node_modules/events/tests/remove-all-listeners.js +0 -133
  399. package/node_modules/events/tests/remove-listeners.js +0 -212
  400. package/node_modules/events/tests/set-max-listeners-side-effects.js +0 -31
  401. package/node_modules/events/tests/special-event-names.js +0 -45
  402. package/node_modules/events/tests/subclass.js +0 -66
  403. package/node_modules/events/tests/symbols.js +0 -25
  404. package/node_modules/fast-redact/.github/workflows/ci.yml +0 -37
  405. package/node_modules/fast-redact/LICENSE +0 -21
  406. package/node_modules/fast-redact/benchmark/index.js +0 -223
  407. package/node_modules/fast-redact/example/default-usage.js +0 -14
  408. package/node_modules/fast-redact/example/intermediate-wildcard-array.js +0 -11
  409. package/node_modules/fast-redact/example/multi-wildcard-array-depth.js +0 -11
  410. package/node_modules/fast-redact/example/multi-wildcard-array-end.js +0 -11
  411. package/node_modules/fast-redact/example/multi-wildcard-array.js +0 -11
  412. package/node_modules/fast-redact/example/serialize-false.js +0 -11
  413. package/node_modules/fast-redact/example/serialize-function.js +0 -4
  414. package/node_modules/fast-redact/example/top-wildcard-object.js +0 -9
  415. package/node_modules/fast-redact/index.js +0 -56
  416. package/node_modules/fast-redact/lib/modifiers.js +0 -291
  417. package/node_modules/fast-redact/lib/parse.js +0 -44
  418. package/node_modules/fast-redact/lib/redactor.js +0 -108
  419. package/node_modules/fast-redact/lib/restorer.js +0 -92
  420. package/node_modules/fast-redact/lib/rx.js +0 -16
  421. package/node_modules/fast-redact/lib/state.js +0 -20
  422. package/node_modules/fast-redact/lib/validator.js +0 -33
  423. package/node_modules/fast-redact/package.json +0 -50
  424. package/node_modules/fast-redact/readme.md +0 -282
  425. package/node_modules/fast-redact/test/index.js +0 -1502
  426. package/node_modules/ieee754/LICENSE +0 -11
  427. package/node_modules/ieee754/README.md +0 -51
  428. package/node_modules/ieee754/index.d.ts +0 -10
  429. package/node_modules/ieee754/index.js +0 -85
  430. package/node_modules/ieee754/package.json +0 -52
  431. package/node_modules/pino/.eslintignore +0 -2
  432. package/node_modules/pino/.eslintrc +0 -8
  433. package/node_modules/pino/.github/workflows/bench.yml +0 -61
  434. package/node_modules/pino/.github/workflows/ci.yml +0 -86
  435. package/node_modules/pino/.github/workflows/lock-threads.yml +0 -30
  436. package/node_modules/pino/.github/workflows/package-manager-ci.yml +0 -99
  437. package/node_modules/pino/.github/workflows/target-main.yml +0 -23
  438. package/node_modules/pino/.taprc.yaml +0 -8
  439. package/node_modules/pino/docsify/sidebar.md +0 -26
  440. package/node_modules/pino/favicon-16x16.png +0 -0
  441. package/node_modules/pino/favicon-32x32.png +0 -0
  442. package/node_modules/pino/lib/worker-pipeline.js +0 -38
  443. package/node_modules/pino/node_modules/sonic-boom/.eslintignore +0 -2
  444. package/node_modules/pino/node_modules/sonic-boom/.husky/pre-commit +0 -4
  445. package/node_modules/pino/node_modules/sonic-boom/.taprc.yaml +0 -11
  446. package/node_modules/pino/node_modules/sonic-boom/LICENSE +0 -21
  447. package/node_modules/pino/node_modules/sonic-boom/README.md +0 -151
  448. package/node_modules/pino/node_modules/sonic-boom/bench.js +0 -98
  449. package/node_modules/pino/node_modules/sonic-boom/check.js +0 -18
  450. package/node_modules/pino/node_modules/sonic-boom/example.js +0 -8
  451. package/node_modules/pino/node_modules/sonic-boom/fixtures/firehose.js +0 -22
  452. package/node_modules/pino/node_modules/sonic-boom/index.js +0 -690
  453. package/node_modules/pino/node_modules/sonic-boom/package.json +0 -50
  454. package/node_modules/pino/node_modules/sonic-boom/test/destroy.test.js +0 -49
  455. package/node_modules/pino/node_modules/sonic-boom/test/end.test.js +0 -98
  456. package/node_modules/pino/node_modules/sonic-boom/test/flush-sync.test.js +0 -140
  457. package/node_modules/pino/node_modules/sonic-boom/test/flush.test.js +0 -419
  458. package/node_modules/pino/node_modules/sonic-boom/test/fsync.test.js +0 -63
  459. package/node_modules/pino/node_modules/sonic-boom/test/helper.js +0 -42
  460. package/node_modules/pino/node_modules/sonic-boom/test/minlength.test.js +0 -35
  461. package/node_modules/pino/node_modules/sonic-boom/test/mode.test.js +0 -116
  462. package/node_modules/pino/node_modules/sonic-boom/test/reopen.test.js +0 -239
  463. package/node_modules/pino/node_modules/sonic-boom/test/retry.test.js +0 -414
  464. package/node_modules/pino/node_modules/sonic-boom/test/sync.test.js +0 -261
  465. package/node_modules/pino/node_modules/sonic-boom/test/write.test.js +0 -465
  466. package/node_modules/pino/node_modules/sonic-boom/types/index.d.ts +0 -62
  467. package/node_modules/pino/node_modules/sonic-boom/types/tests/test.ts +0 -4
  468. package/node_modules/pino/pino-banner.png +0 -0
  469. package/node_modules/pino/pino-logo-hire.png +0 -0
  470. package/node_modules/pino/pino-tree.png +0 -0
  471. package/node_modules/pino/pretty-demo.png +0 -0
  472. package/node_modules/pino/test/errorKey.test.js +0 -34
  473. package/node_modules/pino/test/transport/core.test.ts +0 -236
  474. package/node_modules/pino-std-serializers/.taprc +0 -2
  475. package/node_modules/process/.eslintrc +0 -21
  476. package/node_modules/process/LICENSE +0 -22
  477. package/node_modules/process/README.md +0 -26
  478. package/node_modules/process/browser.js +0 -184
  479. package/node_modules/process/index.js +0 -2
  480. package/node_modules/process/package.json +0 -27
  481. package/node_modules/process/test.js +0 -199
  482. package/node_modules/process-warning/.taprc +0 -2
  483. package/node_modules/readable-stream/LICENSE +0 -47
  484. package/node_modules/readable-stream/README.md +0 -116
  485. package/node_modules/readable-stream/lib/_stream_duplex.js +0 -4
  486. package/node_modules/readable-stream/lib/_stream_passthrough.js +0 -4
  487. package/node_modules/readable-stream/lib/_stream_readable.js +0 -4
  488. package/node_modules/readable-stream/lib/_stream_transform.js +0 -4
  489. package/node_modules/readable-stream/lib/_stream_writable.js +0 -4
  490. package/node_modules/readable-stream/lib/internal/streams/add-abort-signal.js +0 -52
  491. package/node_modules/readable-stream/lib/internal/streams/buffer_list.js +0 -157
  492. package/node_modules/readable-stream/lib/internal/streams/compose.js +0 -194
  493. package/node_modules/readable-stream/lib/internal/streams/destroy.js +0 -290
  494. package/node_modules/readable-stream/lib/internal/streams/duplex.js +0 -143
  495. package/node_modules/readable-stream/lib/internal/streams/duplexify.js +0 -378
  496. package/node_modules/readable-stream/lib/internal/streams/end-of-stream.js +0 -286
  497. package/node_modules/readable-stream/lib/internal/streams/from.js +0 -98
  498. package/node_modules/readable-stream/lib/internal/streams/lazy_transform.js +0 -51
  499. package/node_modules/readable-stream/lib/internal/streams/legacy.js +0 -89
  500. package/node_modules/readable-stream/lib/internal/streams/operators.js +0 -457
  501. package/node_modules/readable-stream/lib/internal/streams/passthrough.js +0 -39
  502. package/node_modules/readable-stream/lib/internal/streams/pipeline.js +0 -471
  503. package/node_modules/readable-stream/lib/internal/streams/readable.js +0 -1290
  504. package/node_modules/readable-stream/lib/internal/streams/state.js +0 -39
  505. package/node_modules/readable-stream/lib/internal/streams/transform.js +0 -180
  506. package/node_modules/readable-stream/lib/internal/streams/utils.js +0 -327
  507. package/node_modules/readable-stream/lib/internal/streams/writable.js +0 -819
  508. package/node_modules/readable-stream/lib/internal/validators.js +0 -530
  509. package/node_modules/readable-stream/lib/ours/browser.js +0 -35
  510. package/node_modules/readable-stream/lib/ours/errors.js +0 -343
  511. package/node_modules/readable-stream/lib/ours/index.js +0 -65
  512. package/node_modules/readable-stream/lib/ours/primordials.js +0 -124
  513. package/node_modules/readable-stream/lib/ours/util/inspect.js +0 -55
  514. package/node_modules/readable-stream/lib/ours/util.js +0 -148
  515. package/node_modules/readable-stream/lib/stream/promises.js +0 -43
  516. package/node_modules/readable-stream/lib/stream.js +0 -143
  517. package/node_modules/readable-stream/package.json +0 -88
  518. package/node_modules/safe-buffer/LICENSE +0 -21
  519. package/node_modules/safe-buffer/README.md +0 -584
  520. package/node_modules/safe-buffer/index.d.ts +0 -187
  521. package/node_modules/safe-buffer/index.js +0 -65
  522. package/node_modules/safe-buffer/package.json +0 -51
  523. package/node_modules/string_decoder/LICENSE +0 -48
  524. package/node_modules/string_decoder/README.md +0 -47
  525. package/node_modules/string_decoder/lib/string_decoder.js +0 -296
  526. package/node_modules/string_decoder/package.json +0 -34
@@ -1,261 +0,0 @@
1
- 'use strict'
2
-
3
- const { test } = require('tap')
4
- const fs = require('fs')
5
- const proxyquire = require('proxyquire')
6
- const SonicBoom = require('../')
7
- const { file } = require('./helper')
8
-
9
- test('write buffers that are not totally written with sync mode', (t) => {
10
- t.plan(9)
11
-
12
- const fakeFs = Object.create(fs)
13
- fakeFs.writeSync = function (fd, buf, enc) {
14
- t.pass('fake fs.write called')
15
- fakeFs.writeSync = (fd, buf, enc) => {
16
- t.pass('calling real fs.writeSync, ' + buf)
17
- return fs.writeSync(fd, buf, enc)
18
- }
19
- return 0
20
- }
21
- const SonicBoom = proxyquire('../', {
22
- fs: fakeFs
23
- })
24
-
25
- const dest = file()
26
- const fd = fs.openSync(dest, 'w')
27
- const stream = new SonicBoom({ fd, minLength: 0, sync: true })
28
-
29
- stream.on('ready', () => {
30
- t.pass('ready emitted')
31
- })
32
-
33
- t.ok(stream.write('hello world\n'))
34
- t.ok(stream.write('something else\n'))
35
-
36
- stream.end()
37
-
38
- stream.on('finish', () => {
39
- fs.readFile(dest, 'utf8', (err, data) => {
40
- t.error(err)
41
- t.equal(data, 'hello world\nsomething else\n')
42
- })
43
- })
44
- stream.on('close', () => {
45
- t.pass('close emitted')
46
- })
47
- })
48
-
49
- test('write buffers that are not totally written with flush sync', (t) => {
50
- t.plan(7)
51
-
52
- const fakeFs = Object.create(fs)
53
- fakeFs.writeSync = function (fd, buf, enc) {
54
- t.pass('fake fs.write called')
55
- fakeFs.writeSync = fs.writeSync
56
- return 0
57
- }
58
- const SonicBoom = proxyquire('../', {
59
- fs: fakeFs
60
- })
61
-
62
- const dest = file()
63
- const fd = fs.openSync(dest, 'w')
64
- const stream = new SonicBoom({ fd, minLength: 100, sync: false })
65
-
66
- stream.on('ready', () => {
67
- t.pass('ready emitted')
68
- })
69
-
70
- t.ok(stream.write('hello world\n'))
71
- t.ok(stream.write('something else\n'))
72
-
73
- stream.flushSync()
74
-
75
- stream.on('write', (n) => {
76
- if (n === 0) {
77
- t.fail('throwing to avoid infinite loop')
78
- throw Error('shouldn\'t call write handler after flushing with n === 0')
79
- }
80
- })
81
-
82
- stream.end()
83
-
84
- stream.on('finish', () => {
85
- fs.readFile(dest, 'utf8', (err, data) => {
86
- t.error(err)
87
- t.equal(data, 'hello world\nsomething else\n')
88
- })
89
- })
90
- stream.on('close', () => {
91
- t.pass('close emitted')
92
- })
93
- })
94
-
95
- test('sync writing is fully sync', (t) => {
96
- t.plan(6)
97
-
98
- const fakeFs = Object.create(fs)
99
- fakeFs.writeSync = function (fd, buf, enc, cb) {
100
- t.pass('fake fs.write called')
101
- return fs.writeSync(fd, buf, enc)
102
- }
103
- const SonicBoom = proxyquire('../', {
104
- fs: fakeFs
105
- })
106
-
107
- const dest = file()
108
- const fd = fs.openSync(dest, 'w')
109
- const stream = new SonicBoom({ fd, minLength: 0, sync: true })
110
- t.ok(stream.write('hello world\n'))
111
- t.ok(stream.write('something else\n'))
112
-
113
- // 'drain' will be only emitted once,
114
- // the number of assertions at the top check this.
115
- stream.on('drain', () => {
116
- t.pass('drain emitted')
117
- })
118
-
119
- const data = fs.readFileSync(dest, 'utf8')
120
- t.equal(data, 'hello world\nsomething else\n')
121
- })
122
-
123
- test('write enormously large buffers sync', (t) => {
124
- t.plan(3)
125
-
126
- const dest = file()
127
- const fd = fs.openSync(dest, 'w')
128
- const stream = new SonicBoom({ fd, minLength: 0, sync: true })
129
-
130
- const buf = Buffer.alloc(1024).fill('x').toString() // 1 MB
131
- let length = 0
132
-
133
- for (let i = 0; i < 1024 * 512; i++) {
134
- length += buf.length
135
- stream.write(buf)
136
- }
137
-
138
- stream.end()
139
-
140
- stream.on('finish', () => {
141
- fs.stat(dest, (err, stat) => {
142
- t.error(err)
143
- t.equal(stat.size, length)
144
- })
145
- })
146
- stream.on('close', () => {
147
- t.pass('close emitted')
148
- })
149
- })
150
-
151
- test('write enormously large buffers sync with utf8 multi-byte split', (t) => {
152
- t.plan(4)
153
-
154
- const dest = file()
155
- const fd = fs.openSync(dest, 'w')
156
- const stream = new SonicBoom({ fd, minLength: 0, sync: true })
157
-
158
- let buf = Buffer.alloc((1024 * 16) - 2).fill('x') // 16MB - 3B
159
- const length = buf.length + 4
160
- buf = buf.toString() + '🌲' // 16 MB + 1B
161
-
162
- stream.write(buf)
163
-
164
- stream.end()
165
-
166
- stream.on('finish', () => {
167
- fs.stat(dest, (err, stat) => {
168
- t.error(err)
169
- t.equal(stat.size, length)
170
- const char = Buffer.alloc(4)
171
- const fd = fs.openSync(dest, 'r')
172
- fs.readSync(fd, char, 0, 4, length - 4)
173
- t.equal(char.toString(), '🌲')
174
- })
175
- })
176
- stream.on('close', () => {
177
- t.pass('close emitted')
178
- })
179
- })
180
-
181
- // for context see this issue https://github.com/pinojs/pino/issues/871
182
- test('file specified by dest path available immediately when options.sync is true', (t) => {
183
- t.plan(3)
184
- const dest = file()
185
- const stream = new SonicBoom({ dest, sync: true })
186
- t.ok(stream.write('hello world\n'))
187
- t.ok(stream.write('something else\n'))
188
- stream.flushSync()
189
- t.pass('file opened and written to without error')
190
- })
191
-
192
- test('sync error handling', (t) => {
193
- t.plan(1)
194
- try {
195
- /* eslint no-new: off */
196
- new SonicBoom({ dest: '/path/to/nowwhere', sync: true })
197
- t.fail('must throw synchronously')
198
- } catch (err) {
199
- t.pass('an error happened')
200
- }
201
- })
202
-
203
- for (const fd of [1, 2]) {
204
- test(`fd ${fd}`, (t) => {
205
- t.plan(1)
206
-
207
- const fakeFs = Object.create(fs)
208
- const SonicBoom = proxyquire('../', {
209
- fs: fakeFs
210
- })
211
-
212
- const stream = new SonicBoom({ fd })
213
-
214
- fakeFs.close = function (fd, cb) {
215
- t.fail(`should not close fd ${fd}`)
216
- }
217
-
218
- stream.end()
219
-
220
- stream.on('close', () => {
221
- t.pass('close emitted')
222
- })
223
- })
224
- }
225
-
226
- test('._len must always be equal or greater than 0', (t) => {
227
- t.plan(3)
228
-
229
- const dest = file()
230
- const fd = fs.openSync(dest, 'w')
231
- const stream = new SonicBoom({ fd, sync: true })
232
-
233
- t.ok(stream.write('hello world 👀\n'))
234
- t.ok(stream.write('another line 👀\n'))
235
-
236
- t.equal(stream._len, 0)
237
-
238
- stream.end()
239
- })
240
-
241
- test('._len must always be equal or greater than 0', (t) => {
242
- const n = 20
243
- t.plan(n + 3)
244
-
245
- const dest = file()
246
- const fd = fs.openSync(dest, 'w')
247
- const stream = new SonicBoom({ fd, sync: true, minLength: 20 })
248
-
249
- let str = ''
250
- for (let i = 0; i < 20; i++) {
251
- t.ok(stream.write('👀'))
252
- str += '👀'
253
- }
254
-
255
- t.equal(stream._len, 0)
256
-
257
- fs.readFile(dest, 'utf8', (err, data) => {
258
- t.error(err)
259
- t.equal(data, str)
260
- })
261
- })
@@ -1,465 +0,0 @@
1
- 'use strict'
2
-
3
- const { test } = require('tap')
4
- const fs = require('fs')
5
- const proxyquire = require('proxyquire')
6
- const SonicBoom = require('../')
7
- const { file, runTests } = require('./helper')
8
-
9
- runTests(buildTests)
10
-
11
- function buildTests (test, sync) {
12
- // Reset the umask for testing
13
- process.umask(0o000)
14
-
15
- test('write things to a file descriptor', (t) => {
16
- t.plan(6)
17
-
18
- const dest = file()
19
- const fd = fs.openSync(dest, 'w')
20
- const stream = new SonicBoom({ fd, sync })
21
-
22
- stream.on('ready', () => {
23
- t.pass('ready emitted')
24
- })
25
-
26
- t.ok(stream.write('hello world\n'))
27
- t.ok(stream.write('something else\n'))
28
-
29
- stream.end()
30
-
31
- stream.on('finish', () => {
32
- fs.readFile(dest, 'utf8', (err, data) => {
33
- t.error(err)
34
- t.equal(data, 'hello world\nsomething else\n')
35
- })
36
- })
37
- stream.on('close', () => {
38
- t.pass('close emitted')
39
- })
40
- })
41
-
42
- test('write things in a streaming fashion', (t) => {
43
- t.plan(8)
44
-
45
- const dest = file()
46
- const fd = fs.openSync(dest, 'w')
47
- const stream = new SonicBoom({ fd, sync })
48
-
49
- stream.once('drain', () => {
50
- fs.readFile(dest, 'utf8', (err, data) => {
51
- t.error(err)
52
- t.equal(data, 'hello world\n')
53
- t.ok(stream.write('something else\n'))
54
- })
55
-
56
- stream.once('drain', () => {
57
- fs.readFile(dest, 'utf8', (err, data) => {
58
- t.error(err)
59
- t.equal(data, 'hello world\nsomething else\n')
60
- stream.end()
61
- })
62
- })
63
- })
64
-
65
- t.ok(stream.write('hello world\n'))
66
-
67
- stream.on('finish', () => {
68
- t.pass('finish emitted')
69
- })
70
- stream.on('close', () => {
71
- t.pass('close emitted')
72
- })
73
- })
74
-
75
- test('can be piped into', (t) => {
76
- t.plan(4)
77
-
78
- const dest = file()
79
- const fd = fs.openSync(dest, 'w')
80
- const stream = new SonicBoom({ fd, sync })
81
- const source = fs.createReadStream(__filename, { encoding: 'utf8' })
82
-
83
- source.pipe(stream)
84
-
85
- stream.on('finish', () => {
86
- fs.readFile(__filename, 'utf8', (err, expected) => {
87
- t.error(err)
88
- fs.readFile(dest, 'utf8', (err, data) => {
89
- t.error(err)
90
- t.equal(data, expected)
91
- })
92
- })
93
- })
94
- stream.on('close', () => {
95
- t.pass('close emitted')
96
- })
97
- })
98
-
99
- test('write things to a file', (t) => {
100
- t.plan(6)
101
-
102
- const dest = file()
103
- const stream = new SonicBoom({ dest, sync })
104
-
105
- stream.on('ready', () => {
106
- t.pass('ready emitted')
107
- })
108
-
109
- t.ok(stream.write('hello world\n'))
110
- t.ok(stream.write('something else\n'))
111
-
112
- stream.end()
113
-
114
- stream.on('finish', () => {
115
- fs.readFile(dest, 'utf8', (err, data) => {
116
- t.error(err)
117
- t.equal(data, 'hello world\nsomething else\n')
118
- })
119
- })
120
- stream.on('close', () => {
121
- t.pass('close emitted')
122
- })
123
- })
124
-
125
- test('minLength', (t) => {
126
- t.plan(8)
127
-
128
- const dest = file()
129
- const stream = new SonicBoom({ dest, minLength: 4096, sync })
130
-
131
- stream.on('ready', () => {
132
- t.pass('ready emitted')
133
- })
134
-
135
- t.ok(stream.write('hello world\n'))
136
- t.ok(stream.write('something else\n'))
137
-
138
- const fail = t.fail
139
- stream.on('drain', fail)
140
-
141
- // bad use of timer
142
- // TODO refactor
143
- setTimeout(function () {
144
- fs.readFile(dest, 'utf8', (err, data) => {
145
- t.error(err)
146
- t.equal(data, '')
147
-
148
- stream.end()
149
-
150
- stream.on('finish', () => {
151
- fs.readFile(dest, 'utf8', (err, data) => {
152
- t.error(err)
153
- t.equal(data, 'hello world\nsomething else\n')
154
- })
155
- })
156
- })
157
- }, 100)
158
-
159
- stream.on('close', () => {
160
- t.pass('close emitted')
161
- })
162
- })
163
-
164
- test('write later on recoverable error', (t) => {
165
- t.plan(8)
166
-
167
- const fakeFs = Object.create(fs)
168
- const SonicBoom = proxyquire('../', {
169
- fs: fakeFs
170
- })
171
-
172
- const dest = file()
173
- const fd = fs.openSync(dest, 'w')
174
- const stream = new SonicBoom({ fd, minLength: 0, sync })
175
-
176
- stream.on('ready', () => {
177
- t.pass('ready emitted')
178
- })
179
- stream.on('error', () => {
180
- t.pass('error emitted')
181
- })
182
-
183
- if (sync) {
184
- fakeFs.writeSync = function (fd, buf, enc) {
185
- t.pass('fake fs.writeSync called')
186
- throw new Error('recoverable error')
187
- }
188
- } else {
189
- fakeFs.write = function (fd, buf, ...args) {
190
- t.pass('fake fs.write called')
191
- setTimeout(() => args.pop()(new Error('recoverable error')), 0)
192
- }
193
- }
194
-
195
- t.ok(stream.write('hello world\n'))
196
-
197
- setTimeout(() => {
198
- if (sync) {
199
- fakeFs.writeSync = fs.writeSync
200
- } else {
201
- fakeFs.write = fs.write
202
- }
203
-
204
- t.ok(stream.write('something else\n'))
205
-
206
- stream.end()
207
- stream.on('finish', () => {
208
- fs.readFile(dest, 'utf8', (err, data) => {
209
- t.error(err)
210
- t.equal(data, 'hello world\nsomething else\n')
211
- })
212
- })
213
- stream.on('close', () => {
214
- t.pass('close emitted')
215
- })
216
- }, 0)
217
- })
218
-
219
- test('emit write events', (t) => {
220
- t.plan(7)
221
-
222
- const dest = file()
223
- const stream = new SonicBoom({ dest, sync })
224
-
225
- stream.on('ready', () => {
226
- t.pass('ready emitted')
227
- })
228
-
229
- let length = 0
230
- stream.on('write', (bytes) => {
231
- length += bytes
232
- })
233
-
234
- t.ok(stream.write('hello world\n'))
235
- t.ok(stream.write('something else\n'))
236
-
237
- stream.end()
238
-
239
- stream.on('finish', () => {
240
- fs.readFile(dest, 'utf8', (err, data) => {
241
- t.error(err)
242
- t.equal(data, 'hello world\nsomething else\n')
243
- t.equal(length, 27)
244
- })
245
- })
246
- stream.on('close', () => {
247
- t.pass('close emitted')
248
- })
249
- })
250
-
251
- test('write multi-byte characters string over than maxWrite', (t) => {
252
- const fakeFs = Object.create(fs)
253
- const MAX_WRITE = 65535
254
- fakeFs.write = function (fd, buf, ...args) {
255
- // only write byteLength === MAX_WRITE
256
- const _buf = Buffer.from(buf).subarray(0, MAX_WRITE).toString()
257
- fs.write(fd, _buf, ...args)
258
- setImmediate(args[args.length - 1], null, MAX_WRITE)
259
- fakeFs.write = function (fd, buf, ...args) {
260
- fs.write(fd, buf, ...args)
261
- }
262
- }
263
- const SonicBoom = proxyquire('../', {
264
- fs: fakeFs
265
- })
266
- const dest = file()
267
- const fd = fs.openSync(dest, 'w')
268
- const stream = new SonicBoom({ fd, minLength: 0, sync, maxWrite: MAX_WRITE })
269
- let buf = Buffer.alloc(MAX_WRITE).fill('x')
270
- buf = '🌲' + buf.toString()
271
- stream.write(buf)
272
- stream.end()
273
-
274
- stream.on('finish', () => {
275
- fs.readFile(dest, 'utf8', (err, data) => {
276
- t.error(err)
277
- t.equal(data, buf)
278
- t.end()
279
- })
280
- })
281
- stream.on('close', () => {
282
- t.pass('close emitted')
283
- })
284
- stream.on('error', () => {
285
- t.pass('error emitted')
286
- })
287
- })
288
- }
289
-
290
- test('write buffers that are not totally written', (t) => {
291
- t.plan(9)
292
-
293
- const fakeFs = Object.create(fs)
294
- fakeFs.write = function (fd, buf, ...args) {
295
- t.pass('fake fs.write called')
296
- fakeFs.write = function (fd, buf, ...args) {
297
- t.pass('calling real fs.write, ' + buf)
298
- fs.write(fd, buf, ...args)
299
- }
300
- process.nextTick(args[args.length - 1], null, 0)
301
- }
302
- const SonicBoom = proxyquire('../', {
303
- fs: fakeFs
304
- })
305
-
306
- const dest = file()
307
- const fd = fs.openSync(dest, 'w')
308
- const stream = new SonicBoom({ fd, minLength: 0, sync: false })
309
-
310
- stream.on('ready', () => {
311
- t.pass('ready emitted')
312
- })
313
-
314
- t.ok(stream.write('hello world\n'))
315
- t.ok(stream.write('something else\n'))
316
-
317
- stream.end()
318
-
319
- stream.on('finish', () => {
320
- fs.readFile(dest, 'utf8', (err, data) => {
321
- t.error(err)
322
- t.equal(data, 'hello world\nsomething else\n')
323
- })
324
- })
325
- stream.on('close', () => {
326
- t.pass('close emitted')
327
- })
328
- })
329
-
330
- test('write enormously large buffers async', (t) => {
331
- t.plan(3)
332
-
333
- const dest = file()
334
- const fd = fs.openSync(dest, 'w')
335
- const stream = new SonicBoom({ fd, minLength: 0, sync: false })
336
-
337
- const buf = Buffer.alloc(1024).fill('x').toString() // 1 MB
338
- let length = 0
339
-
340
- for (let i = 0; i < 1024 * 512; i++) {
341
- length += buf.length
342
- stream.write(buf)
343
- }
344
-
345
- stream.end()
346
-
347
- stream.on('finish', () => {
348
- fs.stat(dest, (err, stat) => {
349
- t.error(err)
350
- t.equal(stat.size, length)
351
- })
352
- })
353
- stream.on('close', () => {
354
- t.pass('close emitted')
355
- })
356
- })
357
-
358
- test('make sure `maxWrite` is passed', (t) => {
359
- t.plan(1)
360
- const dest = file()
361
- const stream = new SonicBoom({ dest, maxLength: 65536 })
362
- t.equal(stream.maxLength, 65536)
363
- })
364
-
365
- test('write enormously large buffers async atomicly', (t) => {
366
- const fakeFs = Object.create(fs)
367
- const SonicBoom = proxyquire('../', {
368
- fs: fakeFs
369
- })
370
-
371
- const dest = file()
372
- const fd = fs.openSync(dest, 'w')
373
- const stream = new SonicBoom({ fd, minLength: 0, sync: false })
374
-
375
- const buf = Buffer.alloc(1023).fill('x').toString()
376
-
377
- fakeFs.write = function (fd, _buf, ...args) {
378
- if (_buf.length % buf.length !== 0) {
379
- t.fail('write called with wrong buffer size')
380
- }
381
-
382
- setImmediate(args[args.length - 1], null, _buf.length)
383
- }
384
-
385
- for (let i = 0; i < 1024 * 512; i++) {
386
- stream.write(buf)
387
- }
388
-
389
- setImmediate(() => {
390
- for (let i = 0; i < 1024 * 512; i++) {
391
- stream.write(buf)
392
- }
393
-
394
- stream.end()
395
- })
396
-
397
- stream.on('close', () => {
398
- t.pass('close emitted')
399
- t.end()
400
- })
401
- })
402
-
403
- test('write should not drop new data if buffer is not full', (t) => {
404
- t.plan(2)
405
- const fakeFs = Object.create(fs)
406
- const SonicBoom = proxyquire('../', {
407
- fs: fakeFs
408
- })
409
-
410
- const dest = file()
411
- const fd = fs.openSync(dest, 'w')
412
- const stream = new SonicBoom({ fd, minLength: 101, maxLength: 102, sync: false })
413
-
414
- const buf = Buffer.alloc(100).fill('x').toString()
415
-
416
- fakeFs.write = function (fd, _buf, ...args) {
417
- t.equal(_buf.length, buf.length + 2)
418
- setImmediate(args[args.length - 1], null, _buf.length)
419
- fakeFs.write = () => t.error('shouldnt call write again')
420
- stream.end()
421
- }
422
-
423
- stream.on('drop', (data) => {
424
- t.error('should not drop')
425
- })
426
-
427
- stream.write(buf)
428
- stream.write('aa')
429
-
430
- stream.on('close', () => {
431
- t.pass('close emitted')
432
- })
433
- })
434
-
435
- test('write should drop new data if buffer is full', (t) => {
436
- t.plan(3)
437
- const fakeFs = Object.create(fs)
438
- const SonicBoom = proxyquire('../', {
439
- fs: fakeFs
440
- })
441
-
442
- const dest = file()
443
- const fd = fs.openSync(dest, 'w')
444
- const stream = new SonicBoom({ fd, minLength: 101, maxLength: 102, sync: false })
445
-
446
- const buf = Buffer.alloc(100).fill('x').toString()
447
-
448
- fakeFs.write = function (fd, _buf, ...args) {
449
- t.equal(_buf.length, buf.length)
450
- setImmediate(args[args.length - 1], null, _buf.length)
451
- fakeFs.write = () => t.error('shouldnt call write more than once')
452
- }
453
-
454
- stream.on('drop', (data) => {
455
- t.equal(data.length, 3)
456
- stream.end()
457
- })
458
-
459
- stream.write(buf)
460
- stream.write('aaa')
461
-
462
- stream.on('close', () => {
463
- t.pass('close emitted')
464
- })
465
- })