@ai-sdk/provider-utils 3.1.0-beta.0 → 3.1.0-beta.2

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.
@@ -1,5 +1,3 @@
1
- import { JsonBodyType } from 'msw';
2
-
3
1
  declare function convertArrayToAsyncIterable<T>(values: T[]): AsyncIterable<T>;
4
2
 
5
3
  declare function convertArrayToReadableStream<T>(values: T[]): ReadableStream<T>;
@@ -16,73 +14,4 @@ declare function mockId({ prefix, }?: {
16
14
  prefix?: string;
17
15
  }): () => string;
18
16
 
19
- type UrlResponse = {
20
- type: 'json-value';
21
- headers?: Record<string, string>;
22
- body: JsonBodyType;
23
- } | {
24
- type: 'stream-chunks';
25
- headers?: Record<string, string>;
26
- chunks: Array<string>;
27
- } | {
28
- type: 'binary';
29
- headers?: Record<string, string>;
30
- body: Buffer;
31
- } | {
32
- type: 'empty';
33
- headers?: Record<string, string>;
34
- status?: number;
35
- } | {
36
- type: 'error';
37
- headers?: Record<string, string>;
38
- status?: number;
39
- body?: string;
40
- } | {
41
- type: 'controlled-stream';
42
- headers?: Record<string, string>;
43
- controller: TestResponseController;
44
- } | undefined;
45
- type UrlResponseParameter = UrlResponse | UrlResponse[] | ((options: {
46
- callNumber: number;
47
- }) => UrlResponse);
48
- type UrlHandler = {
49
- response: UrlResponseParameter;
50
- };
51
- type UrlHandlers<URLS extends {
52
- [url: string]: {
53
- response?: UrlResponseParameter;
54
- };
55
- }> = {
56
- [url in keyof URLS]: UrlHandler;
57
- };
58
- declare class TestServerCall {
59
- private request;
60
- constructor(request: Request);
61
- get requestBodyJson(): Promise<any>;
62
- get requestBodyMultipart(): Promise<Record<string, any>> | null;
63
- get requestCredentials(): RequestCredentials;
64
- get requestHeaders(): Record<string, string>;
65
- get requestUserAgent(): string | undefined;
66
- get requestUrlSearchParams(): URLSearchParams;
67
- get requestUrl(): string;
68
- get requestMethod(): string;
69
- }
70
- declare function createTestServer<URLS extends {
71
- [url: string]: {
72
- response?: UrlResponseParameter;
73
- };
74
- }>(routes: URLS): {
75
- urls: UrlHandlers<URLS>;
76
- calls: TestServerCall[];
77
- };
78
- declare class TestResponseController {
79
- private readonly transformStream;
80
- private readonly writer;
81
- constructor();
82
- get stream(): ReadableStream;
83
- write(chunk: string): Promise<void>;
84
- error(error: Error): Promise<void>;
85
- close(): Promise<void>;
86
- }
87
-
88
- export { TestResponseController, type UrlHandler, type UrlHandlers, type UrlResponse, convertArrayToAsyncIterable, convertArrayToReadableStream, convertAsyncIterableToArray, convertReadableStreamToArray, convertResponseStreamToArray, createTestServer, isNodeVersion, mockId };
17
+ export { convertArrayToAsyncIterable, convertArrayToReadableStream, convertAsyncIterableToArray, convertReadableStreamToArray, convertResponseStreamToArray, isNodeVersion, mockId };
@@ -1,5 +1,3 @@
1
- import { JsonBodyType } from 'msw';
2
-
3
1
  declare function convertArrayToAsyncIterable<T>(values: T[]): AsyncIterable<T>;
4
2
 
5
3
  declare function convertArrayToReadableStream<T>(values: T[]): ReadableStream<T>;
@@ -16,73 +14,4 @@ declare function mockId({ prefix, }?: {
16
14
  prefix?: string;
17
15
  }): () => string;
18
16
 
