|
5 | 5 | import 'dart:async';
|
6 | 6 | import 'dart:io';
|
7 | 7 |
|
| 8 | +import 'package:dart_mcp/server.dart'; |
| 9 | +import 'package:dart_mcp_server/src/server.dart'; |
8 | 10 | import 'package:test/test.dart';
|
9 | 11 | import 'package:test_descriptor/test_descriptor.dart' as d;
|
| 12 | +import 'package:unified_analytics/testing.dart'; |
| 13 | +import 'package:unified_analytics/unified_analytics.dart'; |
10 | 14 |
|
11 | 15 | import 'test_harness.dart';
|
12 | 16 |
|
13 | 17 | void main() {
|
| 18 | + group('analytics', () { |
| 19 | + late TestHarness testHarness; |
| 20 | + late DartMCPServer server; |
| 21 | + late FakeAnalytics analytics; |
| 22 | + |
| 23 | + setUp(() async { |
| 24 | + testHarness = await TestHarness.start(inProcess: true); |
| 25 | + server = testHarness.serverConnectionPair.server!; |
| 26 | + analytics = server.analytics as FakeAnalytics; |
| 27 | + }); |
| 28 | + |
| 29 | + test('sends analytics for successful tool calls', () async { |
| 30 | + server.registerTool( |
| 31 | + Tool(name: 'hello', inputSchema: Schema.object()), |
| 32 | + (_) => CallToolResult(content: [Content.text(text: 'world')]), |
| 33 | + ); |
| 34 | + final result = await testHarness.callToolWithRetry( |
| 35 | + CallToolRequest(name: 'hello'), |
| 36 | + ); |
| 37 | + expect((result.content.single as TextContent).text, 'world'); |
| 38 | + expect( |
| 39 | + analytics.sentEvents.single, |
| 40 | + isA<Event>() |
| 41 | + .having((e) => e.eventName, 'eventName', DashEvent.dartMCPEvent) |
| 42 | + .having( |
| 43 | + (e) => e.eventData, |
| 44 | + 'eventData', |
| 45 | + equals({ |
| 46 | + 'client': server.clientInfo.name, |
| 47 | + 'clientVersion': server.clientInfo.version, |
| 48 | + 'serverVersion': server.implementation.version, |
| 49 | + 'type': 'callTool', |
| 50 | + 'tool': 'hello', |
| 51 | + 'success': true, |
| 52 | + 'elapsedMilliseconds': isA<int>(), |
| 53 | + }), |
| 54 | + ), |
| 55 | + ); |
| 56 | + }); |
| 57 | + |
| 58 | + test('sends analytics for failed tool calls', () async { |
| 59 | + server.registerTool( |
| 60 | + Tool(name: 'hello', inputSchema: Schema.object()), |
| 61 | + (_) => CallToolResult(isError: true, content: []), |
| 62 | + ); |
| 63 | + final result = await testHarness.mcpServerConnection.callTool( |
| 64 | + CallToolRequest(name: 'hello'), |
| 65 | + ); |
| 66 | + expect(result.isError, true); |
| 67 | + expect( |
| 68 | + analytics.sentEvents.single, |
| 69 | + isA<Event>() |
| 70 | + .having((e) => e.eventName, 'eventName', DashEvent.dartMCPEvent) |
| 71 | + .having( |
| 72 | + (e) => e.eventData, |
| 73 | + 'eventData', |
| 74 | + equals({ |
| 75 | + 'client': server.clientInfo.name, |
| 76 | + 'clientVersion': server.clientInfo.version, |
| 77 | + 'serverVersion': server.implementation.version, |
| 78 | + 'type': 'callTool', |
| 79 | + 'tool': 'hello', |
| 80 | + 'success': false, |
| 81 | + 'elapsedMilliseconds': isA<int>(), |
| 82 | + }), |
| 83 | + ), |
| 84 | + ); |
| 85 | + }); |
| 86 | + |
| 87 | + test('Changelog version matches dart server version', () { |
| 88 | + final changelogFile = File('CHANGELOG.md'); |
| 89 | + expect( |
| 90 | + changelogFile.readAsLinesSync().first.split(' ')[1], |
| 91 | + testHarness.serverConnectionPair.server!.implementation.version, |
| 92 | + ); |
| 93 | + }); |
| 94 | + }); |
| 95 | + |
14 | 96 | group('--log-file', () {
|
15 | 97 | late d.FileDescriptor logDescriptor;
|
16 | 98 | late TestHarness testHarness;
|
@@ -41,7 +123,7 @@ void main() {
|
41 | 123 |
|
42 | 124 | // Wait for the process to release the file.
|
43 | 125 | await doWithRetries(() => File(logDescriptor.io.path).delete());
|
44 |
| - }); |
| 126 | + }, skip: 'https://github.com/dart-lang/ai/issues/181'); |
45 | 127 | });
|
46 | 128 | }
|
47 | 129 |
|
|
0 commit comments