@mistralai/mistralai 2.2.5 → 2.2.6
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/README.md +49 -2
- package/esm/extra/observability/formatting.d.ts +40 -0
- package/esm/extra/observability/formatting.d.ts.map +1 -0
- package/esm/extra/observability/formatting.js +187 -0
- package/esm/extra/observability/formatting.js.map +1 -0
- package/esm/extra/observability/index.d.ts +3 -0
- package/esm/extra/observability/index.d.ts.map +1 -0
- package/esm/extra/observability/index.js +3 -0
- package/esm/extra/observability/index.js.map +1 -0
- package/esm/extra/observability/otel.d.ts +59 -0
- package/esm/extra/observability/otel.d.ts.map +1 -0
- package/esm/extra/observability/otel.js +578 -0
- package/esm/extra/observability/otel.js.map +1 -0
- package/esm/extra/observability/streaming.d.ts +25 -0
- package/esm/extra/observability/streaming.d.ts.map +1 -0
- package/esm/extra/observability/streaming.js +142 -0
- package/esm/extra/observability/streaming.js.map +1 -0
- package/esm/funcs/betaConnectorsGetAuthUrl.js +2 -0
- package/esm/funcs/betaConnectorsGetAuthUrl.js.map +1 -1
- package/esm/funcs/betaObservabilityLogsFetchOptions.d.ts +16 -0
- package/esm/funcs/betaObservabilityLogsFetchOptions.d.ts.map +1 -0
- package/esm/funcs/betaObservabilityLogsFetchOptions.js +94 -0
- package/esm/funcs/betaObservabilityLogsFetchOptions.js.map +1 -0
- package/esm/funcs/betaObservabilityLogsList.d.ts +15 -0
- package/esm/funcs/betaObservabilityLogsList.d.ts.map +1 -0
- package/esm/funcs/betaObservabilityLogsList.js +71 -0
- package/esm/funcs/betaObservabilityLogsList.js.map +1 -0
- package/esm/funcs/betaObservabilityLogsSearch.d.ts +16 -0
- package/esm/funcs/betaObservabilityLogsSearch.d.ts.map +1 -0
- package/esm/funcs/betaObservabilityLogsSearch.js +90 -0
- package/esm/funcs/betaObservabilityLogsSearch.js.map +1 -0
- package/esm/funcs/betaObservabilitySpansFetchSpanEvalFieldOptions.d.ts +16 -0
- package/esm/funcs/betaObservabilitySpansFetchSpanEvalFieldOptions.d.ts.map +1 -0
- package/esm/funcs/betaObservabilitySpansFetchSpanEvalFieldOptions.js +94 -0
- package/esm/funcs/betaObservabilitySpansFetchSpanEvalFieldOptions.js.map +1 -0
- package/esm/funcs/betaObservabilitySpansFetchSpanFieldOptions.d.ts +16 -0
- package/esm/funcs/betaObservabilitySpansFetchSpanFieldOptions.d.ts.map +1 -0
- package/esm/funcs/betaObservabilitySpansFetchSpanFieldOptions.js +94 -0
- package/esm/funcs/betaObservabilitySpansFetchSpanFieldOptions.js.map +1 -0
- package/esm/funcs/betaObservabilitySpansListSpanEvalFields.d.ts +15 -0
- package/esm/funcs/betaObservabilitySpansListSpanEvalFields.d.ts.map +1 -0
- package/esm/funcs/betaObservabilitySpansListSpanEvalFields.js +71 -0
- package/esm/funcs/betaObservabilitySpansListSpanEvalFields.js.map +1 -0
- package/esm/funcs/betaObservabilitySpansListSpanFields.d.ts +15 -0
- package/esm/funcs/betaObservabilitySpansListSpanFields.d.ts.map +1 -0
- package/esm/funcs/betaObservabilitySpansListSpanFields.js +71 -0
- package/esm/funcs/betaObservabilitySpansListSpanFields.js.map +1 -0
- package/esm/funcs/betaObservabilitySpansSearchLatestSpanEvaluations.d.ts +16 -0
- package/esm/funcs/betaObservabilitySpansSearchLatestSpanEvaluations.d.ts.map +1 -0
- package/esm/funcs/betaObservabilitySpansSearchLatestSpanEvaluations.js +93 -0
- package/esm/funcs/betaObservabilitySpansSearchLatestSpanEvaluations.js.map +1 -0
- package/esm/funcs/betaObservabilitySpansSearchSpanEvaluations.d.ts +16 -0
- package/esm/funcs/betaObservabilitySpansSearchSpanEvaluations.d.ts.map +1 -0
- package/esm/funcs/betaObservabilitySpansSearchSpanEvaluations.js +93 -0
- package/esm/funcs/betaObservabilitySpansSearchSpanEvaluations.js.map +1 -0
- package/esm/funcs/betaObservabilitySpansSearchSpans.d.ts +16 -0
- package/esm/funcs/betaObservabilitySpansSearchSpans.d.ts.map +1 -0
- package/esm/funcs/betaObservabilitySpansSearchSpans.js +90 -0
- package/esm/funcs/betaObservabilitySpansSearchSpans.js.map +1 -0
- package/esm/funcs/betaObservabilityTracesFetchOptions.d.ts +16 -0
- package/esm/funcs/betaObservabilityTracesFetchOptions.d.ts.map +1 -0
- package/esm/funcs/betaObservabilityTracesFetchOptions.js +94 -0
- package/esm/funcs/betaObservabilityTracesFetchOptions.js.map +1 -0
- package/esm/funcs/betaObservabilityTracesGetSpanById.d.ts +16 -0
- package/esm/funcs/betaObservabilityTracesGetSpanById.d.ts.map +1 -0
- package/esm/funcs/betaObservabilityTracesGetSpanById.js +98 -0
- package/esm/funcs/betaObservabilityTracesGetSpanById.js.map +1 -0
- package/esm/funcs/betaObservabilityTracesGetTraceById.d.ts +16 -0
- package/esm/funcs/betaObservabilityTracesGetTraceById.d.ts.map +1 -0
- package/esm/funcs/betaObservabilityTracesGetTraceById.js +89 -0
- package/esm/funcs/betaObservabilityTracesGetTraceById.js.map +1 -0
- package/esm/funcs/betaObservabilityTracesGetTraceFields.d.ts +15 -0
- package/esm/funcs/betaObservabilityTracesGetTraceFields.d.ts.map +1 -0
- package/esm/funcs/betaObservabilityTracesGetTraceFields.js +71 -0
- package/esm/funcs/betaObservabilityTracesGetTraceFields.js.map +1 -0
- package/esm/funcs/betaObservabilityTracesGetTraceSpans.d.ts +16 -0
- package/esm/funcs/betaObservabilityTracesGetTraceSpans.d.ts.map +1 -0
- package/esm/funcs/betaObservabilityTracesGetTraceSpans.js +96 -0
- package/esm/funcs/betaObservabilityTracesGetTraceSpans.js.map +1 -0
- package/esm/funcs/betaObservabilityTracesSearch.d.ts +16 -0
- package/esm/funcs/betaObservabilityTracesSearch.d.ts.map +1 -0
- package/esm/funcs/betaObservabilityTracesSearch.js +91 -0
- package/esm/funcs/betaObservabilityTracesSearch.js.map +1 -0
- package/esm/funcs/workflowsDeploymentsListDeployments.js +5 -0
- package/esm/funcs/workflowsDeploymentsListDeployments.js.map +1 -1
- package/esm/funcs/workflowsExecutionsGetWorkflowExecutionLogs.d.ts +24 -0
- package/esm/funcs/workflowsExecutionsGetWorkflowExecutionLogs.d.ts.map +1 -0
- package/esm/funcs/workflowsExecutionsGetWorkflowExecutionLogs.js +105 -0
- package/esm/funcs/workflowsExecutionsGetWorkflowExecutionLogs.js.map +1 -0
- package/esm/funcs/workflowsExecutionsStreamWorkflowExecutionLogs.d.ts +22 -0
- package/esm/funcs/workflowsExecutionsStreamWorkflowExecutionLogs.d.ts.map +1 -0
- package/esm/funcs/workflowsExecutionsStreamWorkflowExecutionLogs.js +110 -0
- package/esm/funcs/workflowsExecutionsStreamWorkflowExecutionLogs.js.map +1 -0
- package/esm/funcs/workflowsGetWorkflows.js +6 -0
- package/esm/funcs/workflowsGetWorkflows.js.map +1 -1
- package/esm/funcs/workflowsRunsListRuns.js +7 -0
- package/esm/funcs/workflowsRunsListRuns.js.map +1 -1
- package/esm/funcs/workflowsSchedulesTriggerSchedule.d.ts +15 -0
- package/esm/funcs/workflowsSchedulesTriggerSchedule.d.ts.map +1 -0
- package/esm/funcs/workflowsSchedulesTriggerSchedule.js +92 -0
- package/esm/funcs/workflowsSchedulesTriggerSchedule.js.map +1 -0
- package/esm/hooks/registration.d.ts.map +1 -1
- package/esm/hooks/registration.js +6 -0
- package/esm/hooks/registration.js.map +1 -1
- package/esm/hooks/tracing.d.ts +21 -0
- package/esm/hooks/tracing.d.ts.map +1 -0
- package/esm/hooks/tracing.js +104 -0
- package/esm/hooks/tracing.js.map +1 -0
- package/esm/lib/config.d.ts +2 -2
- package/esm/lib/config.js +2 -2
- package/esm/models/components/authdata.d.ts +2 -2
- package/esm/models/components/authdata.d.ts.map +1 -1
- package/esm/models/components/authdata.js +1 -1
- package/esm/models/components/authdata.js.map +1 -1
- package/esm/models/components/authenticationconfiguration.d.ts +2 -0
- package/esm/models/components/authenticationconfiguration.d.ts.map +1 -1
- package/esm/models/components/authenticationconfiguration.js +2 -0
- package/esm/models/components/authenticationconfiguration.js.map +1 -1
- package/esm/models/components/authstatus.d.ts +11 -0
- package/esm/models/components/authstatus.d.ts.map +1 -0
- package/esm/models/components/authstatus.js +13 -0
- package/esm/models/components/authstatus.js.map +1 -0
- package/esm/models/components/basefielddefinition.d.ts +4 -4
- package/esm/models/components/basefielddefinition.d.ts.map +1 -1
- package/esm/models/components/basefielddefinition.js +3 -3
- package/esm/models/components/basefielddefinition.js.map +1 -1
- package/esm/models/components/completiontokensdetails.d.ts +13 -0
- package/esm/models/components/completiontokensdetails.d.ts.map +1 -0
- package/esm/models/components/completiontokensdetails.js +19 -0
- package/esm/models/components/completiontokensdetails.js.map +1 -0
- package/esm/models/components/connectioncredentials.d.ts +2 -0
- package/esm/models/components/connectioncredentials.d.ts.map +1 -1
- package/esm/models/components/connectioncredentials.js +2 -0
- package/esm/models/components/connectioncredentials.js.map +1 -1
- package/esm/models/components/connectorprotocol.d.ts +0 -2
- package/esm/models/components/connectorprotocol.d.ts.map +1 -1
- package/esm/models/components/connectorprotocol.js +0 -2
- package/esm/models/components/connectorprotocol.js.map +1 -1
- package/esm/models/components/createconnectorrequest.d.ts +11 -0
- package/esm/models/components/createconnectorrequest.d.ts.map +1 -1
- package/esm/models/components/createconnectorrequest.js +6 -0
- package/esm/models/components/createconnectorrequest.js.map +1 -1
- package/esm/models/components/credentialsstatus.d.ts +15 -0
- package/esm/models/components/credentialsstatus.d.ts.map +1 -0
- package/esm/models/components/credentialsstatus.js +27 -0
- package/esm/models/components/credentialsstatus.js.map +1 -0
- package/esm/models/components/deploymentdetailresponse.d.ts +4 -0
- package/esm/models/components/deploymentdetailresponse.d.ts.map +1 -1
- package/esm/models/components/deploymentdetailresponse.js +2 -0
- package/esm/models/components/deploymentdetailresponse.js.map +1 -1
- package/esm/models/components/deploymentlistresponse.d.ts +8 -0
- package/esm/models/components/deploymentlistresponse.d.ts.map +1 -1
- package/esm/models/components/deploymentlistresponse.js +8 -0
- package/esm/models/components/deploymentlistresponse.js.map +1 -1
- package/esm/models/components/deploymentresponse.d.ts +4 -0
- package/esm/models/components/deploymentresponse.d.ts.map +1 -1
- package/esm/models/components/deploymentresponse.js +2 -0
- package/esm/models/components/deploymentresponse.js.map +1 -1
- package/esm/models/components/encodedpayloadoptions.d.ts +1 -0
- package/esm/models/components/encodedpayloadoptions.d.ts.map +1 -1
- package/esm/models/components/encodedpayloadoptions.js +1 -0
- package/esm/models/components/encodedpayloadoptions.js.map +1 -1
- package/esm/models/components/executionlogrecord.d.ts +17 -0
- package/esm/models/components/executionlogrecord.d.ts.map +1 -0
- package/esm/models/components/executionlogrecord.js +27 -0
- package/esm/models/components/executionlogrecord.js.map +1 -0
- package/esm/models/components/executionlogsearchresponse.d.ts +12 -0
- package/esm/models/components/executionlogsearchresponse.d.ts.map +1 -0
- package/esm/models/components/executionlogsearchresponse.js +21 -0
- package/esm/models/components/executionlogsearchresponse.js.map +1 -0
- package/esm/models/components/extendedoauthservermetadata.d.ts +64 -0
- package/esm/models/components/extendedoauthservermetadata.d.ts.map +1 -0
- package/esm/models/components/extendedoauthservermetadata.js +64 -0
- package/esm/models/components/extendedoauthservermetadata.js.map +1 -0
- package/esm/models/components/feedresultgetlog.d.ts +13 -0
- package/esm/models/components/feedresultgetlog.d.ts.map +1 -0
- package/esm/models/components/feedresultgetlog.js +17 -0
- package/esm/models/components/feedresultgetlog.js.map +1 -0
- package/esm/models/components/feedresultgetspan.d.ts +13 -0
- package/esm/models/components/feedresultgetspan.d.ts.map +1 -0
- package/esm/models/components/feedresultgetspan.js +17 -0
- package/esm/models/components/feedresultgetspan.js.map +1 -0
- package/esm/models/components/feedresultgetspanevaluation.d.ts +13 -0
- package/esm/models/components/feedresultgetspanevaluation.d.ts.map +1 -0
- package/esm/models/components/feedresultgetspanevaluation.js +17 -0
- package/esm/models/components/feedresultgetspanevaluation.js.map +1 -0
- package/esm/models/components/feedresultgettrace.d.ts +13 -0
- package/esm/models/components/feedresultgettrace.d.ts.map +1 -0
- package/esm/models/components/feedresultgettrace.js +17 -0
- package/esm/models/components/feedresultgettrace.js.map +1 -0
- package/esm/models/components/getlog.d.ts +35 -0
- package/esm/models/components/getlog.d.ts.map +1 -0
- package/esm/models/components/getlog.js +55 -0
- package/esm/models/components/getlog.js.map +1 -0
- package/esm/models/components/getlogfieldoptions.d.ts +10 -0
- package/esm/models/components/getlogfieldoptions.d.ts.map +1 -0
- package/esm/models/components/getlogfieldoptions.js +14 -0
- package/esm/models/components/getlogfieldoptions.js.map +1 -0
- package/esm/models/components/getlogfields.d.ts +11 -0
- package/esm/models/components/getlogfields.d.ts.map +1 -0
- package/esm/models/components/getlogfields.js +21 -0
- package/esm/models/components/getlogfields.js.map +1 -0
- package/esm/models/components/getlogs.d.ts +11 -0
- package/esm/models/components/getlogs.d.ts.map +1 -0
- package/esm/models/components/getlogs.js +15 -0
- package/esm/models/components/getlogs.js.map +1 -0
- package/esm/models/components/getspan.d.ts +81 -0
- package/esm/models/components/getspan.d.ts.map +1 -0
- package/esm/models/components/getspan.js +143 -0
- package/esm/models/components/getspan.js.map +1 -0
- package/esm/models/components/getspanevaluation.d.ts +25 -0
- package/esm/models/components/getspanevaluation.d.ts.map +1 -0
- package/esm/models/components/getspanevaluation.js +42 -0
- package/esm/models/components/getspanevaluation.js.map +1 -0
- package/esm/models/components/getspanevaluationfieldoptions.d.ts +10 -0
- package/esm/models/components/getspanevaluationfieldoptions.d.ts.map +1 -0
- package/esm/models/components/getspanevaluationfieldoptions.js +14 -0
- package/esm/models/components/getspanevaluationfieldoptions.js.map +1 -0
- package/esm/models/components/getspanevaluationfields.d.ts +11 -0
- package/esm/models/components/getspanevaluationfields.d.ts.map +1 -0
- package/esm/models/components/getspanevaluationfields.js +20 -0
- package/esm/models/components/getspanevaluationfields.js.map +1 -0
- package/esm/models/components/getspanevaluations.d.ts +11 -0
- package/esm/models/components/getspanevaluations.d.ts.map +1 -0
- package/esm/models/components/getspanevaluations.js +20 -0
- package/esm/models/components/getspanevaluations.js.map +1 -0
- package/esm/models/components/getspanfieldoptions.d.ts +10 -0
- package/esm/models/components/getspanfieldoptions.d.ts.map +1 -0
- package/esm/models/components/getspanfieldoptions.js +14 -0
- package/esm/models/components/getspanfieldoptions.js.map +1 -0
- package/esm/models/components/getspanfields.d.ts +11 -0
- package/esm/models/components/getspanfields.d.ts.map +1 -0
- package/esm/models/components/getspanfields.js +21 -0
- package/esm/models/components/getspanfields.js.map +1 -0
- package/esm/models/components/getspans.d.ts +11 -0
- package/esm/models/components/getspans.d.ts.map +1 -0
- package/esm/models/components/getspans.js +15 -0
- package/esm/models/components/getspans.js.map +1 -0
- package/esm/models/components/gettrace.d.ts +51 -0
- package/esm/models/components/gettrace.d.ts.map +1 -0
- package/esm/models/components/gettrace.js +91 -0
- package/esm/models/components/gettrace.js.map +1 -0
- package/esm/models/components/gettracefieldoptions.d.ts +10 -0
- package/esm/models/components/gettracefieldoptions.d.ts.map +1 -0
- package/esm/models/components/gettracefieldoptions.js +14 -0
- package/esm/models/components/gettracefieldoptions.js.map +1 -0
- package/esm/models/components/gettracefields.d.ts +11 -0
- package/esm/models/components/gettracefields.d.ts.map +1 -0
- package/esm/models/components/gettracefields.js +20 -0
- package/esm/models/components/gettracefields.js.map +1 -0
- package/esm/models/components/gettraces.d.ts +11 -0
- package/esm/models/components/gettraces.d.ts.map +1 -0
- package/esm/models/components/gettraces.js +15 -0
- package/esm/models/components/gettraces.js.map +1 -0
- package/esm/models/components/httpstatus.d.ts +112 -0
- package/esm/models/components/httpstatus.d.ts.map +1 -0
- package/esm/models/components/httpstatus.js +93 -0
- package/esm/models/components/httpstatus.js.map +1 -0
- package/esm/models/components/index.d.ts +39 -1
- package/esm/models/components/index.d.ts.map +1 -1
- package/esm/models/components/index.js +39 -1
- package/esm/models/components/index.js.map +1 -1
- package/esm/models/components/logsrequest.d.ts +22 -0
- package/esm/models/components/logsrequest.d.ts.map +1 -0
- package/esm/models/components/logsrequest.js +25 -0
- package/esm/models/components/logsrequest.js.map +1 -0
- package/esm/models/components/mcpservercard.d.ts +3 -3
- package/esm/models/components/mcpservercard.d.ts.map +1 -1
- package/esm/models/components/mcpservercard.js +3 -3
- package/esm/models/components/mcpservercard.js.map +1 -1
- package/esm/models/components/mcpservercardtool.d.ts +27 -0
- package/esm/models/components/mcpservercardtool.d.ts.map +1 -0
- package/esm/models/components/mcpservercardtool.js +31 -0
- package/esm/models/components/mcpservercardtool.js.map +1 -0
- package/esm/models/components/mcptoolmeta.d.ts +11 -16
- package/esm/models/components/mcptoolmeta.d.ts.map +1 -1
- package/esm/models/components/mcptoolmeta.js +5 -13
- package/esm/models/components/mcptoolmeta.js.map +1 -1
- package/esm/models/components/mcpuitoolmeta.d.ts +23 -0
- package/esm/models/components/mcpuitoolmeta.d.ts.map +1 -0
- package/esm/models/components/mcpuitoolmeta.js +23 -0
- package/esm/models/components/mcpuitoolmeta.js.map +1 -0
- package/esm/models/components/observabilityerrorcode.d.ts +0 -1
- package/esm/models/components/observabilityerrorcode.d.ts.map +1 -1
- package/esm/models/components/observabilityerrorcode.js +0 -1
- package/esm/models/components/observabilityerrorcode.js.map +1 -1
- package/esm/models/components/otelfielddefinition.d.ts +57 -0
- package/esm/models/components/otelfielddefinition.d.ts.map +1 -0
- package/esm/models/components/otelfielddefinition.js +64 -0
- package/esm/models/components/otelfielddefinition.js.map +1 -0
- package/esm/models/components/outboundauthenticationtype.d.ts +2 -0
- package/esm/models/components/outboundauthenticationtype.d.ts.map +1 -1
- package/esm/models/components/outboundauthenticationtype.js +2 -0
- package/esm/models/components/outboundauthenticationtype.js.map +1 -1
- package/esm/models/components/prompttokensdetails.d.ts +1 -0
- package/esm/models/components/prompttokensdetails.d.ts.map +1 -1
- package/esm/models/components/prompttokensdetails.js +2 -0
- package/esm/models/components/prompttokensdetails.js.map +1 -1
- package/esm/models/components/reasoningeffort.d.ts +4 -0
- package/esm/models/components/reasoningeffort.d.ts.map +1 -1
- package/esm/models/components/reasoningeffort.js +4 -0
- package/esm/models/components/reasoningeffort.js.map +1 -1
- package/esm/models/components/spanevaluationsrequest.d.ts +12 -0
- package/esm/models/components/spanevaluationsrequest.d.ts.map +1 -0
- package/esm/models/components/spanevaluationsrequest.js +18 -0
- package/esm/models/components/spanevaluationsrequest.js.map +1 -0
- package/esm/models/components/spansrequest.d.ts +12 -0
- package/esm/models/components/spansrequest.d.ts.map +1 -0
- package/esm/models/components/spansrequest.js +18 -0
- package/esm/models/components/spansrequest.js.map +1 -0
- package/esm/models/components/streamerror.d.ts +10 -0
- package/esm/models/components/streamerror.d.ts.map +1 -0
- package/esm/models/components/streamerror.js +15 -0
- package/esm/models/components/streamerror.js.map +1 -0
- package/esm/models/components/tooltype.d.ts +12 -0
- package/esm/models/components/tooltype.d.ts.map +1 -0
- package/esm/models/components/tooltype.js +15 -0
- package/esm/models/components/tooltype.js.map +1 -0
- package/esm/models/components/tracesrequest.d.ts +12 -0
- package/esm/models/components/tracesrequest.d.ts.map +1 -0
- package/esm/models/components/tracesrequest.js +18 -0
- package/esm/models/components/tracesrequest.js.map +1 -0
- package/esm/models/components/turbinetoollocale.d.ts +24 -0
- package/esm/models/components/turbinetoollocale.d.ts.map +1 -0
- package/esm/models/components/turbinetoollocale.js +25 -0
- package/esm/models/components/turbinetoollocale.js.map +1 -0
- package/esm/models/components/turbinetoolmeta.d.ts +15 -0
- package/esm/models/components/turbinetoolmeta.d.ts.map +1 -0
- package/esm/models/components/turbinetoolmeta.js +25 -0
- package/esm/models/components/turbinetoolmeta.js.map +1 -0
- package/esm/models/components/updateconnectorrequest.d.ts +2 -6
- package/esm/models/components/updateconnectorrequest.d.ts.map +1 -1
- package/esm/models/components/updateconnectorrequest.js +1 -2
- package/esm/models/components/updateconnectorrequest.js.map +1 -1
- package/esm/models/components/usageinfodollardefs.d.ts +2 -0
- package/esm/models/components/usageinfodollardefs.d.ts.map +1 -1
- package/esm/models/components/usageinfodollardefs.js +4 -0
- package/esm/models/components/usageinfodollardefs.js.map +1 -1
- package/esm/models/components/voicecreaterequest.d.ts +0 -3
- package/esm/models/components/voicecreaterequest.d.ts.map +1 -1
- package/esm/models/components/voicecreaterequest.js +0 -2
- package/esm/models/components/voicecreaterequest.js.map +1 -1
- package/esm/models/components/voiceresponse.d.ts +1 -2
- package/esm/models/components/voiceresponse.d.ts.map +1 -1
- package/esm/models/components/voiceresponse.js +2 -2
- package/esm/models/components/voiceresponse.js.map +1 -1
- package/esm/models/components/voiceupdaterequest.d.ts +0 -3
- package/esm/models/components/voiceupdaterequest.d.ts.map +1 -1
- package/esm/models/components/voiceupdaterequest.js +0 -2
- package/esm/models/components/voiceupdaterequest.js.map +1 -1
- package/esm/models/components/workflow.d.ts +4 -4
- package/esm/models/components/workflow.d.ts.map +1 -1
- package/esm/models/components/workflow.js +1 -2
- package/esm/models/components/workflow.js.map +1 -1
- package/esm/models/components/workflowbasicdefinition.d.ts +4 -0
- package/esm/models/components/workflowbasicdefinition.d.ts.map +1 -1
- package/esm/models/components/workflowbasicdefinition.js +1 -0
- package/esm/models/components/workflowbasicdefinition.js.map +1 -1
- package/esm/models/components/workflowcodedefinition.d.ts +4 -0
- package/esm/models/components/workflowcodedefinition.d.ts.map +1 -1
- package/esm/models/components/workflowcodedefinition.js +2 -0
- package/esm/models/components/workflowcodedefinition.js.map +1 -1
- package/esm/models/components/workflowscheduletriggerrequest.d.ts +16 -0
- package/esm/models/components/workflowscheduletriggerrequest.d.ts.map +1 -0
- package/esm/models/components/workflowscheduletriggerrequest.js +14 -0
- package/esm/models/components/workflowscheduletriggerrequest.js.map +1 -0
- package/esm/models/components/workflowupdaterequest.d.ts +5 -0
- package/esm/models/components/workflowupdaterequest.d.ts.map +1 -1
- package/esm/models/components/workflowupdaterequest.js +1 -0
- package/esm/models/components/workflowupdaterequest.js.map +1 -1
- package/esm/models/components/workflowwithworkerstatus.d.ts +4 -4
- package/esm/models/components/workflowwithworkerstatus.d.ts.map +1 -1
- package/esm/models/components/workflowwithworkerstatus.js +1 -2
- package/esm/models/components/workflowwithworkerstatus.js.map +1 -1
- package/esm/models/operations/connectorgetauthurlv1.d.ts +11 -0
- package/esm/models/operations/connectorgetauthurlv1.d.ts.map +1 -1
- package/esm/models/operations/connectorgetauthurlv1.js +5 -0
- package/esm/models/operations/connectorgetauthurlv1.js.map +1 -1
- package/esm/models/operations/getlogfieldoptionsv1observabilitylogsfieldsfieldnameoptionsget.d.ts +16 -0
- package/esm/models/operations/getlogfieldoptionsv1observabilitylogsfieldsfieldnameoptionsget.d.ts.map +1 -0
- package/esm/models/operations/getlogfieldoptionsv1observabilitylogsfieldsfieldnameoptionsget.js +21 -0
- package/esm/models/operations/getlogfieldoptionsv1observabilitylogsfieldsfieldnameoptionsget.js.map +1 -0
- package/esm/models/operations/getspanbyidv1observabilitytracestraceidspansspanidget.d.ts +18 -0
- package/esm/models/operations/getspanbyidv1observabilitytracestraceidspansspanidget.d.ts.map +1 -0
- package/esm/models/operations/getspanbyidv1observabilitytracestraceidspansspanidget.js +23 -0
- package/esm/models/operations/getspanbyidv1observabilitytracestraceidspansspanidget.js.map +1 -0
- package/esm/models/operations/getspanevaluationfieldoptionsv1observabilityspansevaluationsfieldsfieldnameoptionsget.d.ts +16 -0
- package/esm/models/operations/getspanevaluationfieldoptionsv1observabilityspansevaluationsfieldsfieldnameoptionsget.d.ts.map +1 -0
- package/esm/models/operations/getspanevaluationfieldoptionsv1observabilityspansevaluationsfieldsfieldnameoptionsget.js +21 -0
- package/esm/models/operations/getspanevaluationfieldoptionsv1observabilityspansevaluationsfieldsfieldnameoptionsget.js.map +1 -0
- package/esm/models/operations/getspanfieldoptionsv1observabilityspansfieldsfieldnameoptionsget.d.ts +16 -0
- package/esm/models/operations/getspanfieldoptionsv1observabilityspansfieldsfieldnameoptionsget.d.ts.map +1 -0
- package/esm/models/operations/getspanfieldoptionsv1observabilityspansfieldsfieldnameoptionsget.js +21 -0
- package/esm/models/operations/getspanfieldoptionsv1observabilityspansfieldsfieldnameoptionsget.js.map +1 -0
- package/esm/models/operations/gettracebyidv1observabilitytracestraceidget.d.ts +12 -0
- package/esm/models/operations/gettracebyidv1observabilitytracestraceidget.d.ts.map +1 -0
- package/esm/models/operations/gettracebyidv1observabilitytracestraceidget.js +18 -0
- package/esm/models/operations/gettracebyidv1observabilitytracestraceidget.js.map +1 -0
- package/esm/models/operations/gettracefieldoptionsv1observabilitytracesfieldsfieldnameoptionsget.d.ts +16 -0
- package/esm/models/operations/gettracefieldoptionsv1observabilitytracesfieldsfieldnameoptionsget.d.ts.map +1 -0
- package/esm/models/operations/gettracefieldoptionsv1observabilitytracesfieldsfieldnameoptionsget.js +21 -0
- package/esm/models/operations/gettracefieldoptionsv1observabilitytracesfieldsfieldnameoptionsget.js.map +1 -0
- package/esm/models/operations/gettracespansv1observabilitytracestraceidspansget.d.ts +20 -0
- package/esm/models/operations/gettracespansv1observabilitytracestraceidspansget.d.ts.map +1 -0
- package/esm/models/operations/gettracespansv1observabilitytracestraceidspansget.js +24 -0
- package/esm/models/operations/gettracespansv1observabilitytracestraceidspansget.js.map +1 -0
- package/esm/models/operations/getworkflowexecutionlogs.d.ts +61 -0
- package/esm/models/operations/getworkflowexecutionlogs.d.ts.map +1 -0
- package/esm/models/operations/getworkflowexecutionlogs.js +36 -0
- package/esm/models/operations/getworkflowexecutionlogs.js.map +1 -0
- package/esm/models/operations/getworkflowsv1workflowsget.d.ts +71 -3
- package/esm/models/operations/getworkflowsv1workflowsget.d.ts.map +1 -1
- package/esm/models/operations/getworkflowsv1workflowsget.js +41 -2
- package/esm/models/operations/getworkflowsv1workflowsget.js.map +1 -1
- package/esm/models/operations/index.d.ts +15 -0
- package/esm/models/operations/index.d.ts.map +1 -1
- package/esm/models/operations/index.js +15 -0
- package/esm/models/operations/index.js.map +1 -1
- package/esm/models/operations/listdeploymentsv1workflowsdeploymentsget.d.ts +25 -0
- package/esm/models/operations/listdeploymentsv1workflowsdeploymentsget.d.ts.map +1 -1
- package/esm/models/operations/listdeploymentsv1workflowsdeploymentsget.js +7 -0
- package/esm/models/operations/listdeploymentsv1workflowsdeploymentsget.js.map +1 -1
- package/esm/models/operations/listrunsv1workflowsrunsget.d.ts +63 -1
- package/esm/models/operations/listrunsv1workflowsrunsget.d.ts.map +1 -1
- package/esm/models/operations/listrunsv1workflowsrunsget.js +34 -0
- package/esm/models/operations/listrunsv1workflowsrunsget.js.map +1 -1
- package/esm/models/operations/searchlatestspanevaluationsv1observabilityspansevaluationssearchlatestpost.d.ts +21 -0
- package/esm/models/operations/searchlatestspanevaluationsv1observabilityspansevaluationssearchlatestpost.d.ts.map +1 -0
- package/esm/models/operations/searchlatestspanevaluationsv1observabilityspansevaluationssearchlatestpost.js +25 -0
- package/esm/models/operations/searchlatestspanevaluationsv1observabilityspansevaluationssearchlatestpost.js.map +1 -0
- package/esm/models/operations/searchlogsv1observabilitylogssearchpost.d.ts +21 -0
- package/esm/models/operations/searchlogsv1observabilitylogssearchpost.d.ts.map +1 -0
- package/esm/models/operations/searchlogsv1observabilitylogssearchpost.js +24 -0
- package/esm/models/operations/searchlogsv1observabilitylogssearchpost.js.map +1 -0
- package/esm/models/operations/searchspanevaluationsv1observabilityspansevaluationssearchpost.d.ts +21 -0
- package/esm/models/operations/searchspanevaluationsv1observabilityspansevaluationssearchpost.d.ts.map +1 -0
- package/esm/models/operations/searchspanevaluationsv1observabilityspansevaluationssearchpost.js +25 -0
- package/esm/models/operations/searchspanevaluationsv1observabilityspansevaluationssearchpost.js.map +1 -0
- package/esm/models/operations/searchspansv1observabilityspanssearchpost.d.ts +21 -0
- package/esm/models/operations/searchspansv1observabilityspanssearchpost.d.ts.map +1 -0
- package/esm/models/operations/searchspansv1observabilityspanssearchpost.js +24 -0
- package/esm/models/operations/searchspansv1observabilityspanssearchpost.js.map +1 -0
- package/esm/models/operations/searchtracesv1observabilitytracessearchpost.d.ts +21 -0
- package/esm/models/operations/searchtracesv1observabilitytracessearchpost.d.ts.map +1 -0
- package/esm/models/operations/searchtracesv1observabilitytracessearchpost.js +24 -0
- package/esm/models/operations/searchtracesv1observabilitytracessearchpost.js.map +1 -0
- package/esm/models/operations/speechv1audiospeechpost.d.ts +3 -3
- package/esm/models/operations/speechv1audiospeechpost.d.ts.map +1 -1
- package/esm/models/operations/speechv1audiospeechpost.js +3 -3
- package/esm/models/operations/speechv1audiospeechpost.js.map +1 -1
- package/esm/models/operations/streamworkflowexecutionlogs.d.ts +58 -0
- package/esm/models/operations/streamworkflowexecutionlogs.d.ts.map +1 -0
- package/esm/models/operations/streamworkflowexecutionlogs.js +70 -0
- package/esm/models/operations/streamworkflowexecutionlogs.js.map +1 -0
- package/esm/models/operations/triggerschedulev1workflowsschedulesscheduleidtriggerpost.d.ts +15 -0
- package/esm/models/operations/triggerschedulev1workflowsschedulesscheduleidtriggerpost.d.ts.map +1 -0
- package/esm/models/operations/triggerschedulev1workflowsschedulesscheduleidtriggerpost.js +22 -0
- package/esm/models/operations/triggerschedulev1workflowsschedulesscheduleidtriggerpost.js.map +1 -0
- package/esm/sdk/executions.d.ts +22 -0
- package/esm/sdk/executions.d.ts.map +1 -1
- package/esm/sdk/executions.js +28 -0
- package/esm/sdk/executions.js.map +1 -1
- package/esm/sdk/logs.d.ts +18 -0
- package/esm/sdk/logs.d.ts.map +1 -0
- package/esm/sdk/logs.js +30 -0
- package/esm/sdk/logs.js.map +1 -0
- package/esm/sdk/observability.d.ts +9 -0
- package/esm/sdk/observability.d.ts.map +1 -1
- package/esm/sdk/observability.js +15 -0
- package/esm/sdk/observability.js.map +1 -1
- package/esm/sdk/schedules.d.ts +4 -0
- package/esm/sdk/schedules.d.ts.map +1 -1
- package/esm/sdk/schedules.js +7 -0
- package/esm/sdk/schedules.js.map +1 -1
- package/esm/sdk/spans.d.ts +34 -0
- package/esm/sdk/spans.d.ts.map +1 -0
- package/esm/sdk/spans.js +58 -0
- package/esm/sdk/spans.js.map +1 -0
- package/esm/sdk/traces.d.ts +30 -0
- package/esm/sdk/traces.d.ts.map +1 -0
- package/esm/sdk/traces.js +51 -0
- package/esm/sdk/traces.js.map +1 -0
- package/jsr.json +1 -1
- package/package.json +21 -1
- package/src/extra/observability/formatting.ts +194 -0
- package/src/extra/observability/index.ts +2 -0
- package/src/extra/observability/otel.ts +750 -0
- package/src/extra/observability/streaming.ts +174 -0
- package/src/funcs/betaConnectorsGetAuthUrl.ts +2 -0
- package/src/funcs/betaObservabilityLogsFetchOptions.ts +192 -0
- package/src/funcs/betaObservabilityLogsList.ts +154 -0
- package/src/funcs/betaObservabilityLogsSearch.ts +183 -0
- package/src/funcs/betaObservabilitySpansFetchSpanEvalFieldOptions.ts +192 -0
- package/src/funcs/betaObservabilitySpansFetchSpanFieldOptions.ts +192 -0
- package/src/funcs/betaObservabilitySpansListSpanEvalFields.ts +155 -0
- package/src/funcs/betaObservabilitySpansListSpanFields.ts +154 -0
- package/src/funcs/betaObservabilitySpansSearchLatestSpanEvaluations.ts +191 -0
- package/src/funcs/betaObservabilitySpansSearchSpanEvaluations.ts +189 -0
- package/src/funcs/betaObservabilitySpansSearchSpans.ts +183 -0
- package/src/funcs/betaObservabilityTracesFetchOptions.ts +192 -0
- package/src/funcs/betaObservabilityTracesGetSpanById.ts +196 -0
- package/src/funcs/betaObservabilityTracesGetTraceById.ts +181 -0
- package/src/funcs/betaObservabilityTracesGetTraceFields.ts +154 -0
- package/src/funcs/betaObservabilityTracesGetTraceSpans.ts +191 -0
- package/src/funcs/betaObservabilityTracesSearch.ts +184 -0
- package/src/funcs/workflowsDeploymentsListDeployments.ts +5 -0
- package/src/funcs/workflowsExecutionsGetWorkflowExecutionLogs.ts +197 -0
- package/src/funcs/workflowsExecutionsStreamWorkflowExecutionLogs.ts +207 -0
- package/src/funcs/workflowsGetWorkflows.ts +6 -0
- package/src/funcs/workflowsRunsListRuns.ts +7 -0
- package/src/funcs/workflowsSchedulesTriggerSchedule.ts +186 -0
- package/src/hooks/registration.ts +6 -0
- package/src/hooks/tracing.ts +173 -0
- package/src/lib/config.ts +2 -2
- package/src/models/components/authdata.ts +3 -3
- package/src/models/components/authenticationconfiguration.ts +6 -0
- package/src/models/components/authstatus.ts +19 -0
- package/src/models/components/basefielddefinition.ts +11 -7
- package/src/models/components/completiontokensdetails.ts +39 -0
- package/src/models/components/connectioncredentials.ts +4 -0
- package/src/models/components/connectorprotocol.ts +0 -5
- package/src/models/components/createconnectorrequest.ts +23 -0
- package/src/models/components/credentialsstatus.ts +49 -0
- package/src/models/components/deploymentdetailresponse.ts +6 -0
- package/src/models/components/deploymentlistresponse.ts +16 -0
- package/src/models/components/deploymentresponse.ts +6 -0
- package/src/models/components/encodedpayloadoptions.ts +1 -0
- package/src/models/components/executionlogrecord.ts +49 -0
- package/src/models/components/executionlogsearchresponse.ts +42 -0
- package/src/models/components/extendedoauthservermetadata.ts +163 -0
- package/src/models/components/feedresultgetlog.ts +36 -0
- package/src/models/components/feedresultgetspan.ts +36 -0
- package/src/models/components/feedresultgetspanevaluation.ts +39 -0
- package/src/models/components/feedresultgettrace.ts +36 -0
- package/src/models/components/getlog.ts +88 -0
- package/src/models/components/getlogfieldoptions.ts +31 -0
- package/src/models/components/getlogfields.ts +38 -0
- package/src/models/components/getlogs.ts +32 -0
- package/src/models/components/getspan.ts +222 -0
- package/src/models/components/getspanevaluation.ts +72 -0
- package/src/models/components/getspanevaluationfieldoptions.ts +31 -0
- package/src/models/components/getspanevaluationfields.ts +40 -0
- package/src/models/components/getspanevaluations.ts +40 -0
- package/src/models/components/getspanfieldoptions.ts +31 -0
- package/src/models/components/getspanfields.ts +38 -0
- package/src/models/components/getspans.ts +32 -0
- package/src/models/components/gettrace.ts +145 -0
- package/src/models/components/gettracefieldoptions.ts +31 -0
- package/src/models/components/gettracefields.ts +38 -0
- package/src/models/components/gettraces.ts +32 -0
- package/src/models/components/httpstatus.ts +120 -0
- package/src/models/components/index.ts +39 -1
- package/src/models/components/logsrequest.ts +45 -0
- package/src/models/components/mcpservercard.ts +8 -5
- package/src/models/components/mcpservercardtool.ts +60 -0
- package/src/models/components/mcptoolmeta.ts +16 -24
- package/src/models/components/mcpuitoolmeta.ts +47 -0
- package/src/models/components/observabilityerrorcode.ts +0 -1
- package/src/models/components/otelfielddefinition.ts +102 -0
- package/src/models/components/outboundauthenticationtype.ts +2 -0
- package/src/models/components/prompttokensdetails.ts +3 -0
- package/src/models/components/reasoningeffort.ts +4 -0
- package/src/models/components/spanevaluationsrequest.ts +36 -0
- package/src/models/components/spansrequest.ts +32 -0
- package/src/models/components/streamerror.ts +29 -0
- package/src/models/components/tooltype.ts +20 -0
- package/src/models/components/tracesrequest.ts +32 -0
- package/src/models/components/turbinetoollocale.ts +46 -0
- package/src/models/components/turbinetoolmeta.ts +48 -0
- package/src/models/components/updateconnectorrequest.ts +3 -10
- package/src/models/components/usageinfodollardefs.ts +8 -0
- package/src/models/components/voicecreaterequest.ts +0 -8
- package/src/models/components/voiceresponse.ts +3 -6
- package/src/models/components/voiceupdaterequest.ts +0 -8
- package/src/models/components/workflow.ts +5 -6
- package/src/models/components/workflowbasicdefinition.ts +5 -0
- package/src/models/components/workflowcodedefinition.ts +6 -0
- package/src/models/components/workflowscheduletriggerrequest.ts +40 -0
- package/src/models/components/workflowupdaterequest.ts +6 -0
- package/src/models/components/workflowwithworkerstatus.ts +5 -6
- package/src/models/operations/connectorgetauthurlv1.ts +15 -0
- package/src/models/operations/getlogfieldoptionsv1observabilitylogsfieldsfieldnameoptionsget.ts +49 -0
- package/src/models/operations/getspanbyidv1observabilitytracestraceidspansspanidget.ts +50 -0
- package/src/models/operations/getspanevaluationfieldoptionsv1observabilityspansevaluationsfieldsfieldnameoptionsget.ts +49 -0
- package/src/models/operations/getspanfieldoptionsv1observabilityspansfieldsfieldnameoptionsget.ts +49 -0
- package/src/models/operations/gettracebyidv1observabilitytracestraceidget.ts +40 -0
- package/src/models/operations/gettracefieldoptionsv1observabilitytracesfieldsfieldnameoptionsget.ts +49 -0
- package/src/models/operations/gettracespansv1observabilitytracestraceidspansget.ts +53 -0
- package/src/models/operations/getworkflowexecutionlogs.ts +102 -0
- package/src/models/operations/getworkflowsv1workflowsget.ts +122 -5
- package/src/models/operations/index.ts +15 -0
- package/src/models/operations/listdeploymentsv1workflowsdeploymentsget.ts +32 -0
- package/src/models/operations/listrunsv1workflowsrunsget.ts +87 -1
- package/src/models/operations/searchlatestspanevaluationsv1observabilityspansevaluationssearchlatestpost.ts +57 -0
- package/src/models/operations/searchlogsv1observabilitylogssearchpost.ts +54 -0
- package/src/models/operations/searchspanevaluationsv1observabilityspansevaluationssearchpost.ts +57 -0
- package/src/models/operations/searchspansv1observabilityspanssearchpost.ts +54 -0
- package/src/models/operations/searchtracesv1observabilitytracessearchpost.ts +54 -0
- package/src/models/operations/speechv1audiospeechpost.ts +12 -12
- package/src/models/operations/streamworkflowexecutionlogs.ts +157 -0
- package/src/models/operations/triggerschedulev1workflowsschedulesscheduleidtriggerpost.ts +53 -0
- package/src/sdk/executions.ts +44 -0
- package/src/sdk/logs.ts +55 -0
- package/src/sdk/observability.ts +18 -0
- package/src/sdk/schedules.ts +16 -0
- package/src/sdk/spans.ts +116 -0
- package/src/sdk/traces.ts +102 -0
- package/tests/extra/observability/customProvider.test.ts +98 -0
- package/tests/extra/observability/formatting.test.ts +111 -0
- package/tests/extra/observability/helpers.ts +62 -0
- package/tests/extra/observability/otel.test.ts +453 -0
- package/tests/extra/observability/streaming.test.ts +94 -0
- package/esm/models/components/voiceappearance.d.ts +0 -23
- package/esm/models/components/voiceappearance.d.ts.map +0 -1
- package/esm/models/components/voiceappearance.js +0 -42
- package/esm/models/components/voiceappearance.js.map +0 -1
- package/src/models/components/voiceappearance.ts +0 -75
|
@@ -0,0 +1,453 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests for OTEL span enrichment helpers.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import {
|
|
6
|
+
context as contextApi,
|
|
7
|
+
ROOT_CONTEXT,
|
|
8
|
+
SpanStatusCode,
|
|
9
|
+
trace,
|
|
10
|
+
type Context,
|
|
11
|
+
type ContextManager,
|
|
12
|
+
type Span,
|
|
13
|
+
type Tracer,
|
|
14
|
+
type TracerProvider,
|
|
15
|
+
} from "@opentelemetry/api";
|
|
16
|
+
import { HTTPClient, Mistral } from "../../../src/index.js";
|
|
17
|
+
import { TracingHook, TracingContext, TRACING_SPAN_KEY, TRACING_TRACER_KEY } from "../../../src/hooks/tracing.js";
|
|
18
|
+
import {
|
|
19
|
+
enrichSpanFromRequest,
|
|
20
|
+
enrichSpanFromResponse,
|
|
21
|
+
getTracedRequestAndSpan,
|
|
22
|
+
getTracedResponse,
|
|
23
|
+
MistralAIAttributes,
|
|
24
|
+
registerTracerProvider,
|
|
25
|
+
semConvAttributes,
|
|
26
|
+
} from "../../../src/extra/observability/otel.js";
|
|
27
|
+
import { createMockSpan, createMockTracer } from "./helpers.js";
|
|
28
|
+
|
|
29
|
+
class TestContextManager implements ContextManager {
|
|
30
|
+
#activeContext: Context = ROOT_CONTEXT;
|
|
31
|
+
|
|
32
|
+
active(): Context {
|
|
33
|
+
return this.#activeContext;
|
|
34
|
+
}
|
|
35
|
+
|
|
36
|
+
with<A extends unknown[], F extends (...args: A) => ReturnType<F>>(
|
|
37
|
+
context: Context,
|
|
38
|
+
fn: F,
|
|
39
|
+
thisArg?: ThisParameterType<F>,
|
|
40
|
+
...args: A
|
|
41
|
+
): ReturnType<F> {
|
|
42
|
+
const previousContext = this.#activeContext;
|
|
43
|
+
this.#activeContext = context;
|
|
44
|
+
|
|
45
|
+
const restore = () => {
|
|
46
|
+
this.#activeContext = previousContext;
|
|
47
|
+
};
|
|
48
|
+
|
|
49
|
+
try {
|
|
50
|
+
const result = fn.call(thisArg, ...args);
|
|
51
|
+
if (result instanceof Promise) {
|
|
52
|
+
return result.finally(restore) as ReturnType<F>;
|
|
53
|
+
}
|
|
54
|
+
restore();
|
|
55
|
+
return result;
|
|
56
|
+
} catch (error) {
|
|
57
|
+
restore();
|
|
58
|
+
throw error;
|
|
59
|
+
}
|
|
60
|
+
}
|
|
61
|
+
|
|
62
|
+
bind<T>(_: Context, target: T): T {
|
|
63
|
+
return target;
|
|
64
|
+
}
|
|
65
|
+
|
|
66
|
+
enable(): this {
|
|
67
|
+
return this;
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
disable(): this {
|
|
71
|
+
this.#activeContext = ROOT_CONTEXT;
|
|
72
|
+
return this;
|
|
73
|
+
}
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
describe("enrichSpanFromRequest", () => {
|
|
77
|
+
test("chat completion with model and messages", () => {
|
|
78
|
+
const span = createMockSpan();
|
|
79
|
+
const body = JSON.stringify({
|
|
80
|
+
model: "mistral-large",
|
|
81
|
+
messages: [{ role: "user", content: "Hi" }],
|
|
82
|
+
temperature: 0.7,
|
|
83
|
+
});
|
|
84
|
+
enrichSpanFromRequest(span, "chat_completion_v1", new URL("https://api.mistral.ai/v1/chat"), "POST", "api.mistral.ai", body);
|
|
85
|
+
|
|
86
|
+
expect(span.name).toBe("chat mistral-large");
|
|
87
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_OPERATION_NAME]).toBe(semConvAttributes.GEN_AI_OPERATION_NAME_VALUE_CHAT);
|
|
88
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_REQUEST_MODEL]).toBe("mistral-large");
|
|
89
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_REQUEST_TEMPERATURE]).toBe(0.7);
|
|
90
|
+
expect(span.attributes[semConvAttributes.ATTR_HTTP_REQUEST_METHOD]).toBe("POST");
|
|
91
|
+
expect(span.attributes[semConvAttributes.ATTR_SERVER_PORT]).toBe(443);
|
|
92
|
+
});
|
|
93
|
+
|
|
94
|
+
test("conversations API with string inputs", () => {
|
|
95
|
+
const span = createMockSpan();
|
|
96
|
+
const body = JSON.stringify({ model: "mistral-large", inputs: "Hello" });
|
|
97
|
+
enrichSpanFromRequest(span, "conversations_start_v1", new URL("https://api.mistral.ai/v1/conversations/start"), "POST", "api.mistral.ai", body);
|
|
98
|
+
|
|
99
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_OPERATION_NAME]).toBe(semConvAttributes.GEN_AI_OPERATION_NAME_VALUE_INVOKE_AGENT);
|
|
100
|
+
const msgs = JSON.parse(span.attributes[semConvAttributes.ATTR_GEN_AI_INPUT_MESSAGES] as string);
|
|
101
|
+
expect(msgs[0].role).toBe("user");
|
|
102
|
+
});
|
|
103
|
+
|
|
104
|
+
test("embeddings operation", () => {
|
|
105
|
+
const span = createMockSpan();
|
|
106
|
+
const body = JSON.stringify({ model: "mistral-embed", input: ["text"] });
|
|
107
|
+
enrichSpanFromRequest(span, "embeddings_v1", new URL("https://api.mistral.ai/v1/embeddings"), "POST", "api.mistral.ai", body);
|
|
108
|
+
|
|
109
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_OPERATION_NAME]).toBe(semConvAttributes.GEN_AI_OPERATION_NAME_VALUE_EMBEDDINGS);
|
|
110
|
+
});
|
|
111
|
+
|
|
112
|
+
test("non-GenAI operation sets only HTTP attributes", () => {
|
|
113
|
+
const span = createMockSpan();
|
|
114
|
+
enrichSpanFromRequest(span, "list_models", new URL("https://api.mistral.ai/v1/models"), "GET", "api.mistral.ai", null);
|
|
115
|
+
|
|
116
|
+
expect(span.attributes[semConvAttributes.ATTR_HTTP_REQUEST_METHOD]).toBe("GET");
|
|
117
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_OPERATION_NAME]).toBeUndefined();
|
|
118
|
+
});
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
describe("enrichSpanFromResponse", () => {
|
|
122
|
+
test("chat completion response", () => {
|
|
123
|
+
const span = createMockSpan();
|
|
124
|
+
const response = {
|
|
125
|
+
id: "cmpl-1",
|
|
126
|
+
model: "mistral-large",
|
|
127
|
+
choices: [{ message: { role: "assistant", content: "Hi!" }, finish_reason: "stop" }],
|
|
128
|
+
usage: { prompt_tokens: 10, completion_tokens: 5, total_tokens: 15 },
|
|
129
|
+
};
|
|
130
|
+
enrichSpanFromResponse(createMockTracer(), span, "chat_completion_v1", response);
|
|
131
|
+
|
|
132
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_RESPONSE_ID]).toBe("cmpl-1");
|
|
133
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_RESPONSE_FINISH_REASONS]).toEqual(["stop"]);
|
|
134
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_USAGE_INPUT_TOKENS]).toBe(10);
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
test("create agent response", () => {
|
|
138
|
+
const span = createMockSpan();
|
|
139
|
+
const response = { id: "agent-1", name: "MyAgent", model: "mistral-large", instructions: "Be helpful" };
|
|
140
|
+
enrichSpanFromResponse(createMockTracer(), span, "agents_create_v1", response);
|
|
141
|
+
|
|
142
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_AGENT_ID]).toBe("agent-1");
|
|
143
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_AGENT_NAME]).toBe("MyAgent");
|
|
144
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_RESPONSE_ID]).toBeUndefined();
|
|
145
|
+
});
|
|
146
|
+
|
|
147
|
+
test("conversation response creates child spans for tool executions", () => {
|
|
148
|
+
const span = createMockSpan();
|
|
149
|
+
const tracer = createMockTracer();
|
|
150
|
+
const response = {
|
|
151
|
+
conversation_id: "conv-1",
|
|
152
|
+
outputs: [
|
|
153
|
+
{ type: "tool.execution", name: "search", created_at: "2024-01-01T00:00:00Z", completed_at: "2024-01-01T00:00:01Z" },
|
|
154
|
+
{ type: "message.output", model: "mistral-large", created_at: "2024-01-01T00:00:01Z", completed_at: "2024-01-01T00:00:02Z" },
|
|
155
|
+
],
|
|
156
|
+
};
|
|
157
|
+
enrichSpanFromResponse(tracer, span, "conversations_start_v1", response);
|
|
158
|
+
|
|
159
|
+
expect(span.attributes[semConvAttributes.ATTR_GEN_AI_CONVERSATION_ID]).toBe("conv-1");
|
|
160
|
+
expect(tracer.spans).toHaveLength(2);
|
|
161
|
+
expect(tracer.spans[0].name).toBe("execute_tool search");
|
|
162
|
+
expect(tracer.spans[1].name).toBe("chat mistral-large");
|
|
163
|
+
});
|
|
164
|
+
|
|
165
|
+
test("OCR response", () => {
|
|
166
|
+
const span = createMockSpan();
|
|
167
|
+
const response = { model: "pixtral", usage_info: { pages_processed: 3, doc_size_bytes: 1000 } };
|
|
168
|
+
enrichSpanFromResponse(createMockTracer(), span, "ocr_v1_ocr_post", response);
|
|
169
|
+
|
|
170
|
+
expect(span.attributes[MistralAIAttributes.MISTRAL_AI_OCR_USAGE_PAGES_PROCESSED]).toBe(3);
|
|
171
|
+
});
|
|
172
|
+
});
|
|
173
|
+
|
|
174
|
+
describe("TracingHook concurrency", () => {
|
|
175
|
+
test("interleaved requests enrich correct spans", async () => {
|
|
176
|
+
const hook = new TracingHook();
|
|
177
|
+
|
|
178
|
+
const createCtx = (operationID: string) => ({
|
|
179
|
+
operationID,
|
|
180
|
+
baseURL: "https://api.mistral.ai",
|
|
181
|
+
oAuth2Scopes: null,
|
|
182
|
+
retryConfig: { strategy: "none" as const },
|
|
183
|
+
resolvedSecurity: null,
|
|
184
|
+
options: {},
|
|
185
|
+
});
|
|
186
|
+
|
|
187
|
+
const createResp = (id: string) =>
|
|
188
|
+
new Response(JSON.stringify({
|
|
189
|
+
id,
|
|
190
|
+
model: "test",
|
|
191
|
+
choices: [{ message: { role: "assistant", content: "Hi" }, finish_reason: "stop" }],
|
|
192
|
+
}), { headers: { "Content-Type": "application/json" } });
|
|
193
|
+
|
|
194
|
+
const createMockSpanWithEndPromise = (name: string) => {
|
|
195
|
+
let resolveEnd!: () => void;
|
|
196
|
+
const endPromise = new Promise<void>(r => { resolveEnd = r; });
|
|
197
|
+
const span = createMockSpan(name);
|
|
198
|
+
span.end = () => { resolveEnd(); };
|
|
199
|
+
return { span, endPromise };
|
|
200
|
+
};
|
|
201
|
+
|
|
202
|
+
const ctxA = createCtx("chat_completion_v1") as TracingContext;
|
|
203
|
+
const ctxB = createCtx("chat_completion_v1") as TracingContext;
|
|
204
|
+
|
|
205
|
+
const { span: mockSpanA, endPromise: endA } = createMockSpanWithEndPromise("spanA");
|
|
206
|
+
const { span: mockSpanB, endPromise: endB } = createMockSpanWithEndPromise("spanB");
|
|
207
|
+
const mockTracer = createMockTracer();
|
|
208
|
+
|
|
209
|
+
ctxA[TRACING_SPAN_KEY] = mockSpanA;
|
|
210
|
+
ctxB[TRACING_SPAN_KEY] = mockSpanB;
|
|
211
|
+
ctxA[TRACING_TRACER_KEY] = mockTracer;
|
|
212
|
+
ctxB[TRACING_TRACER_KEY] = mockTracer;
|
|
213
|
+
|
|
214
|
+
await hook.afterSuccess(ctxA, createResp("resp-A"));
|
|
215
|
+
await hook.afterSuccess(ctxB, createResp("resp-B"));
|
|
216
|
+
|
|
217
|
+
await Promise.all([endA, endB]);
|
|
218
|
+
|
|
219
|
+
expect(mockSpanA.attributes[semConvAttributes.ATTR_GEN_AI_RESPONSE_ID]).toBe("resp-A");
|
|
220
|
+
expect(mockSpanB.attributes[semConvAttributes.ATTR_GEN_AI_RESPONSE_ID]).toBe("resp-B");
|
|
221
|
+
});
|
|
222
|
+
});
|
|
223
|
+
|
|
224
|
+
describe("SDK HTTP span parenting", () => {
|
|
225
|
+
afterEach(() => {
|
|
226
|
+
contextApi.disable();
|
|
227
|
+
registerTracerProvider();
|
|
228
|
+
});
|
|
229
|
+
|
|
230
|
+
test("ends the GenAI span when the HTTP client rejects", async () => {
|
|
231
|
+
const genAiSpan = createMockSpan("chat");
|
|
232
|
+
const tracer = {
|
|
233
|
+
startSpan: () => genAiSpan,
|
|
234
|
+
startActiveSpan: () => undefined as never,
|
|
235
|
+
} as Tracer;
|
|
236
|
+
const tracerProvider: TracerProvider = {
|
|
237
|
+
getTracer: () => tracer,
|
|
238
|
+
};
|
|
239
|
+
registerTracerProvider(tracerProvider);
|
|
240
|
+
|
|
241
|
+
const httpClient = new HTTPClient({
|
|
242
|
+
async fetcher() {
|
|
243
|
+
throw new TypeError("fetch failed");
|
|
244
|
+
},
|
|
245
|
+
});
|
|
246
|
+
const client = new Mistral({
|
|
247
|
+
apiKey: "test-api-key",
|
|
248
|
+
httpClient,
|
|
249
|
+
});
|
|
250
|
+
|
|
251
|
+
await expect(client.chat.complete({
|
|
252
|
+
model: "mistral-small-latest",
|
|
253
|
+
messages: [{ role: "user", content: "hello" }],
|
|
254
|
+
})).rejects.toThrow("Unable to make request");
|
|
255
|
+
|
|
256
|
+
expect(genAiSpan.status).toEqual({
|
|
257
|
+
code: SpanStatusCode.ERROR,
|
|
258
|
+
message: "TypeError: fetch failed",
|
|
259
|
+
});
|
|
260
|
+
expect(genAiSpan.ended).toBe(true);
|
|
261
|
+
});
|
|
262
|
+
|
|
263
|
+
test("runs the HTTP send with the GenAI span active", async () => {
|
|
264
|
+
contextApi.disable();
|
|
265
|
+
contextApi.setGlobalContextManager(new TestContextManager());
|
|
266
|
+
|
|
267
|
+
const genAiSpan = createMockSpan("chat");
|
|
268
|
+
const tracer = {
|
|
269
|
+
startSpan: () => genAiSpan,
|
|
270
|
+
startActiveSpan: () => undefined as never,
|
|
271
|
+
} as Tracer;
|
|
272
|
+
const tracerProvider: TracerProvider = {
|
|
273
|
+
getTracer: () => tracer,
|
|
274
|
+
};
|
|
275
|
+
registerTracerProvider(tracerProvider);
|
|
276
|
+
|
|
277
|
+
let activeSpanDuringFetch: Span | undefined;
|
|
278
|
+
const httpClient = new HTTPClient({
|
|
279
|
+
async fetcher() {
|
|
280
|
+
activeSpanDuringFetch = trace.getSpan(contextApi.active());
|
|
281
|
+
return new Response(JSON.stringify({
|
|
282
|
+
id: "chatcmpl-parenting-test",
|
|
283
|
+
object: "chat.completion",
|
|
284
|
+
created: 1700000000,
|
|
285
|
+
model: "mistral-small-latest",
|
|
286
|
+
choices: [{
|
|
287
|
+
index: 0,
|
|
288
|
+
message: { role: "assistant", content: "ok" },
|
|
289
|
+
finish_reason: "stop",
|
|
290
|
+
}],
|
|
291
|
+
usage: { prompt_tokens: 1, completion_tokens: 1, total_tokens: 2 },
|
|
292
|
+
}), {
|
|
293
|
+
status: 200,
|
|
294
|
+
headers: { "content-type": "application/json" },
|
|
295
|
+
});
|
|
296
|
+
},
|
|
297
|
+
});
|
|
298
|
+
|
|
299
|
+
const client = new Mistral({
|
|
300
|
+
apiKey: "test-api-key",
|
|
301
|
+
httpClient,
|
|
302
|
+
});
|
|
303
|
+
|
|
304
|
+
await client.chat.complete({
|
|
305
|
+
model: "mistral-small-latest",
|
|
306
|
+
messages: [{ role: "user", content: "hello" }],
|
|
307
|
+
});
|
|
308
|
+
|
|
309
|
+
expect(activeSpanDuringFetch).toBe(genAiSpan);
|
|
310
|
+
});
|
|
311
|
+
});
|
|
312
|
+
|
|
313
|
+
describe("TracingHook body and stream handling", () => {
|
|
314
|
+
test("does not read non-GenAI request bodies", async () => {
|
|
315
|
+
const body = new ReadableStream<Uint8Array>({
|
|
316
|
+
pull(controller) {
|
|
317
|
+
controller.enqueue(new Uint8Array([1]));
|
|
318
|
+
controller.close();
|
|
319
|
+
},
|
|
320
|
+
});
|
|
321
|
+
const request = new Request("https://api.mistral.ai/v1/files", {
|
|
322
|
+
method: "POST",
|
|
323
|
+
headers: { "content-type": "multipart/form-data; boundary=test" },
|
|
324
|
+
body,
|
|
325
|
+
duplex: "half",
|
|
326
|
+
} as RequestInit & { duplex: "half" });
|
|
327
|
+
const cloneSpy = vi.spyOn(request, "clone");
|
|
328
|
+
|
|
329
|
+
await getTracedRequestAndSpan(
|
|
330
|
+
createMockTracer(),
|
|
331
|
+
"files_api_routes_upload_file",
|
|
332
|
+
request
|
|
333
|
+
);
|
|
334
|
+
|
|
335
|
+
expect(cloneSpy).not.toHaveBeenCalled();
|
|
336
|
+
});
|
|
337
|
+
|
|
338
|
+
test("does not read non-GenAI response bodies", async () => {
|
|
339
|
+
const body = new ReadableStream<Uint8Array>({
|
|
340
|
+
pull(controller) {
|
|
341
|
+
controller.enqueue(new TextEncoder().encode("download bytes"));
|
|
342
|
+
controller.close();
|
|
343
|
+
},
|
|
344
|
+
});
|
|
345
|
+
const response = new Response(body, {
|
|
346
|
+
headers: { "content-type": "application/octet-stream" },
|
|
347
|
+
});
|
|
348
|
+
const span = createMockSpan();
|
|
349
|
+
const cloneSpy = vi.spyOn(response, "clone");
|
|
350
|
+
|
|
351
|
+
const tracedResponse = await getTracedResponse(
|
|
352
|
+
createMockTracer(),
|
|
353
|
+
span,
|
|
354
|
+
"files_api_routes_download_file",
|
|
355
|
+
response
|
|
356
|
+
);
|
|
357
|
+
|
|
358
|
+
expect(cloneSpy).not.toHaveBeenCalled();
|
|
359
|
+
expect(span.ended).toBe(true);
|
|
360
|
+
await expect(tracedResponse.text()).resolves.toBe("download bytes");
|
|
361
|
+
});
|
|
362
|
+
|
|
363
|
+
test("reads traced SSE responses lazily and cancels upstream", async () => {
|
|
364
|
+
const encoder = new TextEncoder();
|
|
365
|
+
let reads = 0;
|
|
366
|
+
let cancelReason: unknown;
|
|
367
|
+
const body = new ReadableStream<Uint8Array>({
|
|
368
|
+
start(controller) {
|
|
369
|
+
controller.enqueue(encoder.encode(
|
|
370
|
+
'data: {"id":"id-1","model":"m","choices":[{"index":0,"delta":{"content":"hi"},"finish_reason":null}]}\n\n'
|
|
371
|
+
));
|
|
372
|
+
},
|
|
373
|
+
});
|
|
374
|
+
const response = new Response(body, {
|
|
375
|
+
headers: { "content-type": "text/event-stream" },
|
|
376
|
+
});
|
|
377
|
+
const responseBody = response.body!;
|
|
378
|
+
const upstreamReader = responseBody.getReader();
|
|
379
|
+
vi.spyOn(responseBody, "getReader").mockReturnValue({
|
|
380
|
+
read() {
|
|
381
|
+
reads += 1;
|
|
382
|
+
return upstreamReader.read();
|
|
383
|
+
},
|
|
384
|
+
cancel(reason?: unknown) {
|
|
385
|
+
cancelReason = reason;
|
|
386
|
+
return upstreamReader.cancel(reason);
|
|
387
|
+
},
|
|
388
|
+
releaseLock() {
|
|
389
|
+
return upstreamReader.releaseLock();
|
|
390
|
+
},
|
|
391
|
+
closed: upstreamReader.closed,
|
|
392
|
+
} as ReadableStreamDefaultReader<Uint8Array>);
|
|
393
|
+
const span = createMockSpan();
|
|
394
|
+
|
|
395
|
+
const tracedResponse = await getTracedResponse(
|
|
396
|
+
createMockTracer(),
|
|
397
|
+
span,
|
|
398
|
+
"stream_chat",
|
|
399
|
+
response
|
|
400
|
+
);
|
|
401
|
+
|
|
402
|
+
expect(reads).toBe(0);
|
|
403
|
+
|
|
404
|
+
const reader = tracedResponse.body!.getReader();
|
|
405
|
+
const firstChunk = await reader.read();
|
|
406
|
+
expect(firstChunk.done).toBe(false);
|
|
407
|
+
expect(reads).toBe(1);
|
|
408
|
+
|
|
409
|
+
await reader.cancel("stop");
|
|
410
|
+
expect(cancelReason).toBe("stop");
|
|
411
|
+
expect(span.ended).toBe(true);
|
|
412
|
+
});
|
|
413
|
+
});
|
|
414
|
+
|
|
415
|
+
describe("TracingHook error handling", () => {
|
|
416
|
+
test("awaits error response enrichment before returning", async () => {
|
|
417
|
+
const hook = new TracingHook();
|
|
418
|
+
const span = createMockSpan();
|
|
419
|
+
const ctx = {
|
|
420
|
+
operationID: "chat_completion_v1",
|
|
421
|
+
baseURL: "https://api.mistral.ai",
|
|
422
|
+
oAuth2Scopes: null,
|
|
423
|
+
retryConfig: { strategy: "none" as const },
|
|
424
|
+
resolvedSecurity: null,
|
|
425
|
+
options: {},
|
|
426
|
+
[TRACING_SPAN_KEY]: span,
|
|
427
|
+
} as TracingContext;
|
|
428
|
+
const response = new Response(JSON.stringify({
|
|
429
|
+
object: "error",
|
|
430
|
+
message: "Invalid request",
|
|
431
|
+
type: "invalid_request_error",
|
|
432
|
+
code: "bad_request",
|
|
433
|
+
}), {
|
|
434
|
+
status: 400,
|
|
435
|
+
headers: { "Content-Type": "application/json" },
|
|
436
|
+
});
|
|
437
|
+
|
|
438
|
+
await hook.afterError(ctx, response, null);
|
|
439
|
+
|
|
440
|
+
expect(span.status).toEqual({ code: SpanStatusCode.ERROR, message: "Invalid request" });
|
|
441
|
+
expect(span.events).toContainEqual({
|
|
442
|
+
name: "exception",
|
|
443
|
+
attributes: {
|
|
444
|
+
"exception.type": "invalid_request_error",
|
|
445
|
+
"exception.message": "Invalid request",
|
|
446
|
+
},
|
|
447
|
+
});
|
|
448
|
+
expect(span.attributes[semConvAttributes.ATTR_HTTP_RESPONSE_STATUS_CODE]).toBe(400);
|
|
449
|
+
expect(span.attributes[semConvAttributes.ATTR_ERROR_TYPE]).toBe("invalid_request_error");
|
|
450
|
+
expect(span.attributes[MistralAIAttributes.MISTRAL_AI_ERROR_CODE]).toBe("bad_request");
|
|
451
|
+
expect(span.ended).toBe(true);
|
|
452
|
+
});
|
|
453
|
+
});
|
|
@@ -0,0 +1,94 @@
|
|
|
1
|
+
/**
|
|
2
|
+
* Tests for streaming SSE parsing and chunk accumulation.
|
|
3
|
+
*/
|
|
4
|
+
|
|
5
|
+
import {
|
|
6
|
+
parseSseChunks,
|
|
7
|
+
accumulateChunksToResponseDict,
|
|
8
|
+
} from "../../../src/extra/observability/streaming.js";
|
|
9
|
+
|
|
10
|
+
function chunk(opts: {
|
|
11
|
+
content?: string;
|
|
12
|
+
role?: string;
|
|
13
|
+
toolCalls?: Array<{ id?: string; index?: number; function: { name?: string; arguments?: string } }>;
|
|
14
|
+
finishReason?: string | null;
|
|
15
|
+
usage?: { prompt_tokens?: number; completion_tokens?: number; total_tokens?: number };
|
|
16
|
+
}): Record<string, unknown> {
|
|
17
|
+
const delta: Record<string, unknown> = {};
|
|
18
|
+
if (opts.role) delta.role = opts.role;
|
|
19
|
+
if (opts.content !== undefined) delta.content = opts.content;
|
|
20
|
+
if (opts.toolCalls) {
|
|
21
|
+
delta.tool_calls = opts.toolCalls.map((tc) => ({
|
|
22
|
+
id: tc.id ?? "null",
|
|
23
|
+
index: tc.index ?? 0,
|
|
24
|
+
function: { name: tc.function.name ?? "", arguments: tc.function.arguments ?? "" },
|
|
25
|
+
}));
|
|
26
|
+
}
|
|
27
|
+
return {
|
|
28
|
+
id: "id-1",
|
|
29
|
+
model: "m",
|
|
30
|
+
choices: [{ index: 0, delta, finish_reason: opts.finishReason ?? null }],
|
|
31
|
+
usage: opts.usage,
|
|
32
|
+
};
|
|
33
|
+
}
|
|
34
|
+
|
|
35
|
+
function toSse(chunks: Record<string, unknown>[]): string {
|
|
36
|
+
return chunks.map((c) => `data: ${JSON.stringify(c)}`).join("\n\n") + "\n\ndata: [DONE]\n\n";
|
|
37
|
+
}
|
|
38
|
+
|
|
39
|
+
describe("parseSseChunks", () => {
|
|
40
|
+
test("parses valid chunks and skips [DONE]", () => {
|
|
41
|
+
const result = parseSseChunks(toSse([chunk({ content: "hello" }), chunk({ content: " world" })]));
|
|
42
|
+
expect(result.length).toBe(2);
|
|
43
|
+
expect(result[0].choices[0].delta.content).toBe("hello");
|
|
44
|
+
});
|
|
45
|
+
|
|
46
|
+
test("normalizes nullable optional fields without dropping first content chunk", () => {
|
|
47
|
+
const firstChunk = chunk({ role: "assistant", content: "Bonjour" });
|
|
48
|
+
firstChunk["usage"] = null;
|
|
49
|
+
firstChunk["object"] = null;
|
|
50
|
+
const choice = (firstChunk["choices"] as Array<Record<string, unknown>>)[0]!;
|
|
51
|
+
delete choice["finish_reason"];
|
|
52
|
+
|
|
53
|
+
const result = parseSseChunks(toSse([firstChunk, chunk({ content: " monde" })]));
|
|
54
|
+
|
|
55
|
+
expect(result.map((c) => c.choices[0].delta.content)).toEqual(["Bonjour", " monde"]);
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
test("skips invalid json", () => {
|
|
59
|
+
expect(parseSseChunks("data: {invalid}\n\ndata: [DONE]\n\n")).toEqual([]);
|
|
60
|
+
});
|
|
61
|
+
|
|
62
|
+
test("empty input", () => {
|
|
63
|
+
expect(parseSseChunks("")).toEqual([]);
|
|
64
|
+
});
|
|
65
|
+
});
|
|
66
|
+
|
|
67
|
+
describe("accumulateChunksToResponseDict", () => {
|
|
68
|
+
test("concatenates content across chunks", () => {
|
|
69
|
+
const chunks = parseSseChunks(toSse([
|
|
70
|
+
chunk({ role: "assistant", content: "Hello" }),
|
|
71
|
+
chunk({ content: " world", finishReason: "stop", usage: { prompt_tokens: 10, completion_tokens: 5, total_tokens: 15 } }),
|
|
72
|
+
]));
|
|
73
|
+
const result = accumulateChunksToResponseDict(chunks);
|
|
74
|
+
expect(result.choices).toEqual([{ message: { role: "assistant", content: "Hello world" }, finish_reason: "stop" }]);
|
|
75
|
+
expect(result.usage).toEqual({ prompt_tokens: 10, completion_tokens: 5, total_tokens: 15 });
|
|
76
|
+
});
|
|
77
|
+
|
|
78
|
+
test("accumulates fragmented tool call arguments", () => {
|
|
79
|
+
const chunks = parseSseChunks(toSse([
|
|
80
|
+
chunk({ role: "assistant", content: "", toolCalls: [{ id: "tc-1", index: 0, function: { name: "f", arguments: '{"a"' } }] }),
|
|
81
|
+
chunk({ toolCalls: [{ index: 0, function: { arguments: ': 1}' } }], finishReason: "tool_calls" }),
|
|
82
|
+
]));
|
|
83
|
+
const result = accumulateChunksToResponseDict(chunks) as {
|
|
84
|
+
choices: Array<{ message: { tool_calls?: Array<{ id: string; function: { name: string; arguments: string } }> } }>;
|
|
85
|
+
};
|
|
86
|
+
expect(result.choices[0].message.tool_calls).toEqual([
|
|
87
|
+
{ id: "tc-1", function: { name: "f", arguments: '{"a": 1}' } },
|
|
88
|
+
]);
|
|
89
|
+
});
|
|
90
|
+
|
|
91
|
+
test("handles empty chunks", () => {
|
|
92
|
+
expect(accumulateChunksToResponseDict([])).toEqual({ id: undefined, model: undefined, choices: [] });
|
|
93
|
+
});
|
|
94
|
+
});
|
|
@@ -1,23 +0,0 @@
|
|
|
1
|
-
import * as z from "zod/v4";
|
|
2
|
-
import { Result as SafeParseResult } from "../../types/fp.js";
|
|
3
|
-
import { SDKValidationError } from "../errors/sdkvalidationerror.js";
|
|
4
|
-
export type VoiceAppearance = {
|
|
5
|
-
skinColor?: string | null | undefined;
|
|
6
|
-
hairColor?: string | null | undefined;
|
|
7
|
-
backgroundColor?: string | null | undefined;
|
|
8
|
-
avatarId?: string | null | undefined;
|
|
9
|
-
};
|
|
10
|
-
/** @internal */
|
|
11
|
-
export declare const VoiceAppearance$inboundSchema: z.ZodType<VoiceAppearance, unknown>;
|
|
12
|
-
/** @internal */
|
|
13
|
-
export type VoiceAppearance$Outbound = {
|
|
14
|
-
skin_color?: string | null | undefined;
|
|
15
|
-
hair_color?: string | null | undefined;
|
|
16
|
-
background_color?: string | null | undefined;
|
|
17
|
-
avatar_id?: string | null | undefined;
|
|
18
|
-
};
|
|
19
|
-
/** @internal */
|
|
20
|
-
export declare const VoiceAppearance$outboundSchema: z.ZodType<VoiceAppearance$Outbound, VoiceAppearance>;
|
|
21
|
-
export declare function voiceAppearanceToJSON(voiceAppearance: VoiceAppearance): string;
|
|
22
|
-
export declare function voiceAppearanceFromJSON(jsonString: string): SafeParseResult<VoiceAppearance, SDKValidationError>;
|
|
23
|
-
//# sourceMappingURL=voiceappearance.d.ts.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"voiceappearance.d.ts","sourceRoot":"","sources":["../../../src/models/components/voiceappearance.ts"],"names":[],"mappings":"AAKA,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAC;AAG5B,OAAO,EAAE,MAAM,IAAI,eAAe,EAAE,MAAM,mBAAmB,CAAC;AAC9D,OAAO,EAAE,kBAAkB,EAAE,MAAM,iCAAiC,CAAC;AAErE,MAAM,MAAM,eAAe,GAAG;IAC5B,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IACtC,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IACtC,eAAe,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IAC5C,QAAQ,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;CACtC,CAAC;AAEF,gBAAgB;AAChB,eAAO,MAAM,6BAA6B,EAAE,CAAC,CAAC,OAAO,CACnD,eAAe,EACf,OAAO,CAaP,CAAC;AACH,gBAAgB;AAChB,MAAM,MAAM,wBAAwB,GAAG;IACrC,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IACvC,UAAU,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IACvC,gBAAgB,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;IAC7C,SAAS,CAAC,EAAE,MAAM,GAAG,IAAI,GAAG,SAAS,CAAC;CACvC,CAAC;AAEF,gBAAgB;AAChB,eAAO,MAAM,8BAA8B,EAAE,CAAC,CAAC,OAAO,CACpD,wBAAwB,EACxB,eAAe,CAaf,CAAC;AAEH,wBAAgB,qBAAqB,CACnC,eAAe,EAAE,eAAe,GAC/B,MAAM,CAER;AACD,wBAAgB,uBAAuB,CACrC,UAAU,EAAE,MAAM,GACjB,eAAe,CAAC,eAAe,EAAE,kBAAkB,CAAC,CAMtD"}
|
|
@@ -1,42 +0,0 @@
|
|
|
1
|
-
/*
|
|
2
|
-
* Code generated by Speakeasy (https://speakeasy.com). DO NOT EDIT.
|
|
3
|
-
* @generated-id: ce200ca4f463
|
|
4
|
-
*/
|
|
5
|
-
import * as z from "zod/v4";
|
|
6
|
-
import { remap as remap$ } from "../../lib/primitives.js";
|
|
7
|
-
import { safeParse } from "../../lib/schemas.js";
|
|
8
|
-
/** @internal */
|
|
9
|
-
export const VoiceAppearance$inboundSchema = z.object({
|
|
10
|
-
skin_color: z.nullable(z.string()).optional(),
|
|
11
|
-
hair_color: z.nullable(z.string()).optional(),
|
|
12
|
-
background_color: z.nullable(z.string()).optional(),
|
|
13
|
-
avatar_id: z.nullable(z.string()).optional(),
|
|
14
|
-
}).transform((v) => {
|
|
15
|
-
return remap$(v, {
|
|
16
|
-
"skin_color": "skinColor",
|
|
17
|
-
"hair_color": "hairColor",
|
|
18
|
-
"background_color": "backgroundColor",
|
|
19
|
-
"avatar_id": "avatarId",
|
|
20
|
-
});
|
|
21
|
-
});
|
|
22
|
-
/** @internal */
|
|
23
|
-
export const VoiceAppearance$outboundSchema = z.object({
|
|
24
|
-
skinColor: z.nullable(z.string()).optional(),
|
|
25
|
-
hairColor: z.nullable(z.string()).optional(),
|
|
26
|
-
backgroundColor: z.nullable(z.string()).optional(),
|
|
27
|
-
avatarId: z.nullable(z.string()).optional(),
|
|
28
|
-
}).transform((v) => {
|
|
29
|
-
return remap$(v, {
|
|
30
|
-
skinColor: "skin_color",
|
|
31
|
-
hairColor: "hair_color",
|
|
32
|
-
backgroundColor: "background_color",
|
|
33
|
-
avatarId: "avatar_id",
|
|
34
|
-
});
|
|
35
|
-
});
|
|
36
|
-
export function voiceAppearanceToJSON(voiceAppearance) {
|
|
37
|
-
return JSON.stringify(VoiceAppearance$outboundSchema.parse(voiceAppearance));
|
|
38
|
-
}
|
|
39
|
-
export function voiceAppearanceFromJSON(jsonString) {
|
|
40
|
-
return safeParse(jsonString, (x) => VoiceAppearance$inboundSchema.parse(JSON.parse(x)), `Failed to parse 'VoiceAppearance' from JSON`);
|
|
41
|
-
}
|
|
42
|
-
//# sourceMappingURL=voiceappearance.js.map
|
|
@@ -1 +0,0 @@
|
|
|
1
|
-
{"version":3,"file":"voiceappearance.js","sourceRoot":"","sources":["../../../src/models/components/voiceappearance.ts"],"names":[],"mappings":"AAAA;;;GAGG;AAEH,OAAO,KAAK,CAAC,MAAM,QAAQ,CAAC;AAC5B,OAAO,EAAE,KAAK,IAAI,MAAM,EAAE,MAAM,yBAAyB,CAAC;AAC1D,OAAO,EAAE,SAAS,EAAE,MAAM,sBAAsB,CAAC;AAWjD,gBAAgB;AAChB,MAAM,CAAC,MAAM,6BAA6B,GAGtC,CAAC,CAAC,MAAM,CAAC;IACX,UAAU,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE;IAC7C,UAAU,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE;IAC7C,gBAAgB,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE;IACnD,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE;CAC7C,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;IAClB,OAAO,MAAM,CAAC,CAAC,EAAE;QACf,YAAY,EAAE,WAAW;QACzB,YAAY,EAAE,WAAW;QACzB,kBAAkB,EAAE,iBAAiB;QACrC,WAAW,EAAE,UAAU;KACxB,CAAC,CAAC;AAAA,CACJ,CAAC,CAAC;AASH,gBAAgB;AAChB,MAAM,CAAC,MAAM,8BAA8B,GAGvC,CAAC,CAAC,MAAM,CAAC;IACX,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE;IAC5C,SAAS,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE;IAC5C,eAAe,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE;IAClD,QAAQ,EAAE,CAAC,CAAC,QAAQ,CAAC,CAAC,CAAC,MAAM,EAAE,CAAC,CAAC,QAAQ,EAAE;CAC5C,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,EAAE,EAAE,CAAC;IAClB,OAAO,MAAM,CAAC,CAAC,EAAE;QACf,SAAS,EAAE,YAAY;QACvB,SAAS,EAAE,YAAY;QACvB,eAAe,EAAE,kBAAkB;QACnC,QAAQ,EAAE,WAAW;KACtB,CAAC,CAAC;AAAA,CACJ,CAAC,CAAC;AAEH,MAAM,UAAU,qBAAqB,CACnC,eAAgC,EACxB;IACR,OAAO,IAAI,CAAC,SAAS,CAAC,8BAA8B,CAAC,KAAK,CAAC,eAAe,CAAC,CAAC,CAAC;AAAA,CAC9E;AACD,MAAM,UAAU,uBAAuB,CACrC,UAAkB,EACoC;IACtD,OAAO,SAAS,CACd,UAAU,EACV,CAAC,CAAC,EAAE,EAAE,CAAC,6BAA6B,CAAC,KAAK,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,EACzD,6CAA6C,CAC9C,CAAC;AAAA,CACH"}
|