diff --git a/lib/jmap/mail/calendar/reply/calendar_event_maybe_method.dart b/lib/jmap/mail/calendar/reply/calendar_event_maybe_method.dart new file mode 100644 index 0000000..b6ae1c7 --- /dev/null +++ b/lib/jmap/mail/calendar/reply/calendar_event_maybe_method.dart @@ -0,0 +1,28 @@ +import 'package:jmap_dart_client/http/converter/account_id_converter.dart'; +import 'package:jmap_dart_client/http/converter/id_converter.dart'; +import 'package:jmap_dart_client/jmap/core/capability/capability_identifier.dart'; +import 'package:jmap_dart_client/jmap/core/method/request/calendar_event_reply_method.dart'; +import 'package:jmap_dart_client/jmap/core/request/request_invocation.dart'; +import 'package:json_annotation/json_annotation.dart'; + +part 'calendar_event_maybe_method.g.dart'; + +@JsonSerializable(converters: [ + AccountIdConverter(), + IdConverter(), +]) +class CalendarEventMaybeMethod extends CalendarEventReplyMethod { + CalendarEventMaybeMethod(super.accountId, {required super.blobIds}); + + @override + MethodName get methodName => MethodName('CalendarEvent/maybe'); + + @override + Set get requiredCapabilities => { + CapabilityIdentifier.jmapCore, + CapabilityIdentifier.jamesCalendarEvent + }; + + @override + Map toJson() => _$CalendarEventMaybeMethodToJson(this); +} \ No newline at end of file diff --git a/lib/jmap/mail/calendar/reply/calendar_event_maybe_method.g.dart b/lib/jmap/mail/calendar/reply/calendar_event_maybe_method.g.dart new file mode 100644 index 0000000..f1080de --- /dev/null +++ b/lib/jmap/mail/calendar/reply/calendar_event_maybe_method.g.dart @@ -0,0 +1,33 @@ +// GENERATED CODE - DO NOT MODIFY BY HAND + +part of 'calendar_event_maybe_method.dart'; + +// ************************************************************************** +// JsonSerializableGenerator +// ************************************************************************** + +CalendarEventMaybeMethod _$CalendarEventMaybeMethodFromJson( + Map json) => + CalendarEventMaybeMethod( + const AccountIdConverter().fromJson(json['accountId'] as String), + blobIds: (json['blobIds'] as List) + .map((e) => const IdConverter().fromJson(e as String)) + .toList(), + )..language = json['language'] as String?; + +Map _$CalendarEventMaybeMethodToJson( + CalendarEventMaybeMethod instance) { + final val = { + 'accountId': const AccountIdConverter().toJson(instance.accountId), + }; + + void writeNotNull(String key, dynamic value) { + if (value != null) { + val[key] = value; + } + } + + writeNotNull('language', instance.language); + val['blobIds'] = instance.blobIds.map(const IdConverter().toJson).toList(); + return val; +} diff --git a/lib/jmap/mail/calendar/reply/calendar_event_maybe_response.dart b/lib/jmap/mail/calendar/reply/calendar_event_maybe_response.dart new file mode 100644 index 0000000..bcdeef2 --- /dev/null +++ b/lib/jmap/mail/calendar/reply/calendar_event_maybe_response.dart @@ -0,0 +1,29 @@ +import 'package:jmap_dart_client/jmap/core/id.dart'; +import 'package:jmap_dart_client/jmap/core/method/response/calendar_event_reply_response.dart'; +import 'package:jmap_dart_client/jmap/mail/calendar/properties/event_id.dart'; +import 'package:jmap_dart_client/util/json_parsers.dart'; + +class CalendarEventMaybeResponse extends CalendarEventReplyResponse { + CalendarEventMaybeResponse( + super.accountId, + super.notFound, + { + this.maybe, + this.notMaybe + }); + + final List? maybe; + final List? notMaybe; + + static CalendarEventMaybeResponse deserialize(Map json) { + return CalendarEventMaybeResponse( + JsonParsers().parsingAccountId(json), + JsonParsers().parsingListId(json, 'notFound'), + maybe: JsonParsers().parsingListEventId(json, 'maybe'), + notMaybe: JsonParsers().parsingListId(json, 'notMaybe'), + ); + } + + @override + List get props => [...super.props, maybe, notMaybe]; +} \ No newline at end of file diff --git a/test/jmap/mail/calendar/reply/calendar_event_maybe_method_test.dart b/test/jmap/mail/calendar/reply/calendar_event_maybe_method_test.dart new file mode 100644 index 0000000..65648ed --- /dev/null +++ b/test/jmap/mail/calendar/reply/calendar_event_maybe_method_test.dart @@ -0,0 +1,91 @@ +import 'package:dio/dio.dart'; +import 'package:flutter_test/flutter_test.dart'; +import 'package:http_mock_adapter/http_mock_adapter.dart'; +import 'package:jmap_dart_client/http/http_client.dart'; +import 'package:jmap_dart_client/jmap/account_id.dart'; +import 'package:jmap_dart_client/jmap/core/id.dart'; +import 'package:jmap_dart_client/jmap/core/method/request/calendar_event_reply_method.dart'; +import 'package:jmap_dart_client/jmap/core/method/response/calendar_event_reply_response.dart'; +import 'package:jmap_dart_client/jmap/core/request/request_invocation.dart'; +import 'package:jmap_dart_client/jmap/jmap_request.dart'; +import 'package:jmap_dart_client/jmap/mail/calendar/properties/event_id.dart'; +import 'package:jmap_dart_client/jmap/mail/calendar/reply/calendar_event_maybe_method.dart'; +import 'package:jmap_dart_client/jmap/mail/calendar/reply/calendar_event_maybe_response.dart'; + +void main() { + final baseOption = BaseOptions(method: 'POST'); + final dio = Dio(baseOption)..options.baseUrl = 'http://domain.com/jmap'; + final dioAdapter = DioAdapter(dio: dio); + final dioAdapterHeaders = {"accept": "application/json;jmapVersion=rfc-8621"}; + final httpClient = HttpClient(dio); + final processingInvocation = ProcessingInvocation(); + final requestBuilder = JmapRequestBuilder(httpClient, processingInvocation); + final accountId = AccountId(Id('123abc')); + final successBlobId = Id('abc123'); + final failureBlobId = Id('def456'); + final notFoundBlobId = Id('ghi789'); + final blobIds = [successBlobId, failureBlobId, notFoundBlobId]; + final methodCallId = MethodCallId('c0'); + + Map constructData(CalendarEventReplyMethod method) => { + "using": method.requiredCapabilities + .map((capability) => capability.value.toString()) + .toList(), + "methodCalls": [ + [ + method.methodName.value, + { + "accountId": accountId.id.value, + "blobIds": blobIds.map((id) => id.value).toList(), + }, + methodCallId.value + ] + ] + }; + + Map constructResponse(CalendarEventReplyMethod method) => { + "sessionState": "abcdefghij", + "methodResponses": [[ + method.methodName.value, + { + "accountId": accountId.id.value, + "maybe": [successBlobId.value], + "notMaybe": [failureBlobId.value], + "notFound": [notFoundBlobId.value], + }, + methodCallId.value + ]] + }; + + group('calendar event maybe method', () { + final method = CalendarEventMaybeMethod(accountId, blobIds: blobIds); + + test('should succeed with success blob data, ' + 'and fail with failure blob data ' + 'and not found with not found blob data', () async { + // arrange + final invocation = requestBuilder.invocation(method, methodCallId: methodCallId); + dioAdapter.onPost( + '', + (server) => server.reply(200, constructResponse(method)), + data: constructData(method), + headers: dioAdapterHeaders, + ); + + // act + final response = (await (requestBuilder..usings(method.requiredCapabilities)) + .build() + .execute()) + .parse( + invocation.methodCallId, + CalendarEventMaybeResponse.deserialize); + + // assert + expect( + (response as CalendarEventMaybeResponse?)?.maybe, + equals([EventId(successBlobId.value)])); + expect(response?.notMaybe, equals([failureBlobId])); + expect(response?.notFound, equals([notFoundBlobId])); + }); + }); +} \ No newline at end of file