librechat-data-provider 0.8.402 → 0.8.404
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.
- package/dist/index.es.js +1 -1
- package/dist/index.es.js.map +1 -1
- package/dist/index.js +1 -1
- package/dist/index.js.map +1 -1
- package/dist/react-query/index.es.js +1 -1
- package/dist/react-query/index.es.js.map +1 -1
- package/dist/types/accessPermissions.d.ts +744 -0
- package/dist/types/actions.d.ts +118 -0
- package/dist/types/api-endpoints.d.ts +150 -0
- package/dist/types/artifacts.d.ts +97 -0
- package/dist/types/azure.d.ts +22 -0
- package/dist/types/bedrock.d.ts +1220 -0
- package/dist/types/config.d.ts +14849 -0
- package/dist/types/config.spec.d.ts +1 -0
- package/dist/types/createPayload.d.ts +5 -0
- package/dist/types/data-service.d.ts +287 -0
- package/dist/types/feedback.d.ts +36 -0
- package/dist/types/file-config.d.ts +263 -0
- package/dist/types/file-config.spec.d.ts +1 -0
- package/dist/types/generate.d.ts +597 -0
- package/dist/types/headers-helpers.d.ts +2 -0
- package/{src/index.ts → dist/types/index.d.ts} +0 -15
- package/dist/types/keys.d.ts +92 -0
- package/dist/types/mcp.d.ts +2760 -0
- package/dist/types/messages.d.ts +10 -0
- package/dist/types/models.d.ts +1547 -0
- package/dist/types/parameterSettings.d.ts +69 -0
- package/dist/types/parsers.d.ts +110 -0
- package/dist/types/permissions.d.ts +522 -0
- package/dist/types/react-query/react-query-service.d.ts +85 -0
- package/dist/types/request.d.ts +25 -0
- package/dist/types/roles.d.ts +554 -0
- package/dist/types/roles.spec.d.ts +1 -0
- package/dist/types/schemas.d.ts +5110 -0
- package/dist/types/schemas.spec.d.ts +1 -0
- package/dist/types/types/agents.d.ts +433 -0
- package/dist/types/types/assistants.d.ts +547 -0
- package/dist/types/types/files.d.ts +172 -0
- package/dist/types/types/graph.d.ts +135 -0
- package/{src/types/mcpServers.ts → dist/types/types/mcpServers.d.ts} +12 -18
- package/dist/types/types/mutations.d.ts +209 -0
- package/dist/types/types/queries.d.ts +169 -0
- package/dist/types/types/runs.d.ts +36 -0
- package/dist/types/types/web.d.ts +520 -0
- package/dist/types/types.d.ts +503 -0
- package/dist/types/utils.d.ts +12 -0
- package/package.json +5 -1
- package/babel.config.js +0 -4
- package/check_updates.sh +0 -52
- package/jest.config.js +0 -19
- package/react-query/package-lock.json +0 -292
- package/react-query/package.json +0 -10
- package/rollup.config.js +0 -74
- package/server-rollup.config.js +0 -40
- package/specs/actions.spec.ts +0 -2533
- package/specs/api-endpoints-subdir.spec.ts +0 -140
- package/specs/api-endpoints.spec.ts +0 -74
- package/specs/azure.spec.ts +0 -844
- package/specs/bedrock.spec.ts +0 -862
- package/specs/filetypes.spec.ts +0 -175
- package/specs/generate.spec.ts +0 -770
- package/specs/headers-helpers.spec.ts +0 -24
- package/specs/mcp.spec.ts +0 -147
- package/specs/openapiSpecs.ts +0 -524
- package/specs/parsers.spec.ts +0 -601
- package/specs/request-interceptor.spec.ts +0 -304
- package/specs/utils.spec.ts +0 -196
- package/src/accessPermissions.ts +0 -346
- package/src/actions.ts +0 -813
- package/src/api-endpoints.ts +0 -440
- package/src/artifacts.ts +0 -3104
- package/src/azure.ts +0 -328
- package/src/bedrock.ts +0 -425
- package/src/config.spec.ts +0 -315
- package/src/config.ts +0 -2006
- package/src/createPayload.ts +0 -46
- package/src/data-service.ts +0 -1087
- package/src/feedback.ts +0 -141
- package/src/file-config.spec.ts +0 -1248
- package/src/file-config.ts +0 -764
- package/src/generate.ts +0 -634
- package/src/headers-helpers.ts +0 -13
- package/src/keys.ts +0 -99
- package/src/mcp.ts +0 -271
- package/src/messages.ts +0 -50
- package/src/models.ts +0 -69
- package/src/parameterSettings.ts +0 -1111
- package/src/parsers.ts +0 -563
- package/src/permissions.ts +0 -188
- package/src/react-query/react-query-service.ts +0 -566
- package/src/request.ts +0 -171
- package/src/roles.spec.ts +0 -132
- package/src/roles.ts +0 -225
- package/src/schemas.spec.ts +0 -355
- package/src/schemas.ts +0 -1234
- package/src/types/agents.ts +0 -470
- package/src/types/assistants.ts +0 -654
- package/src/types/files.ts +0 -191
- package/src/types/graph.ts +0 -145
- package/src/types/mutations.ts +0 -422
- package/src/types/queries.ts +0 -208
- package/src/types/runs.ts +0 -40
- package/src/types/web.ts +0 -588
- package/src/types.ts +0 -676
- package/src/utils.ts +0 -85
- package/tsconfig.json +0 -28
- package/tsconfig.spec.json +0 -10
- /package/{src/react-query/index.ts → dist/types/react-query/index.d.ts} +0 -0
- /package/{src/types/index.ts → dist/types/types/index.d.ts} +0 -0
package/src/schemas.spec.ts
DELETED
|
@@ -1,355 +0,0 @@
|
|
|
1
|
-
import { anthropicSettings } from './schemas';
|
|
2
|
-
|
|
3
|
-
describe('anthropicSettings', () => {
|
|
4
|
-
describe('maxOutputTokens.reset()', () => {
|
|
5
|
-
const { reset } = anthropicSettings.maxOutputTokens;
|
|
6
|
-
|
|
7
|
-
describe('Claude Sonnet models', () => {
|
|
8
|
-
it('should return 64K for claude-sonnet-4', () => {
|
|
9
|
-
expect(reset('claude-sonnet-4')).toBe(64000);
|
|
10
|
-
});
|
|
11
|
-
|
|
12
|
-
it('should return 64K for claude-sonnet-4-5', () => {
|
|
13
|
-
expect(reset('claude-sonnet-4-5')).toBe(64000);
|
|
14
|
-
});
|
|
15
|
-
|
|
16
|
-
it('should return 64K for claude-sonnet-5', () => {
|
|
17
|
-
expect(reset('claude-sonnet-5')).toBe(64000);
|
|
18
|
-
});
|
|
19
|
-
|
|
20
|
-
it('should return 64K for future versions like claude-sonnet-9', () => {
|
|
21
|
-
expect(reset('claude-sonnet-9')).toBe(64000);
|
|
22
|
-
});
|
|
23
|
-
});
|
|
24
|
-
|
|
25
|
-
describe('Claude Haiku models', () => {
|
|
26
|
-
it('should return 64K for claude-haiku-4-5', () => {
|
|
27
|
-
expect(reset('claude-haiku-4-5')).toBe(64000);
|
|
28
|
-
});
|
|
29
|
-
|
|
30
|
-
it('should return 64K for claude-haiku-4', () => {
|
|
31
|
-
expect(reset('claude-haiku-4')).toBe(64000);
|
|
32
|
-
});
|
|
33
|
-
|
|
34
|
-
it('should return 64K for claude-haiku-5', () => {
|
|
35
|
-
expect(reset('claude-haiku-5')).toBe(64000);
|
|
36
|
-
});
|
|
37
|
-
|
|
38
|
-
it('should return 64K for future versions like claude-haiku-9', () => {
|
|
39
|
-
expect(reset('claude-haiku-9')).toBe(64000);
|
|
40
|
-
});
|
|
41
|
-
});
|
|
42
|
-
|
|
43
|
-
describe('Claude Opus 4.0-4.4 models (32K limit)', () => {
|
|
44
|
-
it('should return 32K for claude-opus-4', () => {
|
|
45
|
-
expect(reset('claude-opus-4')).toBe(32000);
|
|
46
|
-
});
|
|
47
|
-
|
|
48
|
-
it('should return 32K for claude-opus-4-0', () => {
|
|
49
|
-
expect(reset('claude-opus-4-0')).toBe(32000);
|
|
50
|
-
});
|
|
51
|
-
|
|
52
|
-
it('should return 32K for claude-opus-4-1', () => {
|
|
53
|
-
expect(reset('claude-opus-4-1')).toBe(32000);
|
|
54
|
-
});
|
|
55
|
-
|
|
56
|
-
it('should return 32K for claude-opus-4-2', () => {
|
|
57
|
-
expect(reset('claude-opus-4-2')).toBe(32000);
|
|
58
|
-
});
|
|
59
|
-
|
|
60
|
-
it('should return 32K for claude-opus-4-3', () => {
|
|
61
|
-
expect(reset('claude-opus-4-3')).toBe(32000);
|
|
62
|
-
});
|
|
63
|
-
|
|
64
|
-
it('should return 32K for claude-opus-4-4', () => {
|
|
65
|
-
expect(reset('claude-opus-4-4')).toBe(32000);
|
|
66
|
-
});
|
|
67
|
-
|
|
68
|
-
it('should return 32K for claude-opus-4.0', () => {
|
|
69
|
-
expect(reset('claude-opus-4.0')).toBe(32000);
|
|
70
|
-
});
|
|
71
|
-
|
|
72
|
-
it('should return 32K for claude-opus-4.1', () => {
|
|
73
|
-
expect(reset('claude-opus-4.1')).toBe(32000);
|
|
74
|
-
});
|
|
75
|
-
});
|
|
76
|
-
|
|
77
|
-
describe('Claude Opus 4.5 models (64K limit)', () => {
|
|
78
|
-
it('should return 64K for claude-opus-4-5', () => {
|
|
79
|
-
expect(reset('claude-opus-4-5')).toBe(64000);
|
|
80
|
-
});
|
|
81
|
-
|
|
82
|
-
it('should return 64K for claude-opus-4.5', () => {
|
|
83
|
-
expect(reset('claude-opus-4.5')).toBe(64000);
|
|
84
|
-
});
|
|
85
|
-
});
|
|
86
|
-
|
|
87
|
-
describe('Claude Opus 4.6+ models (128K limit - future-proof)', () => {
|
|
88
|
-
it('should return 128K for claude-opus-4-6', () => {
|
|
89
|
-
expect(reset('claude-opus-4-6')).toBe(128000);
|
|
90
|
-
});
|
|
91
|
-
|
|
92
|
-
it('should return 128K for claude-opus-4.6', () => {
|
|
93
|
-
expect(reset('claude-opus-4.6')).toBe(128000);
|
|
94
|
-
});
|
|
95
|
-
|
|
96
|
-
it('should return 128K for claude-opus-4-7', () => {
|
|
97
|
-
expect(reset('claude-opus-4-7')).toBe(128000);
|
|
98
|
-
});
|
|
99
|
-
|
|
100
|
-
it('should return 128K for claude-opus-4-8', () => {
|
|
101
|
-
expect(reset('claude-opus-4-8')).toBe(128000);
|
|
102
|
-
});
|
|
103
|
-
|
|
104
|
-
it('should return 128K for claude-opus-4-9', () => {
|
|
105
|
-
expect(reset('claude-opus-4-9')).toBe(128000);
|
|
106
|
-
});
|
|
107
|
-
});
|
|
108
|
-
|
|
109
|
-
describe('Claude Opus 4.10+ models (double-digit minor versions)', () => {
|
|
110
|
-
it('should return 128K for claude-opus-4-10', () => {
|
|
111
|
-
expect(reset('claude-opus-4-10')).toBe(128000);
|
|
112
|
-
});
|
|
113
|
-
|
|
114
|
-
it('should return 128K for claude-opus-4-11', () => {
|
|
115
|
-
expect(reset('claude-opus-4-11')).toBe(128000);
|
|
116
|
-
});
|
|
117
|
-
|
|
118
|
-
it('should return 128K for claude-opus-4-15', () => {
|
|
119
|
-
expect(reset('claude-opus-4-15')).toBe(128000);
|
|
120
|
-
});
|
|
121
|
-
|
|
122
|
-
it('should return 128K for claude-opus-4-20', () => {
|
|
123
|
-
expect(reset('claude-opus-4-20')).toBe(128000);
|
|
124
|
-
});
|
|
125
|
-
|
|
126
|
-
it('should return 128K for claude-opus-4.10', () => {
|
|
127
|
-
expect(reset('claude-opus-4.10')).toBe(128000);
|
|
128
|
-
});
|
|
129
|
-
});
|
|
130
|
-
|
|
131
|
-
describe('Claude Opus 5+ models (future major versions)', () => {
|
|
132
|
-
it('should return 128K for claude-opus-5', () => {
|
|
133
|
-
expect(reset('claude-opus-5')).toBe(128000);
|
|
134
|
-
});
|
|
135
|
-
|
|
136
|
-
it('should return 128K for claude-opus-6', () => {
|
|
137
|
-
expect(reset('claude-opus-6')).toBe(128000);
|
|
138
|
-
});
|
|
139
|
-
|
|
140
|
-
it('should return 128K for claude-opus-7', () => {
|
|
141
|
-
expect(reset('claude-opus-7')).toBe(128000);
|
|
142
|
-
});
|
|
143
|
-
|
|
144
|
-
it('should return 128K for claude-opus-9', () => {
|
|
145
|
-
expect(reset('claude-opus-9')).toBe(128000);
|
|
146
|
-
});
|
|
147
|
-
|
|
148
|
-
it('should return 128K for claude-opus-5-0', () => {
|
|
149
|
-
expect(reset('claude-opus-5-0')).toBe(128000);
|
|
150
|
-
});
|
|
151
|
-
|
|
152
|
-
it('should return 128K for claude-opus-5.0', () => {
|
|
153
|
-
expect(reset('claude-opus-5.0')).toBe(128000);
|
|
154
|
-
});
|
|
155
|
-
});
|
|
156
|
-
|
|
157
|
-
describe('Model name variations with dates and suffixes', () => {
|
|
158
|
-
it('should return 64K for claude-opus-4-5-20250420', () => {
|
|
159
|
-
expect(reset('claude-opus-4-5-20250420')).toBe(64000);
|
|
160
|
-
});
|
|
161
|
-
|
|
162
|
-
it('should return 128K for claude-opus-4-6-20260101', () => {
|
|
163
|
-
expect(reset('claude-opus-4-6-20260101')).toBe(128000);
|
|
164
|
-
});
|
|
165
|
-
|
|
166
|
-
it('should return 32K for claude-opus-4-1-20250805', () => {
|
|
167
|
-
expect(reset('claude-opus-4-1-20250805')).toBe(32000);
|
|
168
|
-
});
|
|
169
|
-
|
|
170
|
-
it('should return 32K for claude-opus-4-0-20240229', () => {
|
|
171
|
-
expect(reset('claude-opus-4-0-20240229')).toBe(32000);
|
|
172
|
-
});
|
|
173
|
-
});
|
|
174
|
-
|
|
175
|
-
describe('Legacy Claude models', () => {
|
|
176
|
-
it('should return 8192 for claude-3-opus', () => {
|
|
177
|
-
expect(reset('claude-3-opus')).toBe(8192);
|
|
178
|
-
});
|
|
179
|
-
|
|
180
|
-
it('should return 8192 for claude-3-5-sonnet', () => {
|
|
181
|
-
expect(reset('claude-3-5-sonnet')).toBe(8192);
|
|
182
|
-
});
|
|
183
|
-
|
|
184
|
-
it('should return 8192 for claude-3-5-haiku', () => {
|
|
185
|
-
expect(reset('claude-3-5-haiku')).toBe(8192);
|
|
186
|
-
});
|
|
187
|
-
|
|
188
|
-
it('should return 8192 for claude-3-7-sonnet', () => {
|
|
189
|
-
expect(reset('claude-3-7-sonnet')).toBe(8192);
|
|
190
|
-
});
|
|
191
|
-
|
|
192
|
-
it('should return 8192 for claude-2', () => {
|
|
193
|
-
expect(reset('claude-2')).toBe(8192);
|
|
194
|
-
});
|
|
195
|
-
|
|
196
|
-
it('should return 8192 for claude-2.1', () => {
|
|
197
|
-
expect(reset('claude-2.1')).toBe(8192);
|
|
198
|
-
});
|
|
199
|
-
|
|
200
|
-
it('should return 8192 for claude-instant', () => {
|
|
201
|
-
expect(reset('claude-instant')).toBe(8192);
|
|
202
|
-
});
|
|
203
|
-
});
|
|
204
|
-
|
|
205
|
-
describe('Non-Claude models and edge cases', () => {
|
|
206
|
-
it('should return 8192 for unknown model', () => {
|
|
207
|
-
expect(reset('unknown-model')).toBe(8192);
|
|
208
|
-
});
|
|
209
|
-
|
|
210
|
-
it('should return 8192 for empty string', () => {
|
|
211
|
-
expect(reset('')).toBe(8192);
|
|
212
|
-
});
|
|
213
|
-
|
|
214
|
-
it('should return 8192 for gpt-4', () => {
|
|
215
|
-
expect(reset('gpt-4')).toBe(8192);
|
|
216
|
-
});
|
|
217
|
-
|
|
218
|
-
it('should return 8192 for gemini-pro', () => {
|
|
219
|
-
expect(reset('gemini-pro')).toBe(8192);
|
|
220
|
-
});
|
|
221
|
-
});
|
|
222
|
-
|
|
223
|
-
describe('Regex pattern edge cases', () => {
|
|
224
|
-
it('should not match claude-opus-3', () => {
|
|
225
|
-
expect(reset('claude-opus-3')).toBe(8192);
|
|
226
|
-
});
|
|
227
|
-
|
|
228
|
-
it('should not match opus-4-5 without claude prefix', () => {
|
|
229
|
-
expect(reset('opus-4-5')).toBe(8192);
|
|
230
|
-
});
|
|
231
|
-
|
|
232
|
-
it('should NOT match claude.opus.4.5 (incorrect separator pattern)', () => {
|
|
233
|
-
// Model names use hyphens after "claude", not dots
|
|
234
|
-
expect(reset('claude.opus.4.5')).toBe(8192);
|
|
235
|
-
});
|
|
236
|
-
|
|
237
|
-
it('should match claude-opus45 (no separator after opus)', () => {
|
|
238
|
-
// The regex allows optional separators, so "45" can follow directly
|
|
239
|
-
// "45" is treated as major version 45 (>= 5), so it gets 128K
|
|
240
|
-
expect(reset('claude-opus45')).toBe(128000);
|
|
241
|
-
});
|
|
242
|
-
});
|
|
243
|
-
});
|
|
244
|
-
|
|
245
|
-
describe('maxOutputTokens.set()', () => {
|
|
246
|
-
const { set } = anthropicSettings.maxOutputTokens;
|
|
247
|
-
|
|
248
|
-
describe('Claude Sonnet and Haiku 4+ models (64K cap)', () => {
|
|
249
|
-
it('should cap at 64K for claude-sonnet-4 when value exceeds', () => {
|
|
250
|
-
expect(set(100000, 'claude-sonnet-4')).toBe(64000);
|
|
251
|
-
});
|
|
252
|
-
|
|
253
|
-
it('should allow 50K for claude-sonnet-4', () => {
|
|
254
|
-
expect(set(50000, 'claude-sonnet-4')).toBe(50000);
|
|
255
|
-
});
|
|
256
|
-
|
|
257
|
-
it('should cap at 64K for claude-haiku-4-5 when value exceeds', () => {
|
|
258
|
-
expect(set(80000, 'claude-haiku-4-5')).toBe(64000);
|
|
259
|
-
});
|
|
260
|
-
});
|
|
261
|
-
|
|
262
|
-
describe('Claude Opus 4.5+ models (64K cap)', () => {
|
|
263
|
-
it('should cap at 64K for claude-opus-4-5 when value exceeds', () => {
|
|
264
|
-
expect(set(100000, 'claude-opus-4-5')).toBe(64000);
|
|
265
|
-
});
|
|
266
|
-
|
|
267
|
-
it('should cap at model-specific 64K limit, not global 128K limit', () => {
|
|
268
|
-
// Values between 64K and 128K should be capped at 64K (model limit)
|
|
269
|
-
// This verifies the fix for the unreachable code issue
|
|
270
|
-
expect(set(70000, 'claude-opus-4-5')).toBe(64000);
|
|
271
|
-
expect(set(80000, 'claude-opus-4-5')).toBe(64000);
|
|
272
|
-
expect(set(100000, 'claude-opus-4-5')).toBe(64000);
|
|
273
|
-
expect(set(128000, 'claude-opus-4-5')).toBe(64000);
|
|
274
|
-
|
|
275
|
-
// Values above 128K should also be capped at 64K (not 128K)
|
|
276
|
-
expect(set(150000, 'claude-opus-4-5')).toBe(64000);
|
|
277
|
-
});
|
|
278
|
-
|
|
279
|
-
it('should allow 50K for claude-opus-4-5', () => {
|
|
280
|
-
expect(set(50000, 'claude-opus-4-5')).toBe(50000);
|
|
281
|
-
});
|
|
282
|
-
|
|
283
|
-
it('should allow 80K for claude-opus-4-6 (128K cap)', () => {
|
|
284
|
-
expect(set(80000, 'claude-opus-4-6')).toBe(80000);
|
|
285
|
-
});
|
|
286
|
-
|
|
287
|
-
it('should cap at 128K for claude-opus-4-6', () => {
|
|
288
|
-
expect(set(150000, 'claude-opus-4-6')).toBe(128000);
|
|
289
|
-
});
|
|
290
|
-
|
|
291
|
-
it('should cap at 128K for claude-opus-5', () => {
|
|
292
|
-
expect(set(150000, 'claude-opus-5')).toBe(128000);
|
|
293
|
-
});
|
|
294
|
-
|
|
295
|
-
it('should allow 100K for claude-opus-5', () => {
|
|
296
|
-
expect(set(100000, 'claude-opus-5')).toBe(100000);
|
|
297
|
-
});
|
|
298
|
-
|
|
299
|
-
it('should cap at 128K for claude-opus-4-10', () => {
|
|
300
|
-
expect(set(150000, 'claude-opus-4-10')).toBe(128000);
|
|
301
|
-
});
|
|
302
|
-
|
|
303
|
-
it('should allow 100K for claude-opus-4-10', () => {
|
|
304
|
-
expect(set(100000, 'claude-opus-4-10')).toBe(100000);
|
|
305
|
-
});
|
|
306
|
-
});
|
|
307
|
-
|
|
308
|
-
describe('Claude Opus 4.0-4.4 models (32K cap)', () => {
|
|
309
|
-
it('should cap at 32K for claude-opus-4', () => {
|
|
310
|
-
expect(set(50000, 'claude-opus-4')).toBe(32000);
|
|
311
|
-
});
|
|
312
|
-
|
|
313
|
-
it('should allow 20K for claude-opus-4', () => {
|
|
314
|
-
expect(set(20000, 'claude-opus-4')).toBe(20000);
|
|
315
|
-
});
|
|
316
|
-
|
|
317
|
-
it('should cap at 32K for claude-opus-4-1', () => {
|
|
318
|
-
expect(set(50000, 'claude-opus-4-1')).toBe(32000);
|
|
319
|
-
});
|
|
320
|
-
|
|
321
|
-
it('should cap at 32K for claude-opus-4-4', () => {
|
|
322
|
-
expect(set(40000, 'claude-opus-4-4')).toBe(32000);
|
|
323
|
-
});
|
|
324
|
-
});
|
|
325
|
-
|
|
326
|
-
describe('Global 128K cap for all models', () => {
|
|
327
|
-
it('should cap at model-specific limit first, then global', () => {
|
|
328
|
-
// claude-sonnet-4 has 64K limit, so caps at 64K not 128K
|
|
329
|
-
expect(set(150000, 'claude-sonnet-4')).toBe(64000);
|
|
330
|
-
});
|
|
331
|
-
|
|
332
|
-
it('should cap at 128K for claude-3 models', () => {
|
|
333
|
-
expect(set(150000, 'claude-3-opus')).toBe(128000);
|
|
334
|
-
});
|
|
335
|
-
|
|
336
|
-
it('should cap at 128K for unknown models', () => {
|
|
337
|
-
expect(set(200000, 'unknown-model')).toBe(128000);
|
|
338
|
-
});
|
|
339
|
-
});
|
|
340
|
-
|
|
341
|
-
describe('Valid values within limits', () => {
|
|
342
|
-
it('should allow valid values for legacy models', () => {
|
|
343
|
-
expect(set(8000, 'claude-3-opus')).toBe(8000);
|
|
344
|
-
});
|
|
345
|
-
|
|
346
|
-
it('should allow 1 token minimum', () => {
|
|
347
|
-
expect(set(1, 'claude-opus-4-5')).toBe(1);
|
|
348
|
-
});
|
|
349
|
-
|
|
350
|
-
it('should allow 128K exactly', () => {
|
|
351
|
-
expect(set(128000, 'claude-3-opus')).toBe(128000);
|
|
352
|
-
});
|
|
353
|
-
});
|
|
354
|
-
});
|
|
355
|
-
});
|