File tree Expand file tree Collapse file tree 2 files changed +63
-1
lines changed Expand file tree Collapse file tree 2 files changed +63
-1
lines changed Original file line number Diff line number Diff line change @@ -1203,6 +1203,68 @@ describe("tool()", () => {
1203
1203
} ) ,
1204
1204
) . rejects . toThrow ( / T o o l t e s t h a s a n o u t p u t s c h e m a b u t n o s t r u c t u r e d c o n t e n t w a s p r o v i d e d / ) ;
1205
1205
} ) ;
1206
+ /***
1207
+ * Test: Tool with Output Schema Must Provide Structured Content
1208
+ */
1209
+ test ( "should skip outputSchema validation when isError is true" , async ( ) => {
1210
+ const mcpServer = new McpServer ( {
1211
+ name : "test server" ,
1212
+ version : "1.0" ,
1213
+ } ) ;
1214
+
1215
+ const client = new Client ( {
1216
+ name : "test client" ,
1217
+ version : "1.0" ,
1218
+ } ) ;
1219
+
1220
+ mcpServer . registerTool (
1221
+ "test" ,
1222
+ {
1223
+ description : "Test tool with output schema but missing structured content" ,
1224
+ inputSchema : {
1225
+ input : z . string ( ) ,
1226
+ } ,
1227
+ outputSchema : {
1228
+ processedInput : z . string ( ) ,
1229
+ resultType : z . string ( ) ,
1230
+ } ,
1231
+ } ,
1232
+ async ( { input } ) => ( {
1233
+ content : [
1234
+ {
1235
+ type : "text" ,
1236
+ text : `Processed: ${ input } ` ,
1237
+ } ,
1238
+ ] ,
1239
+ isError : true ,
1240
+ } )
1241
+ ) ;
1242
+
1243
+ const [ clientTransport , serverTransport ] =
1244
+ InMemoryTransport . createLinkedPair ( ) ;
1245
+
1246
+ await Promise . all ( [
1247
+ client . connect ( clientTransport ) ,
1248
+ mcpServer . server . connect ( serverTransport ) ,
1249
+ ] ) ;
1250
+
1251
+ await expect (
1252
+ client . callTool ( {
1253
+ name : "test" ,
1254
+ arguments : {
1255
+ input : "hello" ,
1256
+ } ,
1257
+ } ) ,
1258
+ ) . resolves . toStrictEqual ( {
1259
+ content : [
1260
+ {
1261
+ type : "text" ,
1262
+ text : `Processed: hello` ,
1263
+ } ,
1264
+ ] ,
1265
+ isError : true ,
1266
+ } ) ;
1267
+ } ) ;
1206
1268
1207
1269
/***
1208
1270
* Test: Schema Validation Failure for Invalid Structured Content
Original file line number Diff line number Diff line change @@ -200,7 +200,7 @@ export class McpServer {
200
200
}
201
201
}
202
202
203
- if ( tool . outputSchema ) {
203
+ if ( tool . outputSchema && ! result . isError ) {
204
204
if ( ! result . structuredContent ) {
205
205
throw new McpError (
206
206
ErrorCode . InvalidParams ,
You can’t perform that action at this time.
0 commit comments