19
- type UrlResponse = {
20
- type: 'json-value';
21
- headers?: Record<string, string>;
22
- body: JsonBodyType;
23
- } | {
24
- type: 'stream-chunks';
25
- headers?: Record<string, string>;
26
- chunks: Array<string>;
27
- } | {
28
- type: 'binary';
29
- headers?: Record<string, string>;
30
- body: Buffer;
31
- } | {
32
- type: 'empty';
33
- headers?: Record<string, string>;
34
- status?: number;
35
- } | {
36
- type: 'error';
37
- headers?: Record<string, string>;
38
- status?: number;
39
- body?: string;
40
- } | {
41
- type: 'controlled-stream';
42
- headers?: Record<string, string>;
43
- controller: TestResponseController;
44
- } | undefined;
45
- type UrlResponseParameter = UrlResponse | UrlResponse[] | ((options: {
46
- callNumber: number;
47
- }) => UrlResponse);
48
- type UrlHandler = {
49
- response: UrlResponseParameter;
50
- };
51
- type UrlHandlers<URLS extends {
52
- [url: string]: {
53
- response?: UrlResponseParameter;
54
- };
55
- }> = {
56
- [url in keyof URLS]: UrlHandler;
57
- };
58
- declare class TestServerCall {
59
- private request;
60
- constructor(request: Request);
61
- get requestBodyJson(): Promise<any>;
62
- get requestBodyMultipart(): Promise<Record<string, any>> | null;
63
- get requestCredentials(): RequestCredentials;
64
- get requestHeaders(): Record<string, string>;
65
- get requestUserAgent(): string | undefined;
66
- get requestUrlSearchParams(): URLSearchParams;
67
- get requestUrl(): string;
68
- get requestMethod(): string;
69
- }
70
- declare function createTestServer<URLS extends {
71
- [url: string]: {
72
- response?: UrlResponseParameter;
73
- };
74
- }>(routes: URLS): {
75
- urls: UrlHandlers<URLS>;
76
- calls: TestServerCall[];
77
- };
78
- declare class TestResponseController {
79
- private readonly transformStream;
80
- private readonly writer;
81
- constructor();
82
- get stream(): ReadableStream;
83
- write(chunk: string): Promise<void>;
84
- error(error: Error): Promise<void>;
85
- close(): Promise<void>;
86
- }
87
-
88
- export { TestResponseController, type UrlHandler, type UrlHandlers, type UrlResponse, convertArrayToAsyncIterable, convertArrayToReadableStream, convertAsyncIterableToArray, convertReadableStreamToArray, convertResponseStreamToArray, createTestServer, isNodeVersion, mockId };
17
+ export { convertArrayToAsyncIterable, convertArrayToReadableStream, convertAsyncIterableToArray, convertReadableStreamToArray, convertResponseStreamToArray, isNodeVersion, mockId };
@@ -20,13 +20,11 @@ var __toCommonJS = (mod) => __copyProps(__defProp({}, "__esModule", { value: tru
20
20
  // src/test/index.ts
21
21
  var test_exports = {};
22
22
  __export(test_exports, {
23
- TestResponseController: () => TestResponseController,
24
23
  convertArrayToAsyncIterable: () => convertArrayToAsyncIterable,
25
24
  convertArrayToReadableStream: () => convertArrayToReadableStream,
26
25
  convertAsyncIterableToArray: () => convertAsyncIterableToArray,
27
26
  convertReadableStreamToArray: () => convertReadableStreamToArray,
28
27
  convertResponseStreamToArray: () => convertResponseStreamToArray,
29
- createTestServer: () => createTestServer,
30
28
  isNodeVersion: () => isNodeVersion,
31
29
  mockId: () => mockId
32
30
  });
@@ -73,8 +71,7 @@ async function convertReadableStreamToArray(stream) {
73
71
  const result = [];
74
72
  while (true) {
75
73
  const { done, value } = await reader.read();
76
- if (done)
77
- break;
74
+ if (done) break;
78
75
  result.push(value);
79
76
  }
80
77
  return result;
@@ -100,186 +97,13 @@ function mockId({
100
97
  let counter = 0;
101
98
  return () => `${prefix}-${counter++}`;
102
99
  }
103
-
104
- // src/test/test-server.ts
105
- var import_msw = require("msw");
106
- var import_node = require("msw/node");
107
- var import_vitest = require("vitest");
108
- var TestServerCall = class {
109
- constructor(request) {
110
- this.request = request;
111
- }
112
- get requestBodyJson() {
113
- return this.request.text().then(JSON.parse);
114
- }
115
- get requestBodyMultipart() {
116
- return this.request.headers.get("content-type")?.startsWith(
117
- "multipart/form-data"
118
- ) ? (
119
- // For multipart/form-data, return the form data entries as an object
120
- this.request.formData().then((formData) => {
121
- const entries = {};
122
- formData.forEach((value, key) => {
123
- entries[key] = value;
124
- });
125
- return entries;
126
- })
127
- ) : null;
128
- }
129
- get requestCredentials() {
130
- return this.request.credentials;
131
- }
132
- get requestHeaders() {
133
- const requestHeaders = this.request.headers;
134
- const headersObject = {};
135
- requestHeaders.forEach((value, key) => {
136
- if (key.toLowerCase() === "user-agent")
137
- return;
138
- headersObject[key] = value;
139
- });
140
- return headersObject;
141
- }
142
- get requestUserAgent() {
143
- return this.request.headers.get("user-agent") ?? void 0;
144
- }
145
- get requestUrlSearchParams() {
146
- return new URL(this.request.url).searchParams;
147
- }
148
- get requestUrl() {
149
- return this.request.url;
150
- }
151
- get requestMethod() {
152
- return this.request.method;
153
- }
154
- };
155
- function createTestServer(routes) {
156
- const originalRoutes = structuredClone(routes);
157
- const mswServer = (0, import_node.setupServer)(
158
- ...Object.entries(routes).map(([url, handler]) => {
159
- return import_msw.http.all(url, ({ request }) => {
160
- const callNumber = calls.length;
161
- calls.push(new TestServerCall(request));
162
- const response = typeof handler.response === "function" ? handler.response({ callNumber }) : Array.isArray(handler.response) ? handler.response[callNumber] : handler.response;
163
- if (response === void 0) {
164
- return import_msw.HttpResponse.json({ error: "Not Found" }, { status: 404 });
165
- }
166
- const handlerType = response.type;
167
- switch (handlerType) {
168
- case "json-value":
169
- return import_msw.HttpResponse.json(response.body, {
170
- status: 200,
171
- headers: {
172
- "Content-Type": "application/json",
173
- ...response.headers
174
- }
175
- });
176
- case "stream-chunks":
177
- return new import_msw.HttpResponse(
178
- convertArrayToReadableStream(response.chunks).pipeThrough(
179
- new TextEncoderStream()
180
- ),
181
- {
182
- status: 200,
183
- headers: {
184
- "Content-Type": "text/event-stream",
185
- "Cache-Control": "no-cache",
186
- Connection: "keep-alive",
187
- ...response.headers
188
- }
189
- }
190
- );
191
- case "controlled-stream": {
192
- if (request.signal) {
193
- request.signal.addEventListener("abort", () => {
194
- response.controller.error(
195
- new DOMException("Aborted", "AbortError")
196
- );
197
- });
198
- }
199
- return new import_msw.HttpResponse(
200
- response.controller.stream.pipeThrough(new TextEncoderStream()),
201
- {
202
- status: 200,
203
- headers: {
204
- "Content-Type": "text/event-stream",
205
- "Cache-Control": "no-cache",
206
- Connection: "keep-alive",
207
- ...response.headers
208
- }
209
- }
210
- );
211
- }
212
- case "binary": {
213
- return import_msw.HttpResponse.arrayBuffer(response.body, {
214
- status: 200,
215
- headers: response.headers
216
- });
217
- }
218
- case "error":
219
- return import_msw.HttpResponse.text(response.body ?? "Error", {
220
- status: response.status ?? 500,
221
- headers: response.headers
222
- });
223
- case "empty":
224
- return new import_msw.HttpResponse(null, {
225
- status: response.status ?? 200
226
- });
227
- default: {
228
- const _exhaustiveCheck = handlerType;
229
- throw new Error(`Unknown response type: ${_exhaustiveCheck}`);
230
- }
231
- }
232
- });
233
- })
234
- );
235
- let calls = [];
236
- (0, import_vitest.beforeAll)(() => {
237
- mswServer.listen();
238
- });
239
- (0, import_vitest.beforeEach)(() => {
240
- mswServer.resetHandlers();
241
- Object.entries(originalRoutes).forEach(([url, handler]) => {
242
- routes[url].response = handler.response;
243
- });
244
- calls = [];
245
- });
246
- (0, import_vitest.afterAll)(() => {
247
- mswServer.close();
248
- });
249
- return {
250
- urls: routes,
251
- get calls() {
252
- return calls;
253
- }
254
- };
255
- }
256
- var TestResponseController = class {
257
- constructor() {
258
- this.transformStream = new TransformStream();
259
- this.writer = this.transformStream.writable.getWriter();
260
- }
261
- get stream() {
262
- return this.transformStream.readable;
263
- }
264
- async write(chunk) {
265
- await this.writer.write(chunk);
266
- }
267
- async error(error) {
268
- await this.writer.abort(error);
269
- }
270
- async close() {
271
- await this.writer.close();
272
- }
273
- };
274
100
  // Annotate the CommonJS export names for ESM import in node:
275
101
  0 && (module.exports = {
276
- TestResponseController,
277
102
  convertArrayToAsyncIterable,
278
103
  convertArrayToReadableStream,
279
104
  convertAsyncIterableToArray,
280
105
  convertReadableStreamToArray,
281
106
  convertResponseStreamToArray,
282
- createTestServer,
283
107
  isNodeVersion,
284
108
  mockId
285
109
  });
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/test/index.ts","../../src/test/convert-array-to-async-iterable.ts","../../src/test/convert-array-to-readable-stream.ts","../../src/test/convert-async-iterable-to-array.ts","../../src/test/convert-readable-stream-to-array.ts","../../src/test/convert-response-stream-to-array.ts","../../src/test/is-node-version.ts","../../src/test/mock-id.ts","../../src/test/test-server.ts"],"sourcesContent":["export * from './convert-array-to-async-iterable';\nexport * from './convert-array-to-readable-stream';\nexport * from './convert-async-iterable-to-array';\nexport * from './convert-readable-stream-to-array';\nexport * from './convert-response-stream-to-array';\nexport * from './is-node-version';\nexport * from './mock-id';\nexport * from './test-server';\n","export function convertArrayToAsyncIterable<T>(values: T[]): AsyncIterable<T> {\n return {\n async *[Symbol.asyncIterator]() {\n for (const value of values) {\n yield value;\n }\n },\n };\n}\n","export function convertArrayToReadableStream<T>(\n values: T[],\n): ReadableStream<T> {\n return new ReadableStream({\n start(controller) {\n try {\n for (const value of values) {\n controller.enqueue(value);\n }\n } finally {\n controller.close();\n }\n },\n });\n}\n","export async function convertAsyncIterableToArray<T>(\n iterable: AsyncIterable<T>,\n): Promise<T[]> {\n const result: T[] = [];\n for await (const item of iterable) {\n result.push(item);\n }\n return result;\n}\n","export async function convertReadableStreamToArray<T>(\n stream: ReadableStream<T>,\n): Promise<T[]> {\n const reader = stream.getReader();\n const result: T[] = [];\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n result.push(value);\n }\n\n return result;\n}\n","import { convertReadableStreamToArray } from './convert-readable-stream-to-array';\n\nexport async function convertResponseStreamToArray(\n response: Response,\n): Promise<string[]> {\n return convertReadableStreamToArray(\n response.body!.pipeThrough(new TextDecoderStream()),\n );\n}\n","export function isNodeVersion(version: number) {\n const nodeMajorVersion = parseInt(process.version.slice(1).split('.')[0], 10);\n return nodeMajorVersion === version;\n}\n","export function mockId({\n prefix = 'id',\n}: {\n prefix?: string;\n} = {}): () => string {\n let counter = 0;\n return () => `${prefix}-${counter++}`;\n}\n","import { http, HttpResponse, JsonBodyType } from 'msw';\nimport { setupServer } from 'msw/node';\nimport { convertArrayToReadableStream } from './convert-array-to-readable-stream';\nimport { beforeAll, beforeEach, afterAll } from 'vitest';\n\nexport type UrlResponse =\n | {\n type: 'json-value';\n headers?: Record<string, string>;\n body: JsonBodyType;\n }\n | {\n type: 'stream-chunks';\n headers?: Record<string, string>;\n chunks: Array<string>;\n }\n | {\n type: 'binary';\n headers?: Record<string, string>;\n body: Buffer;\n }\n | {\n type: 'empty';\n headers?: Record<string, string>;\n status?: number;\n }\n | {\n type: 'error';\n headers?: Record<string, string>;\n status?: number;\n body?: string;\n }\n | {\n type: 'controlled-stream';\n headers?: Record<string, string>;\n controller: TestResponseController;\n }\n | undefined;\n\ntype UrlResponseParameter =\n | UrlResponse\n | UrlResponse[]\n | ((options: { callNumber: number }) => UrlResponse);\n\nexport type UrlHandler = {\n response: UrlResponseParameter;\n};\n\nexport type UrlHandlers<\n URLS extends {\n [url: string]: {\n response?: UrlResponseParameter;\n };\n },\n> = {\n [url in keyof URLS]: UrlHandler;\n};\n\nclass TestServerCall {\n constructor(private request: Request) {}\n\n get requestBodyJson() {\n return this.request!.text().then(JSON.parse);\n }\n\n get requestBodyMultipart() {\n return this.request!.headers.get('content-type')?.startsWith(\n 'multipart/form-data',\n )\n ? // For multipart/form-data, return the form data entries as an object\n this.request!.formData().then(formData => {\n const entries: Record<string, any> = {};\n formData.forEach((value, key) => {\n entries[key] = value;\n });\n return entries;\n })\n : null;\n }\n\n get requestCredentials() {\n return this.request!.credentials;\n }\n\n get requestHeaders() {\n const requestHeaders = this.request!.headers;\n\n // convert headers to object for easier comparison\n const headersObject: Record<string, string> = {};\n requestHeaders.forEach((value, key) => {\n if (key.toLowerCase() === 'user-agent') return;\n headersObject[key] = value;\n });\n\n return headersObject;\n }\n\n get requestUserAgent(): string | undefined {\n return this.request!.headers.get('user-agent') ?? undefined;\n }\n\n get requestUrlSearchParams() {\n return new URL(this.request!.url).searchParams;\n }\n\n get requestUrl() {\n return this.request!.url;\n }\n\n get requestMethod() {\n return this.request!.method;\n }\n}\n\nexport function createTestServer<\n URLS extends {\n [url: string]: {\n response?: UrlResponseParameter;\n };\n },\n>(\n routes: URLS,\n): {\n urls: UrlHandlers<URLS>;\n calls: TestServerCall[];\n} {\n const originalRoutes = structuredClone(routes); // deep copy\n\n const mswServer = setupServer(\n ...Object.entries(routes).map(([url, handler]) => {\n return http.all(url, ({ request }) => {\n const callNumber = calls.length;\n\n calls.push(new TestServerCall(request));\n\n const response =\n typeof handler.response === 'function'\n ? handler.response({ callNumber })\n : Array.isArray(handler.response)\n ? handler.response[callNumber]\n : handler.response;\n\n if (response === undefined) {\n return HttpResponse.json({ error: 'Not Found' }, { status: 404 });\n }\n\n const handlerType = response.type;\n\n switch (handlerType) {\n case 'json-value':\n return HttpResponse.json(response.body, {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n ...response.headers,\n },\n });\n\n case 'stream-chunks':\n return new HttpResponse(\n convertArrayToReadableStream(response.chunks).pipeThrough(\n new TextEncoderStream(),\n ),\n {\n status: 200,\n headers: {\n 'Content-Type': 'text/event-stream',\n 'Cache-Control': 'no-cache',\n Connection: 'keep-alive',\n ...response.headers,\n },\n },\n );\n\n case 'controlled-stream': {\n if (request.signal) {\n request.signal.addEventListener('abort', () => {\n response.controller.error(\n new DOMException('Aborted', 'AbortError'),\n );\n });\n }\n\n return new HttpResponse(\n response.controller.stream.pipeThrough(new TextEncoderStream()),\n {\n status: 200,\n headers: {\n 'Content-Type': 'text/event-stream',\n 'Cache-Control': 'no-cache',\n Connection: 'keep-alive',\n ...response.headers,\n },\n },\n );\n }\n\n case 'binary': {\n return HttpResponse.arrayBuffer(response.body, {\n status: 200,\n headers: response.headers,\n });\n }\n\n case 'error':\n return HttpResponse.text(response.body ?? 'Error', {\n status: response.status ?? 500,\n headers: response.headers,\n });\n\n case 'empty':\n return new HttpResponse(null, {\n status: response.status ?? 200,\n });\n\n default: {\n const _exhaustiveCheck: never = handlerType;\n throw new Error(`Unknown response type: ${_exhaustiveCheck}`);\n }\n }\n });\n }),\n );\n\n let calls: TestServerCall[] = [];\n\n beforeAll(() => {\n mswServer.listen();\n });\n\n beforeEach(() => {\n mswServer.resetHandlers();\n\n // set the responses back to the original values\n Object.entries(originalRoutes).forEach(([url, handler]) => {\n routes[url].response = handler.response;\n });\n\n calls = [];\n });\n\n afterAll(() => {\n mswServer.close();\n });\n\n return {\n urls: routes as UrlHandlers<URLS>,\n get calls() {\n return calls;\n },\n };\n}\n\nexport class TestResponseController {\n private readonly transformStream: TransformStream;\n private readonly writer: WritableStreamDefaultWriter;\n\n constructor() {\n this.transformStream = new TransformStream();\n this.writer = this.transformStream.writable.getWriter();\n }\n\n get stream(): ReadableStream {\n return this.transformStream.readable;\n }\n\n async write(chunk: string): Promise<void> {\n await this.writer.write(chunk);\n }\n\n async error(error: Error): Promise<void> {\n await this.writer.abort(error);\n }\n\n async close(): Promise<void> {\n await this.writer.close();\n }\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../src/test/index.ts","../../src/test/convert-array-to-async-iterable.ts","../../src/test/convert-array-to-readable-stream.ts","../../src/test/convert-async-iterable-to-array.ts","../../src/test/convert-readable-stream-to-array.ts","../../src/test/convert-response-stream-to-array.ts","../../src/test/is-node-version.ts","../../src/test/mock-id.ts"],"sourcesContent":["export * from './convert-array-to-async-iterable';\nexport * from './convert-array-to-readable-stream';\nexport * from './convert-async-iterable-to-array';\nexport * from './convert-readable-stream-to-array';\nexport * from './convert-response-stream-to-array';\nexport * from './is-node-version';\nexport * from './mock-id';\n","export function convertArrayToAsyncIterable<T>(values: T[]): AsyncIterable<T> {\n return {\n async *[Symbol.asyncIterator]() {\n for (const value of values) {\n yield value;\n }\n },\n };\n}\n","export function convertArrayToReadableStream<T>(\n values: T[],\n): ReadableStream<T> {\n return new ReadableStream({\n start(controller) {\n try {\n for (const value of values) {\n controller.enqueue(value);\n }\n } finally {\n controller.close();\n }\n },\n });\n}\n","export async function convertAsyncIterableToArray<T>(\n iterable: AsyncIterable<T>,\n): Promise<T[]> {\n const result: T[] = [];\n for await (const item of iterable) {\n result.push(item);\n }\n return result;\n}\n","export async function convertReadableStreamToArray<T>(\n stream: ReadableStream<T>,\n): Promise<T[]> {\n const reader = stream.getReader();\n const result: T[] = [];\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n result.push(value);\n }\n\n return result;\n}\n","import { convertReadableStreamToArray } from './convert-readable-stream-to-array';\n\nexport async function convertResponseStreamToArray(\n response: Response,\n): Promise<string[]> {\n return convertReadableStreamToArray(\n response.body!.pipeThrough(new TextDecoderStream()),\n );\n}\n","export function isNodeVersion(version: number) {\n const nodeMajorVersion = parseInt(process.version.slice(1).split('.')[0], 10);\n return nodeMajorVersion === version;\n}\n","export function mockId({\n prefix = 'id',\n}: {\n prefix?: string;\n} = {}): () => string {\n let counter = 0;\n return () => `${prefix}-${counter++}`;\n}\n"],"mappings":";;;;;;;;;;;;;;;;;;;;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA;;;ACAO,SAAS,4BAA+B,QAA+B;AAC5E,SAAO;AAAA,IACL,QAAQ,OAAO,aAAa,IAAI;AAC9B,iBAAW,SAAS,QAAQ;AAC1B,cAAM;AAAA,MACR;AAAA,IACF;AAAA,EACF;AACF;;;ACRO,SAAS,6BACd,QACmB;AACnB,SAAO,IAAI,eAAe;AAAA,IACxB,MAAM,YAAY;AAChB,UAAI;AACF,mBAAW,SAAS,QAAQ;AAC1B,qBAAW,QAAQ,KAAK;AAAA,QAC1B;AAAA,MACF,UAAE;AACA,mBAAW,MAAM;AAAA,MACnB;AAAA,IACF;AAAA,EACF,CAAC;AACH;;;ACdA,eAAsB,4BACpB,UACc;AACd,QAAM,SAAc,CAAC;AACrB,mBAAiB,QAAQ,UAAU;AACjC,WAAO,KAAK,IAAI;AAAA,EAClB;AACA,SAAO;AACT;;;ACRA,eAAsB,6BACpB,QACc;AACd,QAAM,SAAS,OAAO,UAAU;AAChC,QAAM,SAAc,CAAC;AAErB,SAAO,MAAM;AACX,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,OAAO,KAAK;AAC1C,QAAI,KAAM;AACV,WAAO,KAAK,KAAK;AAAA,EACnB;AAEA,SAAO;AACT;;;ACXA,eAAsB,6BACpB,UACmB;AACnB,SAAO;AAAA,IACL,SAAS,KAAM,YAAY,IAAI,kBAAkB,CAAC;AAAA,EACpD;AACF;;;ACRO,SAAS,cAAc,SAAiB;AAC7C,QAAM,mBAAmB,SAAS,QAAQ,QAAQ,MAAM,CAAC,EAAE,MAAM,GAAG,EAAE,CAAC,GAAG,EAAE;AAC5E,SAAO,qBAAqB;AAC9B;;;ACHO,SAAS,OAAO;AAAA,EACrB,SAAS;AACX,IAEI,CAAC,GAAiB;AACpB,MAAI,UAAU;AACd,SAAO,MAAM,GAAG,MAAM,IAAI,SAAS;AACrC;","names":[]}
@@ -39,8 +39,7 @@ async function convertReadableStreamToArray(stream) {
39
39
  const result = [];
40
40
  while (true) {
41
41
  const { done, value } = await reader.read();
42
- if (done)
43
- break;
42
+ if (done) break;
44
43
  result.push(value);
45
44
  }
46
45
  return result;
@@ -66,185 +65,12 @@ function mockId({
66
65
  let counter = 0;
67
66
  return () => `${prefix}-${counter++}`;
68
67
  }
69
-
70
- // src/test/test-server.ts
71
- import { http, HttpResponse } from "msw";
72
- import { setupServer } from "msw/node";
73
- import { beforeAll, beforeEach, afterAll } from "vitest";
74
- var TestServerCall = class {
75
- constructor(request) {
76
- this.request = request;
77
- }
78
- get requestBodyJson() {
79
- return this.request.text().then(JSON.parse);
80
- }
81
- get requestBodyMultipart() {
82
- return this.request.headers.get("content-type")?.startsWith(
83
- "multipart/form-data"
84
- ) ? (
85
- // For multipart/form-data, return the form data entries as an object
86
- this.request.formData().then((formData) => {
87
- const entries = {};
88
- formData.forEach((value, key) => {
89
- entries[key] = value;
90
- });
91
- return entries;
92
- })
93
- ) : null;
94
- }
95
- get requestCredentials() {
96
- return this.request.credentials;
97
- }
98
- get requestHeaders() {
99
- const requestHeaders = this.request.headers;
100
- const headersObject = {};
101
- requestHeaders.forEach((value, key) => {
102
- if (key.toLowerCase() === "user-agent")
103
- return;
104
- headersObject[key] = value;
105
- });
106
- return headersObject;
107
- }
108
- get requestUserAgent() {
109
- return this.request.headers.get("user-agent") ?? void 0;
110
- }
111
- get requestUrlSearchParams() {
112
- return new URL(this.request.url).searchParams;
113
- }
114
- get requestUrl() {
115
- return this.request.url;
116
- }
117
- get requestMethod() {
118
- return this.request.method;
119
- }
120
- };
121
- function createTestServer(routes) {
122
- const originalRoutes = structuredClone(routes);
123
- const mswServer = setupServer(
124
- ...Object.entries(routes).map(([url, handler]) => {
125
- return http.all(url, ({ request }) => {
126
- const callNumber = calls.length;
127
- calls.push(new TestServerCall(request));
128
- const response = typeof handler.response === "function" ? handler.response({ callNumber }) : Array.isArray(handler.response) ? handler.response[callNumber] : handler.response;
129
- if (response === void 0) {
130
- return HttpResponse.json({ error: "Not Found" }, { status: 404 });
131
- }
132
- const handlerType = response.type;
133
- switch (handlerType) {
134
- case "json-value":
135
- return HttpResponse.json(response.body, {
136
- status: 200,
137
- headers: {
138
- "Content-Type": "application/json",
139
- ...response.headers
140
- }
141
- });
142
- case "stream-chunks":
143
- return new HttpResponse(
144
- convertArrayToReadableStream(response.chunks).pipeThrough(
145
- new TextEncoderStream()
146
- ),
147
- {
148
- status: 200,
149
- headers: {
150
- "Content-Type": "text/event-stream",
151
- "Cache-Control": "no-cache",
152
- Connection: "keep-alive",
153
- ...response.headers
154
- }
155
- }
156
- );
157
- case "controlled-stream": {
158
- if (request.signal) {
159
- request.signal.addEventListener("abort", () => {
160
- response.controller.error(
161
- new DOMException("Aborted", "AbortError")
162
- );
163
- });
164
- }
165
- return new HttpResponse(
166
- response.controller.stream.pipeThrough(new TextEncoderStream()),
167
- {
168
- status: 200,
169
- headers: {
170
- "Content-Type": "text/event-stream",
171
- "Cache-Control": "no-cache",
172
- Connection: "keep-alive",
173
- ...response.headers
174
- }
175
- }
176
- );
177
- }
178
- case "binary": {
179
- return HttpResponse.arrayBuffer(response.body, {
180
- status: 200,
181
- headers: response.headers
182
- });
183
- }
184
- case "error":
185
- return HttpResponse.text(response.body ?? "Error", {
186
- status: response.status ?? 500,
187
- headers: response.headers
188
- });
189
- case "empty":
190
- return new HttpResponse(null, {
191
- status: response.status ?? 200
192
- });
193
- default: {
194
- const _exhaustiveCheck = handlerType;
195
- throw new Error(`Unknown response type: ${_exhaustiveCheck}`);
196
- }
197
- }
198
- });
199
- })
200
- );
201
- let calls = [];
202
- beforeAll(() => {
203
- mswServer.listen();
204
- });
205
- beforeEach(() => {
206
- mswServer.resetHandlers();
207
- Object.entries(originalRoutes).forEach(([url, handler]) => {
208
- routes[url].response = handler.response;
209
- });
210
- calls = [];
211
- });
212
- afterAll(() => {
213
- mswServer.close();
214
- });
215
- return {
216
- urls: routes,
217
- get calls() {
218
- return calls;
219
- }
220
- };
221
- }
222
- var TestResponseController = class {
223
- constructor() {
224
- this.transformStream = new TransformStream();
225
- this.writer = this.transformStream.writable.getWriter();
226
- }
227
- get stream() {
228
- return this.transformStream.readable;
229
- }
230
- async write(chunk) {
231
- await this.writer.write(chunk);
232
- }
233
- async error(error) {
234
- await this.writer.abort(error);
235
- }
236
- async close() {
237
- await this.writer.close();
238
- }
239
- };
240
68
  export {
241
- TestResponseController,
242
69
  convertArrayToAsyncIterable,
243
70
  convertArrayToReadableStream,
244
71
  convertAsyncIterableToArray,
245
72
  convertReadableStreamToArray,
246
73
  convertResponseStreamToArray,
247
- createTestServer,
248
74
  isNodeVersion,
249
75
  mockId
250
76
  };
@@ -1 +1 @@
1
- {"version":3,"sources":["../../src/test/convert-array-to-async-iterable.ts","../../src/test/convert-array-to-readable-stream.ts","../../src/test/convert-async-iterable-to-array.ts","../../src/test/convert-readable-stream-to-array.ts","../../src/test/convert-response-stream-to-array.ts","../../src/test/is-node-version.ts","../../src/test/mock-id.ts","../../src/test/test-server.ts"],"sourcesContent":["export function convertArrayToAsyncIterable<T>(values: T[]): AsyncIterable<T> {\n return {\n async *[Symbol.asyncIterator]() {\n for (const value of values) {\n yield value;\n }\n },\n };\n}\n","export function convertArrayToReadableStream<T>(\n values: T[],\n): ReadableStream<T> {\n return new ReadableStream({\n start(controller) {\n try {\n for (const value of values) {\n controller.enqueue(value);\n }\n } finally {\n controller.close();\n }\n },\n });\n}\n","export async function convertAsyncIterableToArray<T>(\n iterable: AsyncIterable<T>,\n): Promise<T[]> {\n const result: T[] = [];\n for await (const item of iterable) {\n result.push(item);\n }\n return result;\n}\n","export async function convertReadableStreamToArray<T>(\n stream: ReadableStream<T>,\n): Promise<T[]> {\n const reader = stream.getReader();\n const result: T[] = [];\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n result.push(value);\n }\n\n return result;\n}\n","import { convertReadableStreamToArray } from './convert-readable-stream-to-array';\n\nexport async function convertResponseStreamToArray(\n response: Response,\n): Promise<string[]> {\n return convertReadableStreamToArray(\n response.body!.pipeThrough(new TextDecoderStream()),\n );\n}\n","export function isNodeVersion(version: number) {\n const nodeMajorVersion = parseInt(process.version.slice(1).split('.')[0], 10);\n return nodeMajorVersion === version;\n}\n","export function mockId({\n prefix = 'id',\n}: {\n prefix?: string;\n} = {}): () => string {\n let counter = 0;\n return () => `${prefix}-${counter++}`;\n}\n","import { http, HttpResponse, JsonBodyType } from 'msw';\nimport { setupServer } from 'msw/node';\nimport { convertArrayToReadableStream } from './convert-array-to-readable-stream';\nimport { beforeAll, beforeEach, afterAll } from 'vitest';\n\nexport type UrlResponse =\n | {\n type: 'json-value';\n headers?: Record<string, string>;\n body: JsonBodyType;\n }\n | {\n type: 'stream-chunks';\n headers?: Record<string, string>;\n chunks: Array<string>;\n }\n | {\n type: 'binary';\n headers?: Record<string, string>;\n body: Buffer;\n }\n | {\n type: 'empty';\n headers?: Record<string, string>;\n status?: number;\n }\n | {\n type: 'error';\n headers?: Record<string, string>;\n status?: number;\n body?: string;\n }\n | {\n type: 'controlled-stream';\n headers?: Record<string, string>;\n controller: TestResponseController;\n }\n | undefined;\n\ntype UrlResponseParameter =\n | UrlResponse\n | UrlResponse[]\n | ((options: { callNumber: number }) => UrlResponse);\n\nexport type UrlHandler = {\n response: UrlResponseParameter;\n};\n\nexport type UrlHandlers<\n URLS extends {\n [url: string]: {\n response?: UrlResponseParameter;\n };\n },\n> = {\n [url in keyof URLS]: UrlHandler;\n};\n\nclass TestServerCall {\n constructor(private request: Request) {}\n\n get requestBodyJson() {\n return this.request!.text().then(JSON.parse);\n }\n\n get requestBodyMultipart() {\n return this.request!.headers.get('content-type')?.startsWith(\n 'multipart/form-data',\n )\n ? // For multipart/form-data, return the form data entries as an object\n this.request!.formData().then(formData => {\n const entries: Record<string, any> = {};\n formData.forEach((value, key) => {\n entries[key] = value;\n });\n return entries;\n })\n : null;\n }\n\n get requestCredentials() {\n return this.request!.credentials;\n }\n\n get requestHeaders() {\n const requestHeaders = this.request!.headers;\n\n // convert headers to object for easier comparison\n const headersObject: Record<string, string> = {};\n requestHeaders.forEach((value, key) => {\n if (key.toLowerCase() === 'user-agent') return;\n headersObject[key] = value;\n });\n\n return headersObject;\n }\n\n get requestUserAgent(): string | undefined {\n return this.request!.headers.get('user-agent') ?? undefined;\n }\n\n get requestUrlSearchParams() {\n return new URL(this.request!.url).searchParams;\n }\n\n get requestUrl() {\n return this.request!.url;\n }\n\n get requestMethod() {\n return this.request!.method;\n }\n}\n\nexport function createTestServer<\n URLS extends {\n [url: string]: {\n response?: UrlResponseParameter;\n };\n },\n>(\n routes: URLS,\n): {\n urls: UrlHandlers<URLS>;\n calls: TestServerCall[];\n} {\n const originalRoutes = structuredClone(routes); // deep copy\n\n const mswServer = setupServer(\n ...Object.entries(routes).map(([url, handler]) => {\n return http.all(url, ({ request }) => {\n const callNumber = calls.length;\n\n calls.push(new TestServerCall(request));\n\n const response =\n typeof handler.response === 'function'\n ? handler.response({ callNumber })\n : Array.isArray(handler.response)\n ? handler.response[callNumber]\n : handler.response;\n\n if (response === undefined) {\n return HttpResponse.json({ error: 'Not Found' }, { status: 404 });\n }\n\n const handlerType = response.type;\n\n switch (handlerType) {\n case 'json-value':\n return HttpResponse.json(response.body, {\n status: 200,\n headers: {\n 'Content-Type': 'application/json',\n ...response.headers,\n },\n });\n\n case 'stream-chunks':\n return new HttpResponse(\n convertArrayToReadableStream(response.chunks).pipeThrough(\n new TextEncoderStream(),\n ),\n {\n status: 200,\n headers: {\n 'Content-Type': 'text/event-stream',\n 'Cache-Control': 'no-cache',\n Connection: 'keep-alive',\n ...response.headers,\n },\n },\n );\n\n case 'controlled-stream': {\n if (request.signal) {\n request.signal.addEventListener('abort', () => {\n response.controller.error(\n new DOMException('Aborted', 'AbortError'),\n );\n });\n }\n\n return new HttpResponse(\n response.controller.stream.pipeThrough(new TextEncoderStream()),\n {\n status: 200,\n headers: {\n 'Content-Type': 'text/event-stream',\n 'Cache-Control': 'no-cache',\n Connection: 'keep-alive',\n ...response.headers,\n },\n },\n );\n }\n\n case 'binary': {\n return HttpResponse.arrayBuffer(response.body, {\n status: 200,\n headers: response.headers,\n });\n }\n\n case 'error':\n return HttpResponse.text(response.body ?? 'Error', {\n status: response.status ?? 500,\n headers: response.headers,\n });\n\n case 'empty':\n return new HttpResponse(null, {\n status: response.status ?? 200,\n });\n\n default: {\n const _exhaustiveCheck: never = handlerType;\n throw new Error(`Unknown response type: ${_exhaustiveCheck}`);\n }\n }\n });\n }),\n );\n\n let calls: TestServerCall[] = [];\n\n beforeAll(() => {\n mswServer.listen();\n });\n\n beforeEach(() => {\n mswServer.resetHandlers();\n\n // set the responses back to the original values\n Object.entries(originalRoutes).forEach(([url, handler]) => {\n routes[url].response = handler.response;\n });\n\n calls = [];\n });\n\n afterAll(() => {\n mswServer.close();\n });\n\n return {\n urls: routes as UrlHandlers<URLS>,\n get calls() {\n return calls;\n },\n };\n}\n\nexport class TestResponseController {\n private readonly transformStream: TransformStream;\n private readonly writer: WritableStreamDefaultWriter;\n\n constructor() {\n this.transformStream = new TransformStream();\n this.writer = this.transformStream.writable.getWriter();\n }\n\n get stream(): ReadableStream {\n return this.transformStream.readable;\n }\n\n async write(chunk: string): Promise<void> {\n await this.writer.write(chunk);\n }\n\n async error(error: Error): Promise<void> {\n await this.writer.abort(error);\n }\n\n async close(): Promise<void> {\n await this.writer.close();\n }\n}\n"],"mappings":"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","names":[]}
1
+ {"version":3,"sources":["../../src/test/convert-array-to-async-iterable.ts","../../src/test/convert-array-to-readable-stream.ts","../../src/test/convert-async-iterable-to-array.ts","../../src/test/convert-readable-stream-to-array.ts","../../src/test/convert-response-stream-to-array.ts","../../src/test/is-node-version.ts","../../src/test/mock-id.ts"],"sourcesContent":["export function convertArrayToAsyncIterable<T>(values: T[]): AsyncIterable<T> {\n return {\n async *[Symbol.asyncIterator]() {\n for (const value of values) {\n yield value;\n }\n },\n };\n}\n","export function convertArrayToReadableStream<T>(\n values: T[],\n): ReadableStream<T> {\n return new ReadableStream({\n start(controller) {\n try {\n for (const value of values) {\n controller.enqueue(value);\n }\n } finally {\n controller.close();\n }\n },\n });\n}\n","export async function convertAsyncIterableToArray<T>(\n iterable: AsyncIterable<T>,\n): Promise<T[]> {\n const result: T[] = [];\n for await (const item of iterable) {\n result.push(item);\n }\n return result;\n}\n","export async function convertReadableStreamToArray<T>(\n stream: ReadableStream<T>,\n): Promise<T[]> {\n const reader = stream.getReader();\n const result: T[] = [];\n\n while (true) {\n const { done, value } = await reader.read();\n if (done) break;\n result.push(value);\n }\n\n return result;\n}\n","import { convertReadableStreamToArray } from './convert-readable-stream-to-array';\n\nexport async function convertResponseStreamToArray(\n response: Response,\n): Promise<string[]> {\n return convertReadableStreamToArray(\n response.body!.pipeThrough(new TextDecoderStream()),\n );\n}\n","export function isNodeVersion(version: number) {\n const nodeMajorVersion = parseInt(process.version.slice(1).split('.')[0], 10);\n return nodeMajorVersion === version;\n}\n","export function mockId({\n prefix = 'id',\n}: {\n prefix?: string;\n} = {}): () => string {\n let counter = 0;\n return () => `${prefix}-${counter++}`;\n}\n"],"mappings":";AAAO,SAAS,4BAA+B,QAA+B;AAC5E,SAAO;AAAA,IACL,QAAQ,OAAO,aAAa,IAAI;AAC9B,iBAAW,SAAS,QAAQ;AAC1B,cAAM;AAAA,MACR;AAAA,IACF;AAAA,EACF;AACF;;;ACRO,SAAS,6BACd,QACmB;AACnB,SAAO,IAAI,eAAe;AAAA,IACxB,MAAM,YAAY;AAChB,UAAI;AACF,mBAAW,SAAS,QAAQ;AAC1B,qBAAW,QAAQ,KAAK;AAAA,QAC1B;AAAA,MACF,UAAE;AACA,mBAAW,MAAM;AAAA,MACnB;AAAA,IACF;AAAA,EACF,CAAC;AACH;;;ACdA,eAAsB,4BACpB,UACc;AACd,QAAM,SAAc,CAAC;AACrB,mBAAiB,QAAQ,UAAU;AACjC,WAAO,KAAK,IAAI;AAAA,EAClB;AACA,SAAO;AACT;;;ACRA,eAAsB,6BACpB,QACc;AACd,QAAM,SAAS,OAAO,UAAU;AAChC,QAAM,SAAc,CAAC;AAErB,SAAO,MAAM;AACX,UAAM,EAAE,MAAM,MAAM,IAAI,MAAM,OAAO,KAAK;AAC1C,QAAI,KAAM;AACV,WAAO,KAAK,KAAK;AAAA,EACnB;AAEA,SAAO;AACT;;;ACXA,eAAsB,6BACpB,UACmB;AACnB,SAAO;AAAA,IACL,SAAS,KAAM,YAAY,IAAI,kBAAkB,CAAC;AAAA,EACpD;AACF;;;ACRO,SAAS,cAAc,SAAiB;AAC7C,QAAM,mBAAmB,SAAS,QAAQ,QAAQ,MAAM,CAAC,EAAE,MAAM,GAAG,EAAE,CAAC,GAAG,EAAE;AAC5E,SAAO,qBAAqB;AAC9B;;;ACHO,SAAS,OAAO;AAAA,EACrB,SAAS;AACX,IAEI,CAAC,GAAiB;AACpB,MAAI,UAAU;AACd,SAAO,MAAM,GAAG,MAAM,IAAI,SAAS;AACrC;","names":[]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@ai-sdk/provider-utils",
3
- "version": "3.1.0-beta.0",
3
+ "version": "3.1.0-beta.2",
4
4
  "license": "Apache-2.0",
5
5
  "sideEffects": false,
6
6
  "main": "./dist/index.js",
@@ -28,7 +28,7 @@
28
28
  "dependencies": {
29
29
  "@standard-schema/spec": "^1.0.0",
30
30
  "eventsource-parser": "^3.0.5",
31
- "@ai-sdk/provider": "2.1.0-beta.0"
31
+ "@ai-sdk/provider": "2.1.0-beta.1"
32
32
  },
33
33
  "devDependencies": {
34
34
  "@types/node": "20.17.24",