summaryrefslogtreecommitdiffhomepage
path: root/packages/opencode/test/provider/transform.test.ts
diff options
context:
space:
mode:
Diffstat (limited to 'packages/opencode/test/provider/transform.test.ts')
-rw-r--r--packages/opencode/test/provider/transform.test.ts98
1 files changed, 98 insertions, 0 deletions
diff --git a/packages/opencode/test/provider/transform.test.ts b/packages/opencode/test/provider/transform.test.ts
new file mode 100644
index 000000000..e6080d54c
--- /dev/null
+++ b/packages/opencode/test/provider/transform.test.ts
@@ -0,0 +1,98 @@
+import { describe, expect, test } from "bun:test"
+import { ProviderTransform } from "../../src/provider/transform"
+
+const OUTPUT_TOKEN_MAX = 32000
+
+describe("ProviderTransform.maxOutputTokens", () => {
+ test("returns 32k when modelLimit > 32k", () => {
+ const modelLimit = 100000
+ const result = ProviderTransform.maxOutputTokens("@ai-sdk/openai", {}, modelLimit, OUTPUT_TOKEN_MAX)
+ expect(result).toBe(OUTPUT_TOKEN_MAX)
+ })
+
+ test("returns modelLimit when modelLimit < 32k", () => {
+ const modelLimit = 16000
+ const result = ProviderTransform.maxOutputTokens("@ai-sdk/openai", {}, modelLimit, OUTPUT_TOKEN_MAX)
+ expect(result).toBe(16000)
+ })
+
+ describe("azure", () => {
+ test("returns 32k when modelLimit > 32k", () => {
+ const modelLimit = 100000
+ const result = ProviderTransform.maxOutputTokens("@ai-sdk/azure", {}, modelLimit, OUTPUT_TOKEN_MAX)
+ expect(result).toBe(OUTPUT_TOKEN_MAX)
+ })
+
+ test("returns modelLimit when modelLimit < 32k", () => {
+ const modelLimit = 16000
+ const result = ProviderTransform.maxOutputTokens("@ai-sdk/azure", {}, modelLimit, OUTPUT_TOKEN_MAX)
+ expect(result).toBe(16000)
+ })
+ })
+
+ describe("bedrock", () => {
+ test("returns 32k when modelLimit > 32k", () => {
+ const modelLimit = 100000
+ const result = ProviderTransform.maxOutputTokens("@ai-sdk/amazon-bedrock", {}, modelLimit, OUTPUT_TOKEN_MAX)
+ expect(result).toBe(OUTPUT_TOKEN_MAX)
+ })
+
+ test("returns modelLimit when modelLimit < 32k", () => {
+ const modelLimit = 16000
+ const result = ProviderTransform.maxOutputTokens("@ai-sdk/amazon-bedrock", {}, modelLimit, OUTPUT_TOKEN_MAX)
+ expect(result).toBe(16000)
+ })
+ })
+
+ describe("anthropic without thinking options", () => {
+ test("returns 32k when modelLimit > 32k", () => {
+ const modelLimit = 100000
+ const result = ProviderTransform.maxOutputTokens("@ai-sdk/anthropic", {}, modelLimit, OUTPUT_TOKEN_MAX)
+ expect(result).toBe(OUTPUT_TOKEN_MAX)
+ })
+
+ test("returns modelLimit when modelLimit < 32k", () => {
+ const modelLimit = 16000
+ const result = ProviderTransform.maxOutputTokens("@ai-sdk/anthropic", {}, modelLimit, OUTPUT_TOKEN_MAX)
+ expect(result).toBe(16000)
+ })
+ })
+
+ describe("anthropic with thinking options", () => {
+ test("returns 32k when budgetTokens + 32k <= modelLimit", () => {
+ const modelLimit = 100000
+ const options = {
+ thinking: {
+ type: "enabled",
+ budgetTokens: 10000,
+ },
+ }
+ const result = ProviderTransform.maxOutputTokens("@ai-sdk/anthropic", options, modelLimit, OUTPUT_TOKEN_MAX)
+ expect(result).toBe(OUTPUT_TOKEN_MAX)
+ })
+
+ test("returns modelLimit - budgetTokens when budgetTokens + 32k > modelLimit", () => {
+ const modelLimit = 50000
+ const options = {
+ thinking: {
+ type: "enabled",
+ budgetTokens: 30000,
+ },
+ }
+ const result = ProviderTransform.maxOutputTokens("@ai-sdk/anthropic", options, modelLimit, OUTPUT_TOKEN_MAX)
+ expect(result).toBe(20000)
+ })
+
+ test("returns 32k when thinking type is not enabled", () => {
+ const modelLimit = 100000
+ const options = {
+ thinking: {
+ type: "disabled",
+ budgetTokens: 10000,
+ },
+ }
+ const result = ProviderTransform.maxOutputTokens("@ai-sdk/anthropic", options, modelLimit, OUTPUT_TOKEN_MAX)
+ expect(result).toBe(OUTPUT_TOKEN_MAX)
+ })
+ })
+})