fix(venice): disable streaming to prevent SDK crash with usage-only chunks (#15819)

Venice.ai API returns SSE chunks containing only usage metadata without
a choices array. The SDK crashes trying to access choices[0] on these
chunks with: Cannot read properties of undefined (reading '0')

Changes:
- Disable streaming by default for all Venice models
- Apply to both static catalog and dynamically discovered models
- Users can explicitly enable streaming in config if needed

This is a workaround until the SDK handles Venice's streaming format.

Fixes #15819
This commit is contained in:
帅小呆1号
2026-02-14 00:41:00 +00:00
committed by Peter Steinberger
parent 54a242eaad
commit 737bf7ba63

View File

@@ -300,6 +300,11 @@ export function buildVeniceModelDefinition(entry: VeniceCatalogEntry): ModelDefi
cost: VENICE_DEFAULT_COST,
contextWindow: entry.contextWindow,
maxTokens: entry.maxTokens,
// Disable streaming by default for Venice to avoid SDK crash with usage-only chunks
// See: https://github.com/openclaw/openclaw/issues/15819
params: {
streaming: false,
},
};
}
@@ -381,6 +386,10 @@ export async function discoverVeniceModels(): Promise<ModelDefinitionConfig[]> {
cost: VENICE_DEFAULT_COST,
contextWindow: apiModel.model_spec.availableContextTokens || 128000,
maxTokens: 8192,
// Disable streaming to avoid SDK crash with usage-only chunks (#15819)
params: {
streaming: false,
},
});
}
}