ai 6.0.32 → 6.0.34

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 (353) hide show
  1. package/CHANGELOG.md +16 -0
  2. package/dist/index.js +12 -2
  3. package/dist/index.js.map +1 -1
  4. package/dist/index.mjs +12 -2
  5. package/dist/index.mjs.map +1 -1
  6. package/dist/internal/index.js +1 -1
  7. package/dist/internal/index.mjs +1 -1
  8. package/docs/02-foundations/03-prompts.mdx +2 -2
  9. package/docs/03-ai-sdk-core/15-tools-and-tool-calling.mdx +1 -1
  10. package/docs/07-reference/01-ai-sdk-core/28-output.mdx +1 -1
  11. package/package.json +6 -4
  12. package/src/agent/agent.ts +116 -0
  13. package/src/agent/create-agent-ui-stream-response.test.ts +258 -0
  14. package/src/agent/create-agent-ui-stream-response.ts +50 -0
  15. package/src/agent/create-agent-ui-stream.ts +73 -0
  16. package/src/agent/index.ts +33 -0
  17. package/src/agent/infer-agent-tools.ts +7 -0
  18. package/src/agent/infer-agent-ui-message.test-d.ts +54 -0
  19. package/src/agent/infer-agent-ui-message.ts +11 -0
  20. package/src/agent/pipe-agent-ui-stream-to-response.ts +52 -0
  21. package/src/agent/tool-loop-agent-on-finish-callback.ts +31 -0
  22. package/src/agent/tool-loop-agent-on-step-finish-callback.ts +11 -0
  23. package/src/agent/tool-loop-agent-settings.ts +182 -0
  24. package/src/agent/tool-loop-agent.test-d.ts +114 -0
  25. package/src/agent/tool-loop-agent.test.ts +442 -0
  26. package/src/agent/tool-loop-agent.ts +114 -0
  27. package/src/embed/__snapshots__/embed-many.test.ts.snap +191 -0
  28. package/src/embed/__snapshots__/embed.test.ts.snap +81 -0
  29. package/src/embed/embed-many-result.ts +53 -0
  30. package/src/embed/embed-many.test.ts +653 -0
  31. package/src/embed/embed-many.ts +378 -0
  32. package/src/embed/embed-result.ts +50 -0
  33. package/src/embed/embed.test.ts +298 -0
  34. package/src/embed/embed.ts +211 -0
  35. package/src/embed/index.ts +4 -0
  36. package/src/error/index.ts +34 -0
  37. package/src/error/invalid-argument-error.ts +34 -0
  38. package/src/error/invalid-stream-part-error.ts +28 -0
  39. package/src/error/invalid-tool-approval-error.ts +26 -0
  40. package/src/error/invalid-tool-input-error.ts +33 -0
  41. package/src/error/no-image-generated-error.ts +39 -0
  42. package/src/error/no-object-generated-error.ts +70 -0
  43. package/src/error/no-output-generated-error.ts +26 -0
  44. package/src/error/no-speech-generated-error.ts +18 -0
  45. package/src/error/no-such-tool-error.ts +35 -0
  46. package/src/error/no-transcript-generated-error.ts +20 -0
  47. package/src/error/tool-call-not-found-for-approval-error.ts +32 -0
  48. package/src/error/tool-call-repair-error.ts +30 -0
  49. package/src/error/unsupported-model-version-error.ts +23 -0
  50. package/src/error/verify-no-object-generated-error.ts +27 -0
  51. package/src/generate-image/generate-image-result.ts +42 -0
  52. package/src/generate-image/generate-image.test.ts +1420 -0
  53. package/src/generate-image/generate-image.ts +360 -0
  54. package/src/generate-image/index.ts +18 -0
  55. package/src/generate-object/__snapshots__/generate-object.test.ts.snap +133 -0
  56. package/src/generate-object/__snapshots__/stream-object.test.ts.snap +297 -0
  57. package/src/generate-object/generate-object-result.ts +67 -0
  58. package/src/generate-object/generate-object.test-d.ts +49 -0
  59. package/src/generate-object/generate-object.test.ts +1191 -0
  60. package/src/generate-object/generate-object.ts +518 -0
  61. package/src/generate-object/index.ts +9 -0
  62. package/src/generate-object/inject-json-instruction.test.ts +181 -0
  63. package/src/generate-object/inject-json-instruction.ts +30 -0
  64. package/src/generate-object/output-strategy.ts +415 -0
  65. package/src/generate-object/parse-and-validate-object-result.ts +111 -0
  66. package/src/generate-object/repair-text.ts +12 -0
  67. package/src/generate-object/stream-object-result.ts +120 -0
  68. package/src/generate-object/stream-object.test-d.ts +74 -0
  69. package/src/generate-object/stream-object.test.ts +1950 -0
  70. package/src/generate-object/stream-object.ts +986 -0
  71. package/src/generate-object/validate-object-generation-input.ts +144 -0
  72. package/src/generate-speech/generate-speech-result.ts +30 -0
  73. package/src/generate-speech/generate-speech.test.ts +300 -0
  74. package/src/generate-speech/generate-speech.ts +190 -0
  75. package/src/generate-speech/generated-audio-file.ts +65 -0
  76. package/src/generate-speech/index.ts +3 -0
  77. package/src/generate-text/__snapshots__/generate-text.test.ts.snap +1872 -0
  78. package/src/generate-text/__snapshots__/stream-text.test.ts.snap +1255 -0
  79. package/src/generate-text/collect-tool-approvals.test.ts +553 -0
  80. package/src/generate-text/collect-tool-approvals.ts +116 -0
  81. package/src/generate-text/content-part.ts +25 -0
  82. package/src/generate-text/execute-tool-call.ts +129 -0
  83. package/src/generate-text/extract-reasoning-content.ts +17 -0
  84. package/src/generate-text/extract-text-content.ts +15 -0
  85. package/src/generate-text/generate-text-result.ts +168 -0
  86. package/src/generate-text/generate-text.test-d.ts +68 -0
  87. package/src/generate-text/generate-text.test.ts +7011 -0
  88. package/src/generate-text/generate-text.ts +1223 -0
  89. package/src/generate-text/generated-file.ts +70 -0
  90. package/src/generate-text/index.ts +57 -0
  91. package/src/generate-text/is-approval-needed.ts +29 -0
  92. package/src/generate-text/output-utils.ts +23 -0
  93. package/src/generate-text/output.test.ts +698 -0
  94. package/src/generate-text/output.ts +590 -0
  95. package/src/generate-text/parse-tool-call.test.ts +570 -0
  96. package/src/generate-text/parse-tool-call.ts +188 -0
  97. package/src/generate-text/prepare-step.ts +103 -0
  98. package/src/generate-text/prune-messages.test.ts +720 -0
  99. package/src/generate-text/prune-messages.ts +167 -0
  100. package/src/generate-text/reasoning-output.ts +20 -0
  101. package/src/generate-text/reasoning.ts +8 -0
  102. package/src/generate-text/response-message.ts +10 -0
  103. package/src/generate-text/run-tools-transformation.test.ts +1143 -0
  104. package/src/generate-text/run-tools-transformation.ts +420 -0
  105. package/src/generate-text/smooth-stream.test.ts +2101 -0
  106. package/src/generate-text/smooth-stream.ts +162 -0
  107. package/src/generate-text/step-result.ts +238 -0
  108. package/src/generate-text/stop-condition.ts +29 -0
  109. package/src/generate-text/stream-text-result.ts +463 -0
  110. package/src/generate-text/stream-text.test-d.ts +200 -0
  111. package/src/generate-text/stream-text.test.ts +19979 -0
  112. package/src/generate-text/stream-text.ts +2505 -0
  113. package/src/generate-text/to-response-messages.test.ts +922 -0
  114. package/src/generate-text/to-response-messages.ts +163 -0
  115. package/src/generate-text/tool-approval-request-output.ts +21 -0
  116. package/src/generate-text/tool-call-repair-function.ts +27 -0
  117. package/src/generate-text/tool-call.ts +47 -0
  118. package/src/generate-text/tool-error.ts +34 -0
  119. package/src/generate-text/tool-output-denied.ts +21 -0
  120. package/src/generate-text/tool-output.ts +7 -0
  121. package/src/generate-text/tool-result.ts +36 -0
  122. package/src/generate-text/tool-set.ts +14 -0
  123. package/src/global.ts +24 -0
  124. package/src/index.ts +50 -0
  125. package/src/logger/index.ts +6 -0
  126. package/src/logger/log-warnings.test.ts +351 -0
  127. package/src/logger/log-warnings.ts +119 -0
  128. package/src/middleware/__snapshots__/simulate-streaming-middleware.test.ts.snap +64 -0
  129. package/src/middleware/add-tool-input-examples-middleware.test.ts +476 -0
  130. package/src/middleware/add-tool-input-examples-middleware.ts +90 -0
  131. package/src/middleware/default-embedding-settings-middleware.test.ts +126 -0
  132. package/src/middleware/default-embedding-settings-middleware.ts +22 -0
  133. package/src/middleware/default-settings-middleware.test.ts +388 -0
  134. package/src/middleware/default-settings-middleware.ts +33 -0
  135. package/src/middleware/extract-json-middleware.test.ts +827 -0
  136. package/src/middleware/extract-json-middleware.ts +197 -0
  137. package/src/middleware/extract-reasoning-middleware.test.ts +1028 -0
  138. package/src/middleware/extract-reasoning-middleware.ts +238 -0
  139. package/src/middleware/index.ts +10 -0
  140. package/src/middleware/simulate-streaming-middleware.test.ts +911 -0
  141. package/src/middleware/simulate-streaming-middleware.ts +79 -0
  142. package/src/middleware/wrap-embedding-model.test.ts +358 -0
  143. package/src/middleware/wrap-embedding-model.ts +86 -0
  144. package/src/middleware/wrap-image-model.test.ts +423 -0
  145. package/src/middleware/wrap-image-model.ts +85 -0
  146. package/src/middleware/wrap-language-model.test.ts +518 -0
  147. package/src/middleware/wrap-language-model.ts +104 -0
  148. package/src/middleware/wrap-provider.test.ts +120 -0
  149. package/src/middleware/wrap-provider.ts +51 -0
  150. package/src/model/as-embedding-model-v3.test.ts +319 -0
  151. package/src/model/as-embedding-model-v3.ts +24 -0
  152. package/src/model/as-image-model-v3.test.ts +409 -0
  153. package/src/model/as-image-model-v3.ts +24 -0
  154. package/src/model/as-language-model-v3.test.ts +508 -0
  155. package/src/model/as-language-model-v3.ts +103 -0
  156. package/src/model/as-provider-v3.ts +36 -0
  157. package/src/model/as-speech-model-v3.test.ts +356 -0
  158. package/src/model/as-speech-model-v3.ts +24 -0
  159. package/src/model/as-transcription-model-v3.test.ts +529 -0
  160. package/src/model/as-transcription-model-v3.ts +24 -0
  161. package/src/model/resolve-model.test.ts +244 -0
  162. package/src/model/resolve-model.ts +126 -0
  163. package/src/prompt/call-settings.ts +148 -0
  164. package/src/prompt/content-part.ts +209 -0
  165. package/src/prompt/convert-to-language-model-prompt.test.ts +2018 -0
  166. package/src/prompt/convert-to-language-model-prompt.ts +442 -0
  167. package/src/prompt/create-tool-model-output.test.ts +508 -0
  168. package/src/prompt/create-tool-model-output.ts +34 -0
  169. package/src/prompt/data-content.test.ts +15 -0
  170. package/src/prompt/data-content.ts +134 -0
  171. package/src/prompt/index.ts +27 -0
  172. package/src/prompt/invalid-data-content-error.ts +29 -0
  173. package/src/prompt/invalid-message-role-error.ts +27 -0
  174. package/src/prompt/message-conversion-error.ts +28 -0
  175. package/src/prompt/message.ts +68 -0
  176. package/src/prompt/prepare-call-settings.test.ts +159 -0
  177. package/src/prompt/prepare-call-settings.ts +108 -0
  178. package/src/prompt/prepare-tools-and-tool-choice.test.ts +461 -0
  179. package/src/prompt/prepare-tools-and-tool-choice.ts +86 -0
  180. package/src/prompt/prompt.ts +43 -0
  181. package/src/prompt/split-data-url.ts +17 -0
  182. package/src/prompt/standardize-prompt.test.ts +82 -0
  183. package/src/prompt/standardize-prompt.ts +99 -0
  184. package/src/prompt/wrap-gateway-error.ts +29 -0
  185. package/src/registry/custom-provider.test.ts +211 -0
  186. package/src/registry/custom-provider.ts +155 -0
  187. package/src/registry/index.ts +7 -0
  188. package/src/registry/no-such-provider-error.ts +41 -0
  189. package/src/registry/provider-registry.test.ts +691 -0
  190. package/src/registry/provider-registry.ts +328 -0
  191. package/src/rerank/index.ts +2 -0
  192. package/src/rerank/rerank-result.ts +70 -0
  193. package/src/rerank/rerank.test.ts +516 -0
  194. package/src/rerank/rerank.ts +237 -0
  195. package/src/telemetry/assemble-operation-name.ts +21 -0
  196. package/src/telemetry/get-base-telemetry-attributes.ts +53 -0
  197. package/src/telemetry/get-tracer.ts +20 -0
  198. package/src/telemetry/noop-tracer.ts +69 -0
  199. package/src/telemetry/record-span.ts +63 -0
  200. package/src/telemetry/select-telemetry-attributes.ts +78 -0
  201. package/src/telemetry/select-temetry-attributes.test.ts +114 -0
  202. package/src/telemetry/stringify-for-telemetry.test.ts +114 -0
  203. package/src/telemetry/stringify-for-telemetry.ts +33 -0
  204. package/src/telemetry/telemetry-settings.ts +44 -0
  205. package/src/test/mock-embedding-model-v2.ts +35 -0
  206. package/src/test/mock-embedding-model-v3.ts +48 -0
  207. package/src/test/mock-image-model-v2.ts +28 -0
  208. package/src/test/mock-image-model-v3.ts +28 -0
  209. package/src/test/mock-language-model-v2.ts +72 -0
  210. package/src/test/mock-language-model-v3.ts +77 -0
  211. package/src/test/mock-provider-v2.ts +68 -0
  212. package/src/test/mock-provider-v3.ts +80 -0
  213. package/src/test/mock-reranking-model-v3.ts +25 -0
  214. package/src/test/mock-server-response.ts +69 -0
  215. package/src/test/mock-speech-model-v2.ts +24 -0
  216. package/src/test/mock-speech-model-v3.ts +24 -0
  217. package/src/test/mock-tracer.ts +156 -0
  218. package/src/test/mock-transcription-model-v2.ts +24 -0
  219. package/src/test/mock-transcription-model-v3.ts +24 -0
  220. package/src/test/mock-values.ts +4 -0
  221. package/src/test/not-implemented.ts +3 -0
  222. package/src/text-stream/create-text-stream-response.test.ts +38 -0
  223. package/src/text-stream/create-text-stream-response.ts +18 -0
  224. package/src/text-stream/index.ts +2 -0
  225. package/src/text-stream/pipe-text-stream-to-response.test.ts +38 -0
  226. package/src/text-stream/pipe-text-stream-to-response.ts +26 -0
  227. package/src/transcribe/index.ts +2 -0
  228. package/src/transcribe/transcribe-result.ts +60 -0
  229. package/src/transcribe/transcribe.test.ts +313 -0
  230. package/src/transcribe/transcribe.ts +173 -0
  231. package/src/types/embedding-model-middleware.ts +3 -0
  232. package/src/types/embedding-model.ts +18 -0
  233. package/src/types/image-model-middleware.ts +3 -0
  234. package/src/types/image-model-response-metadata.ts +16 -0
  235. package/src/types/image-model.ts +19 -0
  236. package/src/types/index.ts +29 -0
  237. package/src/types/json-value.ts +15 -0
  238. package/src/types/language-model-middleware.ts +3 -0
  239. package/src/types/language-model-request-metadata.ts +6 -0
  240. package/src/types/language-model-response-metadata.ts +21 -0
  241. package/src/types/language-model.ts +104 -0
  242. package/src/types/provider-metadata.ts +16 -0
  243. package/src/types/provider.ts +55 -0
  244. package/src/types/reranking-model.ts +6 -0
  245. package/src/types/speech-model-response-metadata.ts +21 -0
  246. package/src/types/speech-model.ts +6 -0
  247. package/src/types/transcription-model-response-metadata.ts +16 -0
  248. package/src/types/transcription-model.ts +9 -0
  249. package/src/types/usage.ts +200 -0
  250. package/src/types/warning.ts +7 -0
  251. package/src/ui/__snapshots__/append-response-messages.test.ts.snap +416 -0
  252. package/src/ui/__snapshots__/convert-to-model-messages.test.ts.snap +419 -0
  253. package/src/ui/__snapshots__/process-chat-text-response.test.ts.snap +142 -0
  254. package/src/ui/call-completion-api.ts +157 -0
  255. package/src/ui/chat-transport.ts +83 -0
  256. package/src/ui/chat.test-d.ts +233 -0
  257. package/src/ui/chat.test.ts +2695 -0
  258. package/src/ui/chat.ts +716 -0
  259. package/src/ui/convert-file-list-to-file-ui-parts.ts +36 -0
  260. package/src/ui/convert-to-model-messages.test.ts +2775 -0
  261. package/src/ui/convert-to-model-messages.ts +373 -0
  262. package/src/ui/default-chat-transport.ts +36 -0
  263. package/src/ui/direct-chat-transport.test.ts +446 -0
  264. package/src/ui/direct-chat-transport.ts +118 -0
  265. package/src/ui/http-chat-transport.test.ts +185 -0
  266. package/src/ui/http-chat-transport.ts +292 -0
  267. package/src/ui/index.ts +71 -0
  268. package/src/ui/last-assistant-message-is-complete-with-approval-responses.ts +44 -0
  269. package/src/ui/last-assistant-message-is-complete-with-tool-calls.test.ts +371 -0
  270. package/src/ui/last-assistant-message-is-complete-with-tool-calls.ts +39 -0
  271. package/src/ui/process-text-stream.test.ts +38 -0
  272. package/src/ui/process-text-stream.ts +16 -0
  273. package/src/ui/process-ui-message-stream.test.ts +8052 -0
  274. package/src/ui/process-ui-message-stream.ts +713 -0
  275. package/src/ui/text-stream-chat-transport.ts +23 -0
  276. package/src/ui/transform-text-to-ui-message-stream.test.ts +124 -0
  277. package/src/ui/transform-text-to-ui-message-stream.ts +27 -0
  278. package/src/ui/ui-messages.test.ts +48 -0
  279. package/src/ui/ui-messages.ts +534 -0
  280. package/src/ui/use-completion.ts +84 -0
  281. package/src/ui/validate-ui-messages.test.ts +1428 -0
  282. package/src/ui/validate-ui-messages.ts +476 -0
  283. package/src/ui-message-stream/create-ui-message-stream-response.test.ts +266 -0
  284. package/src/ui-message-stream/create-ui-message-stream-response.ts +32 -0
  285. package/src/ui-message-stream/create-ui-message-stream.test.ts +639 -0
  286. package/src/ui-message-stream/create-ui-message-stream.ts +124 -0
  287. package/src/ui-message-stream/get-response-ui-message-id.test.ts +55 -0
  288. package/src/ui-message-stream/get-response-ui-message-id.ts +24 -0
  289. package/src/ui-message-stream/handle-ui-message-stream-finish.test.ts +429 -0
  290. package/src/ui-message-stream/handle-ui-message-stream-finish.ts +135 -0
  291. package/src/ui-message-stream/index.ts +13 -0
  292. package/src/ui-message-stream/json-to-sse-transform-stream.ts +12 -0
  293. package/src/ui-message-stream/pipe-ui-message-stream-to-response.test.ts +90 -0
  294. package/src/ui-message-stream/pipe-ui-message-stream-to-response.ts +40 -0
  295. package/src/ui-message-stream/read-ui-message-stream.test.ts +122 -0
  296. package/src/ui-message-stream/read-ui-message-stream.ts +87 -0
  297. package/src/ui-message-stream/ui-message-chunks.test-d.ts +18 -0
  298. package/src/ui-message-stream/ui-message-chunks.ts +344 -0
  299. package/src/ui-message-stream/ui-message-stream-headers.ts +7 -0
  300. package/src/ui-message-stream/ui-message-stream-on-finish-callback.ts +32 -0
  301. package/src/ui-message-stream/ui-message-stream-response-init.ts +5 -0
  302. package/src/ui-message-stream/ui-message-stream-writer.ts +24 -0
  303. package/src/util/as-array.ts +3 -0
  304. package/src/util/async-iterable-stream.test.ts +241 -0
  305. package/src/util/async-iterable-stream.ts +94 -0
  306. package/src/util/consume-stream.ts +29 -0
  307. package/src/util/cosine-similarity.test.ts +57 -0
  308. package/src/util/cosine-similarity.ts +47 -0
  309. package/src/util/create-resolvable-promise.ts +30 -0
  310. package/src/util/create-stitchable-stream.test.ts +239 -0
  311. package/src/util/create-stitchable-stream.ts +112 -0
  312. package/src/util/data-url.ts +17 -0
  313. package/src/util/deep-partial.ts +84 -0
  314. package/src/util/detect-media-type.test.ts +670 -0
  315. package/src/util/detect-media-type.ts +184 -0
  316. package/src/util/download/download-function.ts +45 -0
  317. package/src/util/download/download.test.ts +69 -0
  318. package/src/util/download/download.ts +46 -0
  319. package/src/util/error-handler.ts +1 -0
  320. package/src/util/fix-json.test.ts +279 -0
  321. package/src/util/fix-json.ts +401 -0
  322. package/src/util/get-potential-start-index.test.ts +34 -0
  323. package/src/util/get-potential-start-index.ts +30 -0
  324. package/src/util/index.ts +11 -0
  325. package/src/util/is-deep-equal-data.test.ts +119 -0
  326. package/src/util/is-deep-equal-data.ts +48 -0
  327. package/src/util/is-non-empty-object.ts +5 -0
  328. package/src/util/job.ts +1 -0
  329. package/src/util/log-v2-compatibility-warning.ts +21 -0
  330. package/src/util/merge-abort-signals.test.ts +155 -0
  331. package/src/util/merge-abort-signals.ts +43 -0
  332. package/src/util/merge-objects.test.ts +118 -0
  333. package/src/util/merge-objects.ts +79 -0
  334. package/src/util/now.ts +4 -0
  335. package/src/util/parse-partial-json.test.ts +80 -0
  336. package/src/util/parse-partial-json.ts +30 -0
  337. package/src/util/prepare-headers.test.ts +51 -0
  338. package/src/util/prepare-headers.ts +14 -0
  339. package/src/util/prepare-retries.test.ts +10 -0
  340. package/src/util/prepare-retries.ts +47 -0
  341. package/src/util/retry-error.ts +41 -0
  342. package/src/util/retry-with-exponential-backoff.test.ts +446 -0
  343. package/src/util/retry-with-exponential-backoff.ts +154 -0
  344. package/src/util/serial-job-executor.test.ts +162 -0
  345. package/src/util/serial-job-executor.ts +36 -0
  346. package/src/util/simulate-readable-stream.test.ts +98 -0
  347. package/src/util/simulate-readable-stream.ts +39 -0
  348. package/src/util/split-array.test.ts +60 -0
  349. package/src/util/split-array.ts +20 -0
  350. package/src/util/value-of.ts +65 -0
  351. package/src/util/write-to-server-response.test.ts +266 -0
  352. package/src/util/write-to-server-response.ts +49 -0
  353. package/src/version.ts +5 -0
