Skip to content

Commit

Permalink
TF-2819 calendar event maybe repo implementation
Browse files Browse the repository at this point in the history
  • Loading branch information
tddang-linagora committed Apr 23, 2024
1 parent cbf420b commit 43ae55d
Show file tree
Hide file tree
Showing 2 changed files with 38 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import 'package:jmap_dart_client/jmap/account_id.dart';
import 'package:jmap_dart_client/jmap/core/id.dart';
import 'package:jmap_dart_client/jmap/mail/calendar/calendar_event.dart';
import 'package:jmap_dart_client/jmap/mail/calendar/reply/calendar_event_accept_response.dart';
import 'package:jmap_dart_client/jmap/mail/calendar/reply/calendar_event_maybe_response.dart';
import 'package:tmail_ui_user/features/email/data/datasource/calendar_event_datasource.dart';
import 'package:tmail_ui_user/features/email/domain/model/event_action.dart';
import 'package:tmail_ui_user/features/email/domain/repository/calendar_event_repository.dart';
Expand All @@ -28,4 +29,9 @@ class CalendarEventRepositoryImpl extends CalendarEventRepository {
Future<CalendarEventAcceptResponse> accept(AccountId accountId, Set<Id> blobIds) {
return _calendarEventDataSource[DataSourceType.network]!.accept(accountId, blobIds);
}

@override
Future<CalendarEventMaybeResponse> maybeEventInvitation(AccountId accountId, Set<Id> blobIds) {
return _calendarEventDataSource[DataSourceType.network]!.maybeEventInvitation(accountId, blobIds);
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import 'package:jmap_dart_client/jmap/account_id.dart';
import 'package:jmap_dart_client/jmap/core/id.dart';
import 'package:jmap_dart_client/jmap/mail/calendar/properties/event_id.dart';
import 'package:jmap_dart_client/jmap/mail/calendar/reply/calendar_event_accept_response.dart';
import 'package:jmap_dart_client/jmap/mail/calendar/reply/calendar_event_maybe_response.dart';
import 'package:mockito/annotations.dart';
import 'package:mockito/mockito.dart';
import 'package:tmail_ui_user/features/email/data/datasource/calendar_event_datasource.dart';
Expand All @@ -21,7 +22,7 @@ void main() {
final accountId = AccountId(Id('123'));
final blobId = Id('blobId');

group('calendar event repository', () {
group('calendar event accept repository', () {
final calendarEventAcceptResponseresponse = CalendarEventAcceptResponse(
accountId,
null,
Expand Down Expand Up @@ -50,4 +51,34 @@ void main() {
throwsA(isA<NotAcceptableCalendarEventException>()));
});
});

group('calendar event maybe repository', () {
final calendarEventMaybeResponse = CalendarEventMaybeResponse(
accountId,
null,
maybe: [EventId(blobId.value)]);

test('should return response when data source return response', () async {
// arrange
when(calendarEventNetworkDataSource.maybeEventInvitation(any, any))
.thenAnswer((_) async => calendarEventMaybeResponse);

// act
final response = await calendarEventRepository.maybeEventInvitation(accountId, {blobId});

// assert
expect(response, calendarEventMaybeResponse);
});

test('should throw exception when data source throw exception', () {
// arrange
when(calendarEventNetworkDataSource.maybeEventInvitation(any, any))
.thenThrow(NotMaybeableCalendarEventException());

// assert
expect(
() => calendarEventRepository.maybeEventInvitation(accountId, {blobId}),
throwsA(isA<NotMaybeableCalendarEventException>()));
});
});
}

0 comments on commit 43ae55d

Please sign in to comment.