@@ -0,0 +1,911 @@
1
+ import { LanguageModelV3Usage } from '@ai-sdk/provider';
2
+ import { jsonSchema, tool } from '@ai-sdk/provider-utils';
3
+ import {
4
+ convertAsyncIterableToArray,
5
+ mockId,
6
+ } from '@ai-sdk/provider-utils/test';
7
+ import {
8
+ afterEach,
9
+ beforeEach,
10
+ describe,
11
+ expect,
12
+ it,
13
+ vi,
14
+ vitest,
15
+ } from 'vitest';
16
+ import { streamText } from '../generate-text';
17
+ import * as logWarningsModule from '../logger/log-warnings';
18
+ import { wrapLanguageModel } from '../middleware/wrap-language-model';
19
+ import { MockLanguageModelV3 } from '../test/mock-language-model-v3';
20
+ import { simulateStreamingMiddleware } from './simulate-streaming-middleware';
21
+
22
+ const DEFAULT_SETTINGs = {
23
+ prompt: 'Test prompt',
24
+ experimental_generateMessageId: mockId({ prefix: 'msg' }),
25
+ _internal: {
26
+ generateId: mockId({ prefix: 'id' }),
27
+ },
28
+ };
29
+
30
+ const testUsage: LanguageModelV3Usage = {
31
+ inputTokens: {
32
+ total: 5,
33
+ noCache: 5,
34
+ cacheRead: 0,
35
+ cacheWrite: 0,
36
+ },
37
+ outputTokens: {
38
+ total: 10,
39
+ text: 10,
40
+ reasoning: 3,
41
+ },
42
+ };
43
+
44
+ describe('simulateStreamingMiddleware', () => {
45
+ let logWarningsSpy: ReturnType<typeof vitest.spyOn>;
46
+
47
+ beforeEach(() => {
48
+ vi.useFakeTimers();
49
+ vi.setSystemTime(new Date('2025-01-01'));
50
+ logWarningsSpy = vitest
51
+ .spyOn(logWarningsModule, 'logWarnings')
52
+ .mockImplementation(() => {});
53
+ });
54
+
55
+ afterEach(() => {
56
+ vi.useRealTimers();
57
+ logWarningsSpy.mockRestore();
58
+ });
59
+
60
+ it('should simulate streaming with text response', async () => {
61
+ const mockModel = new MockLanguageModelV3({
62
+ async doGenerate() {
63
+ return {
64
+ content: [{ type: 'text', text: 'This is a test response' }],
65
+ finishReason: { unified: 'stop', raw: 'stop' },
66
+ usage: testUsage,
67
+ warnings: [],
68
+ };
69
+ },
70
+ });
71
+
72
+ const result = streamText({
73
+ model: wrapLanguageModel({
74
+ model: mockModel,
75
+ middleware: simulateStreamingMiddleware(),
76
+ }),
77
+ ...DEFAULT_SETTINGs,
78
+ });
79
+
80
+ expect(await convertAsyncIterableToArray(result.fullStream))
81
+ .toMatchInlineSnapshot(`
82
+ [
83
+ {
84
+ "type": "start",
85
+ },
86
+ {
87
+ "request": {},
88
+ "type": "start-step",
89
+ "warnings": [],
90
+ },
91
+ {
92
+ "id": "0",
93
+ "type": "text-start",
94
+ },
95
+ {
96
+ "id": "0",
97
+ "providerMetadata": undefined,
98
+ "text": "This is a test response",
99
+ "type": "text-delta",
100
+ },
101
+ {
102
+ "id": "0",
103
+ "type": "text-end",
104
+ },
105
+ {
106
+ "finishReason": "stop",
107
+ "providerMetadata": undefined,
108
+ "rawFinishReason": "stop",
109
+ "response": {
110
+ "headers": undefined,
111
+ "id": "id-0",
112
+ "modelId": "mock-model-id",
113
+ "timestamp": 2025-01-01T00:00:00.000Z,
114
+ },
115
+ "type": "finish-step",
116
+ "usage": {
117
+ "cachedInputTokens": 0,
118
+ "inputTokenDetails": {
119
+ "cacheReadTokens": 0,
120
+ "cacheWriteTokens": 0,
121
+ "noCacheTokens": 5,
122
+ },
123
+ "inputTokens": 5,
124
+ "outputTokenDetails": {
125
+ "reasoningTokens": 3,
126
+ "textTokens": 10,
127
+ },
128
+ "outputTokens": 10,
129
+ "raw": undefined,
130
+ "reasoningTokens": 3,
131
+ "totalTokens": 15,
132
+ },
133
+ },
134
+ {
135
+ "finishReason": "stop",
136
+ "rawFinishReason": "stop",
137
+ "totalUsage": {
138
+ "cachedInputTokens": 0,
139
+ "inputTokenDetails": {
140
+ "cacheReadTokens": 0,
141
+ "cacheWriteTokens": 0,
142
+ "noCacheTokens": 5,
143
+ },
144
+ "inputTokens": 5,
145
+ "outputTokenDetails": {
146
+ "reasoningTokens": 3,
147
+ "textTokens": 10,
148
+ },
149
+ "outputTokens": 10,
150
+ "reasoningTokens": 3,
151
+ "totalTokens": 15,
152
+ },
153
+ "type": "finish",
154
+ },
155
+ ]
156
+ `);
157
+ });
158
+
159
+ it('should simulate streaming with reasoning as string', async () => {
160
+ const mockModel = new MockLanguageModelV3({
161
+ async doGenerate() {
162
+ return {
163
+ content: [
164
+ {
165
+ type: 'reasoning',
166
+ reasoningType: 'text',
167
+ text: 'This is the reasoning process',
168
+ },
169
+ { type: 'text', text: 'This is a test response' },
170
+ ],
171
+ finishReason: { unified: 'stop', raw: 'stop' },
172
+ usage: testUsage,
173
+ warnings: [],
174
+ };
175
+ },
176
+ });
177
+
178
+ const result = streamText({
179
+ model: wrapLanguageModel({
180
+ model: mockModel,
181
+ middleware: simulateStreamingMiddleware(),
182
+ }),
183
+ ...DEFAULT_SETTINGs,
184
+ });
185
+
186
+ expect(await convertAsyncIterableToArray(result.fullStream))
187
+ .toMatchInlineSnapshot(`
188
+ [
189
+ {
190
+ "type": "start",
191
+ },
192
+ {
193
+ "request": {},
194
+ "type": "start-step",
195
+ "warnings": [],
196
+ },
197
+ {
198
+ "id": "0",
199
+ "providerMetadata": undefined,
200
+ "type": "reasoning-start",
201
+ },
202
+ {
203
+ "id": "0",
204
+ "providerMetadata": undefined,
205
+ "text": "This is the reasoning process",
206
+ "type": "reasoning-delta",
207
+ },
208
+ {
209
+ "id": "0",
210
+ "type": "reasoning-end",
211
+ },
212
+ {
213
+ "id": "1",
214
+ "type": "text-start",
215
+ },
216
+ {
217
+ "id": "1",
218
+ "providerMetadata": undefined,
219
+ "text": "This is a test response",
220
+ "type": "text-delta",
221
+ },
222
+ {
223
+ "id": "1",
224
+ "type": "text-end",
225
+ },
226
+ {
227
+ "finishReason": "stop",
228
+ "providerMetadata": undefined,
229
+ "rawFinishReason": "stop",
230
+ "response": {
231
+ "headers": undefined,
232
+ "id": "id-1",
233
+ "modelId": "mock-model-id",
234
+ "timestamp": 2025-01-01T00:00:00.000Z,
235
+ },
236
+ "type": "finish-step",
237
+ "usage": {
238
+ "cachedInputTokens": 0,
239
+ "inputTokenDetails": {
240
+ "cacheReadTokens": 0,
241
+ "cacheWriteTokens": 0,
242
+ "noCacheTokens": 5,
243
+ },
244
+ "inputTokens": 5,
245
+ "outputTokenDetails": {
246
+ "reasoningTokens": 3,
247
+ "textTokens": 10,
248
+ },
249
+ "outputTokens": 10,
250
+ "raw": undefined,
251
+ "reasoningTokens": 3,
252
+ "totalTokens": 15,
253
+ },
254
+ },
255
+ {
256
+ "finishReason": "stop",
257
+ "rawFinishReason": "stop",
258
+ "totalUsage": {
259
+ "cachedInputTokens": 0,
260
+ "inputTokenDetails": {
261
+ "cacheReadTokens": 0,
262
+ "cacheWriteTokens": 0,
263
+ "noCacheTokens": 5,
264
+ },
265
+ "inputTokens": 5,
266
+ "outputTokenDetails": {
267
+ "reasoningTokens": 3,
268
+ "textTokens": 10,
269
+ },
270
+ "outputTokens": 10,
271
+ "reasoningTokens": 3,
272
+ "totalTokens": 15,
273
+ },
274
+ "type": "finish",
275
+ },
276
+ ]
277
+ `);
278
+ });
279
+
280
+ it('should simulate streaming with reasoning as array of text objects', async () => {
281
+ const mockModel = new MockLanguageModelV3({
282
+ async doGenerate() {
283
+ return {
284
+ content: [
285
+ { type: 'text', text: 'This is a test response' },
286
+ {
287
+ type: 'reasoning',
288
+ text: 'First reasoning step',
289
+ },
290
+ {
291
+ type: 'reasoning',
292
+ text: 'Second reasoning step',
293
+ },
294
+ {
295
+ type: 'reasoning',
296
+ text: '',
297
+ providerMetadata: {
298
+ testProvider: {
299
+ signature: 'abc',
300
+ },
301
+ },
302
+ },
303
+ ],
304
+ finishReason: { unified: 'stop', raw: 'stop' },
305
+ usage: testUsage,
306
+ warnings: [],
307
+ };
308
+ },
309
+ });
310
+
311
+ const result = streamText({
312
+ model: wrapLanguageModel({
313
+ model: mockModel,
314
+ middleware: simulateStreamingMiddleware(),
315
+ }),
316
+ ...DEFAULT_SETTINGs,
317
+ });
318
+
319
+ expect(await convertAsyncIterableToArray(result.fullStream))
320
+ .toMatchInlineSnapshot(`
321
+ [
322
+ {
323
+ "type": "start",
324
+ },
325
+ {
326
+ "request": {},
327
+ "type": "start-step",
328
+ "warnings": [],
329
+ },
330
+ {
331
+ "id": "0",
332
+ "type": "text-start",
333
+ },
334
+ {
335
+ "id": "0",
336
+ "providerMetadata": undefined,
337
+ "text": "This is a test response",
338
+ "type": "text-delta",
339
+ },
340
+ {
341
+ "id": "0",
342
+ "type": "text-end",
343
+ },
344
+ {
345
+ "id": "1",
346
+ "providerMetadata": undefined,
347
+ "type": "reasoning-start",
348
+ },
349
+ {
350
+ "id": "1",
351
+ "providerMetadata": undefined,
352
+ "text": "First reasoning step",
353
+ "type": "reasoning-delta",
354
+ },
355
+ {
356
+ "id": "1",
357
+ "type": "reasoning-end",
358
+ },
359
+ {
360
+ "id": "2",
361
+ "providerMetadata": undefined,
362
+ "type": "reasoning-start",
363
+ },
364
+ {
365
+ "id": "2",
366
+ "providerMetadata": undefined,
367
+ "text": "Second reasoning step",
368
+ "type": "reasoning-delta",
369
+ },
370
+ {
371
+ "id": "2",
372
+ "type": "reasoning-end",
373
+ },
374
+ {
375
+ "id": "3",
376
+ "providerMetadata": {
377
+ "testProvider": {
378
+ "signature": "abc",
379
+ },
380
+ },
381
+ "type": "reasoning-start",
382
+ },
383
+ {
384
+ "id": "3",
385
+ "providerMetadata": undefined,
386
+ "text": "",
387
+ "type": "reasoning-delta",
388
+ },
389
+ {
390
+ "id": "3",
391
+ "type": "reasoning-end",
392
+ },
393
+ {
394
+ "finishReason": "stop",
395
+ "providerMetadata": undefined,
396
+ "rawFinishReason": "stop",
397
+ "response": {
398
+ "headers": undefined,
399
+ "id": "id-2",
400
+ "modelId": "mock-model-id",
401
+ "timestamp": 2025-01-01T00:00:00.000Z,
402
+ },
403
+ "type": "finish-step",
404
+ "usage": {
405
+ "cachedInputTokens": 0,
406
+ "inputTokenDetails": {
407
+ "cacheReadTokens": 0,
408
+ "cacheWriteTokens": 0,
409
+ "noCacheTokens": 5,
410
+ },
411
+ "inputTokens": 5,
412
+ "outputTokenDetails": {
413
+ "reasoningTokens": 3,
414
+ "textTokens": 10,
415
+ },
416
+ "outputTokens": 10,
417
+ "raw": undefined,
418
+ "reasoningTokens": 3,
419
+ "totalTokens": 15,
420
+ },
421
+ },
422
+ {
423
+ "finishReason": "stop",
424
+ "rawFinishReason": "stop",
425
+ "totalUsage": {
426
+ "cachedInputTokens": 0,
427
+ "inputTokenDetails": {
428
+ "cacheReadTokens": 0,
429
+ "cacheWriteTokens": 0,
430
+ "noCacheTokens": 5,
431
+ },
432
+ "inputTokens": 5,
433
+ "outputTokenDetails": {
434
+ "reasoningTokens": 3,
435
+ "textTokens": 10,
436
+ },
437
+ "outputTokens": 10,
438
+ "reasoningTokens": 3,
439
+ "totalTokens": 15,
440
+ },
441
+ "type": "finish",
442
+ },
443
+ ]
444
+ `);
445
+ });
446
+
447
+ it('should simulate streaming with reasoning as array of mixed objects', async () => {
448
+ const mockModel = new MockLanguageModelV3({
449
+ async doGenerate() {
450
+ return {
451
+ content: [
452
+ {
453
+ type: 'reasoning',
454
+ text: 'First reasoning step',
455
+ },
456
+ {
457
+ type: 'reasoning',
458
+ text: 'data',
459
+ providerMetadata: {
460
+ testProvider: { isRedacted: true },
461
+ },
462
+ },
463
+ {
464
+ type: 'text',
465
+ text: 'This is a test response',
466
+ },
467
+ ],
468
+ finishReason: { unified: 'stop', raw: 'stop' },
469
+ usage: testUsage,
470
+ warnings: [],
471
+ };
472
+ },
473
+ });
474
+
475
+ const result = streamText({
476
+ model: wrapLanguageModel({
477
+ model: mockModel,
478
+ middleware: simulateStreamingMiddleware(),
479
+ }),
480
+ ...DEFAULT_SETTINGs,
481
+ });
482
+
483
+ expect(await convertAsyncIterableToArray(result.fullStream))
484
+ .toMatchInlineSnapshot(`
485
+ [
486
+ {
487
+ "type": "start",
488
+ },
489
+ {
490
+ "request": {},
491
+ "type": "start-step",
492
+ "warnings": [],
493
+ },
494
+ {
495
+ "id": "0",
496
+ "providerMetadata": undefined,
497
+ "type": "reasoning-start",
498
+ },
499
+ {
500
+ "id": "0",
501
+ "providerMetadata": undefined,
502
+ "text": "First reasoning step",
503
+ "type": "reasoning-delta",
504
+ },
505
+ {
506
+ "id": "0",
507
+ "type": "reasoning-end",
508
+ },
509
+ {
510
+ "id": "1",
511
+ "providerMetadata": {
512
+ "testProvider": {
513
+ "isRedacted": true,
514
+ },
515
+ },
516
+ "type": "reasoning-start",
517
+ },
518
+ {
519
+ "id": "1",
520
+ "providerMetadata": undefined,
521
+ "text": "data",
522
+ "type": "reasoning-delta",
523
+ },
524
+ {
525
+ "id": "1",
526
+ "type": "reasoning-end",
527
+ },
528
+ {
529
+ "id": "2",
530
+ "type": "text-start",
531
+ },
532
+ {
533
+ "id": "2",
534
+ "providerMetadata": undefined,
535
+ "text": "This is a test response",
536
+ "type": "text-delta",
537
+ },
538
+ {
539
+ "id": "2",
540
+ "type": "text-end",
541
+ },
542
+ {
543
+ "finishReason": "stop",
544
+ "providerMetadata": undefined,
545
+ "rawFinishReason": "stop",
546
+ "response": {
547
+ "headers": undefined,
548
+ "id": "id-3",
549
+ "modelId": "mock-model-id",
550
+ "timestamp": 2025-01-01T00:00:00.000Z,
551
+ },
552
+ "type": "finish-step",
553
+ "usage": {
554
+ "cachedInputTokens": 0,
555
+ "inputTokenDetails": {
556
+ "cacheReadTokens": 0,
557
+ "cacheWriteTokens": 0,
558
+ "noCacheTokens": 5,
559
+ },
560
+ "inputTokens": 5,
561
+ "outputTokenDetails": {
562
+ "reasoningTokens": 3,
563
+ "textTokens": 10,
564
+ },
565
+ "outputTokens": 10,
566
+ "raw": undefined,
567
+ "reasoningTokens": 3,
568
+ "totalTokens": 15,
569
+ },
570
+ },
571
+ {
572
+ "finishReason": "stop",
573
+ "rawFinishReason": "stop",
574
+ "totalUsage": {
575
+ "cachedInputTokens": 0,
576
+ "inputTokenDetails": {
577
+ "cacheReadTokens": 0,
578
+ "cacheWriteTokens": 0,
579
+ "noCacheTokens": 5,
580
+ },
581
+ "inputTokens": 5,
582
+ "outputTokenDetails": {
583
+ "reasoningTokens": 3,
584
+ "textTokens": 10,
585
+ },
586
+ "outputTokens": 10,
587
+ "reasoningTokens": 3,
588
+ "totalTokens": 15,
589
+ },
590
+ "type": "finish",
591
+ },
592
+ ]
593
+ `);
594
+ });
595
+
596
+ it('should simulate streaming with tool calls', async () => {
597
+ const mockModel = new MockLanguageModelV3({
598
+ async doGenerate() {
599
+ return {
600
+ content: [
601
+ {
602
+ type: 'text',
603
+ text: 'This is a test response',
604
+ },
605
+ {
606
+ type: 'tool-call',
607
+ toolCallId: 'tool-1',
608
+ toolName: 'calculator',
609
+ input: '{"expression": "2+2"}',
610
+ toolCallType: 'function',
611
+ },
612
+ {
613
+ type: 'tool-call',
614
+ toolCallId: 'tool-2',
615
+ toolName: 'weather',
616
+ input: '{"location": "New York"}',
617
+ toolCallType: 'function',
618
+ },
619
+ ],
620
+ finishReason: { unified: 'tool-calls', raw: undefined },
621
+ usage: testUsage,
622
+ warnings: [],
623
+ };
624
+ },
625
+ });
626
+
627
+ const result = streamText({
628
+ model: wrapLanguageModel({
629
+ model: mockModel,
630
+ middleware: simulateStreamingMiddleware(),
631
+ }),
632
+ tools: {
633
+ calculator: tool({
634
+ inputSchema: jsonSchema<{ expression: string }>({
635
+ type: 'object',
636
+ }),
637
+ }),
638
+ weather: tool({
639
+ inputSchema: jsonSchema<{ location: string }>({
640
+ type: 'object',
641
+ }),
642
+ }),
643
+ },
644
+ ...DEFAULT_SETTINGs,
645
+ });
646
+
647
+ expect(await convertAsyncIterableToArray(result.fullStream))
648
+ .toMatchInlineSnapshot(`
649
+ [
650
+ {
651
+ "type": "start",
652
+ },
653
+ {
654
+ "request": {},
655
+ "type": "start-step",
656
+ "warnings": [],
657
+ },
658
+ {
659
+ "id": "0",
660
+ "type": "text-start",
661
+ },
662
+ {
663
+ "id": "0",
664
+ "providerMetadata": undefined,
665
+ "text": "This is a test response",
666
+ "type": "text-delta",
667
+ },
668
+ {
669
+ "id": "0",
670
+ "type": "text-end",
671
+ },
672
+ {
673
+ "input": {
674
+ "expression": "2+2",
675
+ },
676
+ "providerExecuted": undefined,
677
+ "providerMetadata": undefined,
678
+ "title": undefined,
679
+ "toolCallId": "tool-1",
680
+ "toolName": "calculator",
681
+ "type": "tool-call",
682
+ },
683
+ {
684
+ "input": {
685
+ "location": "New York",
686
+ },
687
+ "providerExecuted": undefined,
688
+ "providerMetadata": undefined,
689
+ "title": undefined,
690
+ "toolCallId": "tool-2",
691
+ "toolName": "weather",
692
+ "type": "tool-call",
693
+ },
694
+ {
695
+ "finishReason": "tool-calls",
696
+ "providerMetadata": undefined,
697
+ "rawFinishReason": undefined,
698
+ "response": {
699
+ "headers": undefined,
700
+ "id": "id-4",
701
+ "modelId": "mock-model-id",
702
+ "timestamp": 2025-01-01T00:00:00.000Z,
703
+ },
704
+ "type": "finish-step",
705
+ "usage": {
706
+ "cachedInputTokens": 0,
707
+ "inputTokenDetails": {
708
+ "cacheReadTokens": 0,
709
+ "cacheWriteTokens": 0,
710
+ "noCacheTokens": 5,
711
+ },
712
+ "inputTokens": 5,
713
+ "outputTokenDetails": {
714
+ "reasoningTokens": 3,
715
+ "textTokens": 10,
716
+ },
717
+ "outputTokens": 10,
718
+ "raw": undefined,
719
+ "reasoningTokens": 3,
720
+ "totalTokens": 15,
721
+ },
722
+ },
723
+ {
724
+ "finishReason": "tool-calls",
725
+ "rawFinishReason": undefined,
726
+ "totalUsage": {
727
+ "cachedInputTokens": 0,
728
+ "inputTokenDetails": {
729
+ "cacheReadTokens": 0,
730
+ "cacheWriteTokens": 0,
731
+ "noCacheTokens": 5,
732
+ },
733
+ "inputTokens": 5,
734
+ "outputTokenDetails": {
735
+ "reasoningTokens": 3,
736
+ "textTokens": 10,
737
+ },
738
+ "outputTokens": 10,
739
+ "reasoningTokens": 3,
740
+ "totalTokens": 15,
741
+ },
742
+ "type": "finish",
743
+ },
744
+ ]
745
+ `);
746
+ });
747
+
748
+ it('should preserve additional metadata in the response', async () => {
749
+ const mockModel = new MockLanguageModelV3({
750
+ async doGenerate() {
751
+ return {
752
+ content: [{ type: 'text', text: 'This is a test response' }],
753
+ finishReason: { unified: 'stop', raw: 'stop' },
754
+ usage: testUsage,
755
+ providerMetadata: { custom: { key: 'value' } },
756
+ warnings: [],
757
+ };
758
+ },
759
+ });
760
+
761
+ const result = streamText({
762
+ model: wrapLanguageModel({
763
+ model: mockModel,
764
+ middleware: simulateStreamingMiddleware(),
765
+ }),
766
+ ...DEFAULT_SETTINGs,
767
+ });
768
+
769
+ expect(await convertAsyncIterableToArray(result.fullStream))
770
+ .toMatchInlineSnapshot(`
771
+ [
772
+ {
773
+ "type": "start",
774
+ },
775
+ {
776
+ "request": {},
777
+ "type": "start-step",
778
+ "warnings": [],
779
+ },
780
+ {
781
+ "id": "0",
782
+ "type": "text-start",
783
+ },
784
+ {
785
+ "id": "0",
786
+ "providerMetadata": undefined,
787
+ "text": "This is a test response",
788
+ "type": "text-delta",
789
+ },
790
+ {
791
+ "id": "0",
792
+ "type": "text-end",
793
+ },
794
+ {
795
+ "finishReason": "stop",
796
+ "providerMetadata": {
797
+ "custom": {
798
+ "key": "value",
799
+ },
800
+ },
801
+ "rawFinishReason": "stop",
802
+ "response": {
803
+ "headers": undefined,
804
+ "id": "id-5",
805
+ "modelId": "mock-model-id",
806
+ "timestamp": 2025-01-01T00:00:00.000Z,
807
+ },
808
+ "type": "finish-step",
809
+ "usage": {
810
+ "cachedInputTokens": 0,
811
+ "inputTokenDetails": {
812
+ "cacheReadTokens": 0,
813
+ "cacheWriteTokens": 0,
814
+ "noCacheTokens": 5,
815
+ },
816
+ "inputTokens": 5,
817
+ "outputTokenDetails": {
818
+ "reasoningTokens": 3,
819
+ "textTokens": 10,
820
+ },
821
+ "outputTokens": 10,
822
+ "raw": undefined,
823
+ "reasoningTokens": 3,
824
+ "totalTokens": 15,
825
+ },
826
+ },
827
+ {
828
+ "finishReason": "stop",
829
+ "rawFinishReason": "stop",
830
+ "totalUsage": {
831
+ "cachedInputTokens": 0,
832
+ "inputTokenDetails": {
833
+ "cacheReadTokens": 0,
834
+ "cacheWriteTokens": 0,
835
+ "noCacheTokens": 5,
836
+ },
837
+ "inputTokens": 5,
838
+ "outputTokenDetails": {
839
+ "reasoningTokens": 3,
840
+ "textTokens": 10,
841
+ },
842
+ "outputTokens": 10,
843
+ "reasoningTokens": 3,
844
+ "totalTokens": 15,
845
+ },
846
+ "type": "finish",
847
+ },
848
+ ]
849
+ `);
850
+ });
851
+
852
+ it('should handle empty text response', async () => {
853
+ const mockModel = new MockLanguageModelV3({
854
+ async doGenerate() {
855
+ return {
856
+ content: [{ type: 'text', text: '' }],
857
+ finishReason: { unified: 'stop', raw: 'stop' },
858
+ usage: testUsage,
859
+ warnings: [],
860
+ };
861
+ },
862
+ });
863
+
864
+ const result = streamText({
865
+ model: wrapLanguageModel({
866
+ model: mockModel,
867
+ middleware: simulateStreamingMiddleware(),
868
+ }),
869
+ ...DEFAULT_SETTINGs,
870
+ });
871
+
872
+ expect(
873
+ await convertAsyncIterableToArray(result.fullStream),
874
+ ).toMatchSnapshot();
875
+ });
876
+
877
+ it('should pass through warnings from the model', async () => {
878
+ const mockModel = new MockLanguageModelV3({
879
+ async doGenerate() {
880
+ return {
881
+ content: [{ type: 'text', text: 'This is a test response' }],
882
+ finishReason: { unified: 'stop', raw: 'stop' },
883
+ usage: testUsage,
884
+ warnings: [
885
+ { type: 'other', message: 'Test warning', code: 'test_warning' },
886
+ ],
887
+ };
888
+ },
889
+ });
890
+
891
+ const result = streamText({
892
+ model: wrapLanguageModel({
893
+ model: mockModel,
894
+ middleware: simulateStreamingMiddleware(),
895
+ }),
896
+ ...DEFAULT_SETTINGs,
897
+ });
898
+
899
+ result.consumeStream();
900
+
901
+ expect(await result.warnings).toMatchInlineSnapshot(`
902
+ [
903
+ {
904
+ "code": "test_warning",
905
+ "message": "Test warning",
906
+ "type": "other",
907
+ },
908
+ ]
909
+ `);
910
+ });
911
+ });