feat: BLoC tests complets + sécurité production + freerasp 7.5.1 migration

## Tests BLoC (Task P2.4 Mobile)
- 25 nouveaux fichiers *_bloc_test.dart + mocks générés (build_runner)
- Features couvertes : authentication, admin_users, adhesions, backup,
  communication/messaging, contributions, dashboard, finance (approval/budget),
  events, explore/network, feed, logs_monitoring, notifications, onboarding,
  organizations (switcher/types/CRUD), profile, reports, settings, solidarity
- ~380 tests, > 80% coverage BLoCs

## Sécurité Production (Task P2.2)
- lib/core/security/app_integrity_service.dart (freerasp 7.5.1)
- Migration API breaking changes freerasp 7.5.1 :
  - onRootDetected → onPrivilegedAccess
  - onDebuggerDetected → onDebug
  - onSignatureDetected → onAppIntegrity
  - onHookDetected → onHooks
  - onEmulatorDetected → onSimulator
  - onUntrustedInstallationSourceDetected → onUnofficialStore
  - onDeviceBindingDetected → onDeviceBinding
  - onObfuscationIssuesDetected → onObfuscationIssues
  - Talsec.start() split → start() + attachListener()
  - const AndroidConfig/IOSConfig → final (constructors call ConfigVerifier)
  - supportedAlternativeStores → supportedStores

## Pubspec
- bloc_test: ^9.1.7 → ^10.0.0 (compat flutter_bloc ^9.0.0)
- freerasp 7.5.1

## Config
- android/app/build.gradle : ajustements release
- lib/core/config/environment.dart : URLs API actualisées
- lib/main.dart + app_router : intégrations sécurité/BLoC

## Cleanup
- Suppression docs intermédiaires (TACHES_*.md, TASK_*_COMPLETION_REPORT.md,
  TESTS_UNITAIRES_PROGRESS.md)
- .g.dart régénérés (json_serializable)
- .mocks.dart régénérés (mockito)

## Résultat
- 142 fichiers, +27 596 insertions
- Toutes les tâches P2 mobile complétées

Co-Authored-By: Claude Opus 4.7 (1M context) <noreply@anthropic.com>
This commit is contained in:
dahoud
2026-04-21 12:42:35 +00:00
parent 33f5b5a707
commit 37db88672b
142 changed files with 27599 additions and 16068 deletions

View File

@@ -0,0 +1,498 @@
import 'dart:async';
import 'package:bloc_test/bloc_test.dart';
import 'package:flutter_test/flutter_test.dart';
import 'package:mockito/annotations.dart';
import 'package:mockito/mockito.dart';
import 'package:unionflow_mobile_apps/features/communication/presentation/bloc/messaging_bloc.dart';
import 'package:unionflow_mobile_apps/features/communication/presentation/bloc/messaging_event.dart';
import 'package:unionflow_mobile_apps/features/communication/presentation/bloc/messaging_state.dart';
import 'package:unionflow_mobile_apps/features/communication/domain/repositories/messaging_repository.dart';
import 'package:unionflow_mobile_apps/features/communication/domain/entities/conversation.dart';
import 'package:unionflow_mobile_apps/features/communication/domain/entities/message.dart';
import 'package:unionflow_mobile_apps/core/websocket/websocket_service.dart';
@GenerateMocks([MessagingRepository, WebSocketService])
import 'messaging_bloc_test.mocks.dart';
void main() {
late MessagingBloc bloc;
late MockMessagingRepository mockRepository;
late MockWebSocketService mockWebSocketService;
late StreamController<WebSocketEvent> wsController;
// ── Fixtures ──────────────────────────────────────────────────────────────
ConversationSummary fakeConversationSummary({
String id = 'conv-1',
String type = 'DIRECTE',
}) =>
ConversationSummary(
id: id,
typeConversation: type,
titre: 'Conversation $id',
statut: 'ACTIVE',
nonLus: 0,
);
Conversation fakeConversation({String id = 'conv-1'}) => Conversation(
id: id,
typeConversation: 'DIRECTE',
titre: 'Conversation $id',
statut: 'ACTIVE',
messages: [],
participants: [],
);
Message fakeMessage({String id = 'msg-1'}) => Message(
id: id,
typeMessage: 'TEXTE',
contenu: 'Bonjour !',
dateEnvoi: DateTime.now(),
);
setUp(() {
wsController = StreamController<WebSocketEvent>.broadcast();
mockRepository = MockMessagingRepository();
mockWebSocketService = MockWebSocketService();
when(mockWebSocketService.eventStream).thenAnswer((_) => wsController.stream);
bloc = MessagingBloc(
repository: mockRepository,
webSocketService: mockWebSocketService,
);
});
tearDown(() async {
await bloc.close();
await wsController.close();
});
// ── Initial state ─────────────────────────────────────────────────────────
test('initial state is MessagingInitial', () {
expect(bloc.state, isA<MessagingInitial>());
});
// ── LoadMesConversations ──────────────────────────────────────────────────
group('LoadMesConversations', () {
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingLoading, MesConversationsLoaded] on success',
build: () {
when(mockRepository.getMesConversations()).thenAnswer(
(_) async => [
fakeConversationSummary(),
fakeConversationSummary(id: 'conv-2', type: 'ROLE_CANAL'),
],
);
return bloc;
},
act: (b) => b.add(const LoadMesConversations()),
expect: () => [
isA<MessagingLoading>(),
isA<MesConversationsLoaded>().having(
(s) => s.conversations.length,
'conversations.length',
2,
),
],
verify: (_) => verify(mockRepository.getMesConversations()).called(1),
);
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingLoading, MesConversationsLoaded] with empty list',
build: () {
when(mockRepository.getMesConversations()).thenAnswer((_) async => []);
return bloc;
},
act: (b) => b.add(const LoadMesConversations()),
expect: () => [
isA<MessagingLoading>(),
isA<MesConversationsLoaded>().having(
(s) => s.conversations,
'conversations',
isEmpty,
),
],
);
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingLoading, MessagingError] on failure',
build: () {
when(mockRepository.getMesConversations())
.thenThrow(Exception('network error'));
return bloc;
},
act: (b) => b.add(const LoadMesConversations()),
expect: () => [
isA<MessagingLoading>(),
isA<MessagingError>(),
],
);
});
// ── OpenConversation ──────────────────────────────────────────────────────
group('OpenConversation', () {
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingLoading, ConversationOuverte] on success',
build: () {
when(mockRepository.getConversation('conv-1'))
.thenAnswer((_) async => fakeConversation());
when(mockRepository.marquerLu('conv-1')).thenAnswer((_) async {});
return bloc;
},
act: (b) => b.add(const OpenConversation('conv-1')),
expect: () => [
isA<MessagingLoading>(),
isA<ConversationOuverte>().having(
(s) => s.conversation.id,
'conversation.id',
'conv-1',
),
],
verify: (_) {
verify(mockRepository.getConversation('conv-1')).called(1);
},
);
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingLoading, MessagingError] when conversation not found',
build: () {
when(mockRepository.getConversation(any))
.thenThrow(Exception('Conversation introuvable'));
return bloc;
},
act: (b) => b.add(const OpenConversation('conv-x')),
expect: () => [isA<MessagingLoading>(), isA<MessagingError>()],
);
});
// ── DemarrerConversationDirecte ───────────────────────────────────────────
group('DemarrerConversationDirecte', () {
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingLoading, ConversationCreee] on success',
build: () {
when(mockRepository.demarrerConversationDirecte(
destinataireId: 'usr-2',
organisationId: 'org-1',
premierMessage: anyNamed('premierMessage'),
)).thenAnswer((_) async => fakeConversation(id: 'conv-new'));
return bloc;
},
act: (b) => b.add(const DemarrerConversationDirecte(
destinataireId: 'usr-2',
organisationId: 'org-1',
premierMessage: 'Bonjour !',
)),
expect: () => [
isA<MessagingLoading>(),
isA<ConversationCreee>().having(
(s) => s.conversation.id,
'conversation.id',
'conv-new',
),
],
);
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingLoading, MessagingError] on failure',
build: () {
when(mockRepository.demarrerConversationDirecte(
destinataireId: anyNamed('destinataireId'),
organisationId: anyNamed('organisationId'),
premierMessage: anyNamed('premierMessage'),
)).thenThrow(Exception('Cannot start conversation'));
return bloc;
},
act: (b) => b.add(const DemarrerConversationDirecte(
destinataireId: 'usr-2',
organisationId: 'org-1',
)),
expect: () => [isA<MessagingLoading>(), isA<MessagingError>()],
);
});
// ── DemarrerConversationRole ──────────────────────────────────────────────
group('DemarrerConversationRole', () {
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingLoading, ConversationCreee] on success',
build: () {
when(mockRepository.demarrerConversationRole(
roleCible: 'TRESORIER',
organisationId: 'org-1',
premierMessage: anyNamed('premierMessage'),
)).thenAnswer((_) async => fakeConversation(id: 'conv-role'));
return bloc;
},
act: (b) => b.add(const DemarrerConversationRole(
roleCible: 'TRESORIER',
organisationId: 'org-1',
)),
expect: () => [
isA<MessagingLoading>(),
isA<ConversationCreee>().having(
(s) => s.conversation.id,
'conversation.id',
'conv-role',
),
],
);
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingLoading, MessagingError] on failure',
build: () {
when(mockRepository.demarrerConversationRole(
roleCible: anyNamed('roleCible'),
organisationId: anyNamed('organisationId'),
premierMessage: anyNamed('premierMessage'),
)).thenThrow(Exception('role not found'));
return bloc;
},
act: (b) => b.add(const DemarrerConversationRole(
roleCible: 'ADMIN',
organisationId: 'org-1',
)),
expect: () => [isA<MessagingLoading>(), isA<MessagingError>()],
);
});
// ── ArchiverConversation ──────────────────────────────────────────────────
group('ArchiverConversation', () {
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingActionOk, MessagingLoading, MesConversationsLoaded] on success',
build: () {
when(mockRepository.archiverConversation('conv-1'))
.thenAnswer((_) async {});
when(mockRepository.getMesConversations()).thenAnswer((_) async => []);
return bloc;
},
act: (b) => b.add(const ArchiverConversation('conv-1')),
expect: () => [
isA<MessagingActionOk>().having(
(s) => s.action,
'action',
'archiver',
),
isA<MessagingLoading>(),
isA<MesConversationsLoaded>(),
],
verify: (_) {
verify(mockRepository.archiverConversation('conv-1')).called(1);
verify(mockRepository.getMesConversations()).called(1);
},
);
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingError] on archive failure',
build: () {
when(mockRepository.archiverConversation(any))
.thenThrow(Exception('archive failed'));
return bloc;
},
act: (b) => b.add(const ArchiverConversation('conv-1')),
expect: () => [isA<MessagingError>()],
);
});
// ── EnvoyerMessageTexte ───────────────────────────────────────────────────
group('EnvoyerMessageTexte', () {
blocTest<MessagingBloc, MessagingState>(
'emits [MessageEnvoye, MessagesLoaded] on success',
build: () {
when(mockRepository.envoyerMessage(
'conv-1',
typeMessage: 'TEXTE',
contenu: 'Hello',
messageParentId: anyNamed('messageParentId'),
)).thenAnswer((_) async => fakeMessage());
when(mockRepository.getMessages('conv-1', page: anyNamed('page')))
.thenAnswer((_) async => [fakeMessage()]);
return bloc;
},
act: (b) => b.add(const EnvoyerMessageTexte(
conversationId: 'conv-1',
contenu: 'Hello',
)),
expect: () => [
isA<MessageEnvoye>()
.having((s) => s.conversationId, 'conversationId', 'conv-1')
.having((s) => s.message.id, 'message.id', 'msg-1'),
isA<MessagesLoaded>(),
],
);
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingError] on send failure',
build: () {
when(mockRepository.envoyerMessage(
any,
typeMessage: anyNamed('typeMessage'),
contenu: anyNamed('contenu'),
messageParentId: anyNamed('messageParentId'),
)).thenThrow(Exception('send failed'));
return bloc;
},
act: (b) => b.add(const EnvoyerMessageTexte(
conversationId: 'conv-1',
contenu: 'Hello',
)),
expect: () => [isA<MessagingError>()],
);
});
// ── LoadMessages ──────────────────────────────────────────────────────────
group('LoadMessages', () {
blocTest<MessagingBloc, MessagingState>(
'emits [MessagesLoaded] with hasMore=true when 20 messages returned',
build: () {
final messages = List.generate(
20,
(i) => fakeMessage(id: 'msg-$i'),
);
when(mockRepository.getMessages('conv-1', page: 0))
.thenAnswer((_) async => messages);
return bloc;
},
act: (b) => b.add(const LoadMessages(conversationId: 'conv-1')),
expect: () => [
isA<MessagesLoaded>()
.having((s) => s.messages.length, 'messages.length', 20)
.having((s) => s.hasMore, 'hasMore', true)
.having((s) => s.conversationId, 'conversationId', 'conv-1'),
],
);
blocTest<MessagingBloc, MessagingState>(
'emits [MessagesLoaded] with hasMore=false when less than 20 messages',
build: () {
when(mockRepository.getMessages('conv-1', page: 0))
.thenAnswer((_) async => [fakeMessage(), fakeMessage(id: 'msg-2')]);
return bloc;
},
act: (b) => b.add(const LoadMessages(conversationId: 'conv-1')),
expect: () => [
isA<MessagesLoaded>().having((s) => s.hasMore, 'hasMore', false),
],
);
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingError] on load messages failure',
build: () {
when(mockRepository.getMessages(any, page: anyNamed('page')))
.thenThrow(Exception('load error'));
return bloc;
},
act: (b) => b.add(const LoadMessages(conversationId: 'conv-1')),
expect: () => [isA<MessagingError>()],
);
});
// ── SupprimerMessage ──────────────────────────────────────────────────────
group('SupprimerMessage', () {
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingActionOk, MessagesLoaded] on delete success',
build: () {
when(mockRepository.supprimerMessage('conv-1', 'msg-1'))
.thenAnswer((_) async {});
when(mockRepository.getMessages('conv-1', page: anyNamed('page')))
.thenAnswer((_) async => []);
return bloc;
},
act: (b) => b.add(const SupprimerMessage(
conversationId: 'conv-1',
messageId: 'msg-1',
)),
expect: () => [
isA<MessagingActionOk>().having(
(s) => s.action,
'action',
'supprimer-message',
),
isA<MessagesLoaded>(),
],
);
blocTest<MessagingBloc, MessagingState>(
'emits [MessagingError] on delete failure',
build: () {
when(mockRepository.supprimerMessage(any, any))
.thenThrow(Exception('delete error'));
return bloc;
},
act: (b) => b.add(const SupprimerMessage(
conversationId: 'conv-1',
messageId: 'msg-1',
)),
expect: () => [isA<MessagingError>()],
);
});
// ── NouveauMessageWebSocket ───────────────────────────────────────────────
group('NouveauMessageWebSocket', () {
blocTest<MessagingBloc, MessagingState>(
'reloads messages when current conversation matches',
build: () {
// Open a conversation first so _currentConversationId is set
when(mockRepository.getConversation('conv-1'))
.thenAnswer((_) async => fakeConversation());
when(mockRepository.marquerLu(any)).thenAnswer((_) async {});
when(mockRepository.getMessages('conv-1', page: anyNamed('page')))
.thenAnswer((_) async => [fakeMessage()]);
return bloc;
},
act: (b) async {
b.add(const OpenConversation('conv-1'));
await Future<void>.delayed(const Duration(milliseconds: 50));
b.add(const NouveauMessageWebSocket('conv-1'));
},
expect: () => [
isA<MessagingLoading>(),
isA<ConversationOuverte>(),
isA<MessagesLoaded>(),
],
);
blocTest<MessagingBloc, MessagingState>(
'refreshes conversations list when ws message is for a different conversation',
build: () {
when(mockRepository.getMesConversations())
.thenAnswer((_) async => [fakeConversationSummary()]);
return bloc;
},
act: (b) => b.add(const NouveauMessageWebSocket('conv-other')),
expect: () => [
isA<MessagingLoading>(),
isA<MesConversationsLoaded>(),
],
verify: (_) {
verify(mockRepository.getMesConversations()).called(1);
},
);
});
// ── MarquerLu ─────────────────────────────────────────────────────────────
group('MarquerLu', () {
blocTest<MessagingBloc, MessagingState>(
'calls marquerLu on repository without state change',
build: () {
when(mockRepository.marquerLu('conv-1')).thenAnswer((_) async {});
return bloc;
},
act: (b) => b.add(const MarquerLu('conv-1')),
expect: () => [],
verify: (_) => verify(mockRepository.marquerLu('conv-1')).called(1),
);
});
}

View File

@@ -0,0 +1,353 @@
// Mocks generated by Mockito 5.4.6 from annotations
// in unionflow_mobile_apps/test/features/communication/bloc/messaging_bloc_test.dart.
// Do not manually edit this file.
// ignore_for_file: no_leading_underscores_for_library_prefixes
import 'dart:async' as _i6;
import 'package:mockito/mockito.dart' as _i1;
import 'package:unionflow_mobile_apps/core/websocket/websocket_service.dart'
as _i7;
import 'package:unionflow_mobile_apps/features/communication/domain/entities/contact_policy.dart'
as _i4;
import 'package:unionflow_mobile_apps/features/communication/domain/entities/conversation.dart'
as _i2;
import 'package:unionflow_mobile_apps/features/communication/domain/entities/message.dart'
as _i3;
import 'package:unionflow_mobile_apps/features/communication/domain/repositories/messaging_repository.dart'
as _i5;
// ignore_for_file: type=lint
// ignore_for_file: avoid_redundant_argument_values
// ignore_for_file: avoid_setters_without_getters
// ignore_for_file: comment_references
// ignore_for_file: deprecated_member_use
// ignore_for_file: deprecated_member_use_from_same_package
// ignore_for_file: implementation_imports
// ignore_for_file: invalid_use_of_visible_for_testing_member
// ignore_for_file: must_be_immutable
// ignore_for_file: prefer_const_constructors
// ignore_for_file: unnecessary_parenthesis
// ignore_for_file: camel_case_types
// ignore_for_file: subtype_of_sealed_class
// ignore_for_file: invalid_use_of_internal_member
class _FakeConversation_0 extends _i1.SmartFake implements _i2.Conversation {
_FakeConversation_0(Object parent, Invocation parentInvocation)
: super(parent, parentInvocation);
}
class _FakeMessage_1 extends _i1.SmartFake implements _i3.Message {
_FakeMessage_1(Object parent, Invocation parentInvocation)
: super(parent, parentInvocation);
}
class _FakeContactPolicy_2 extends _i1.SmartFake implements _i4.ContactPolicy {
_FakeContactPolicy_2(Object parent, Invocation parentInvocation)
: super(parent, parentInvocation);
}
/// A class which mocks [MessagingRepository].
///
/// See the documentation for Mockito's code generation for more information.
class MockMessagingRepository extends _i1.Mock
implements _i5.MessagingRepository {
MockMessagingRepository() {
_i1.throwOnMissingStub(this);
}
@override
_i6.Future<List<_i2.ConversationSummary>> getMesConversations() =>
(super.noSuchMethod(
Invocation.method(#getMesConversations, []),
returnValue: _i6.Future<List<_i2.ConversationSummary>>.value(
<_i2.ConversationSummary>[],
),
)
as _i6.Future<List<_i2.ConversationSummary>>);
@override
_i6.Future<_i2.Conversation> getConversation(String? conversationId) =>
(super.noSuchMethod(
Invocation.method(#getConversation, [conversationId]),
returnValue: _i6.Future<_i2.Conversation>.value(
_FakeConversation_0(
this,
Invocation.method(#getConversation, [conversationId]),
),
),
)
as _i6.Future<_i2.Conversation>);
@override
_i6.Future<_i2.Conversation> demarrerConversationDirecte({
required String? destinataireId,
required String? organisationId,
String? premierMessage,
}) =>
(super.noSuchMethod(
Invocation.method(#demarrerConversationDirecte, [], {
#destinataireId: destinataireId,
#organisationId: organisationId,
#premierMessage: premierMessage,
}),
returnValue: _i6.Future<_i2.Conversation>.value(
_FakeConversation_0(
this,
Invocation.method(#demarrerConversationDirecte, [], {
#destinataireId: destinataireId,
#organisationId: organisationId,
#premierMessage: premierMessage,
}),
),
),
)
as _i6.Future<_i2.Conversation>);
@override
_i6.Future<_i2.Conversation> demarrerConversationRole({
required String? roleCible,
required String? organisationId,
String? premierMessage,
}) =>
(super.noSuchMethod(
Invocation.method(#demarrerConversationRole, [], {
#roleCible: roleCible,
#organisationId: organisationId,
#premierMessage: premierMessage,
}),
returnValue: _i6.Future<_i2.Conversation>.value(
_FakeConversation_0(
this,
Invocation.method(#demarrerConversationRole, [], {
#roleCible: roleCible,
#organisationId: organisationId,
#premierMessage: premierMessage,
}),
),
),
)
as _i6.Future<_i2.Conversation>);
@override
_i6.Future<void> archiverConversation(String? conversationId) =>
(super.noSuchMethod(
Invocation.method(#archiverConversation, [conversationId]),
returnValue: _i6.Future<void>.value(),
returnValueForMissingStub: _i6.Future<void>.value(),
)
as _i6.Future<void>);
@override
_i6.Future<_i3.Message> envoyerMessage(
String? conversationId, {
required String? typeMessage,
String? contenu,
String? urlFichier,
int? dureeAudio,
String? messageParentId,
}) =>
(super.noSuchMethod(
Invocation.method(
#envoyerMessage,
[conversationId],
{
#typeMessage: typeMessage,
#contenu: contenu,
#urlFichier: urlFichier,
#dureeAudio: dureeAudio,
#messageParentId: messageParentId,
},
),
returnValue: _i6.Future<_i3.Message>.value(
_FakeMessage_1(
this,
Invocation.method(
#envoyerMessage,
[conversationId],
{
#typeMessage: typeMessage,
#contenu: contenu,
#urlFichier: urlFichier,
#dureeAudio: dureeAudio,
#messageParentId: messageParentId,
},
),
),
),
)
as _i6.Future<_i3.Message>);
@override
_i6.Future<List<_i3.Message>> getMessages(
String? conversationId, {
int? page = 0,
}) =>
(super.noSuchMethod(
Invocation.method(#getMessages, [conversationId], {#page: page}),
returnValue: _i6.Future<List<_i3.Message>>.value(<_i3.Message>[]),
)
as _i6.Future<List<_i3.Message>>);
@override
_i6.Future<void> marquerLu(String? conversationId) =>
(super.noSuchMethod(
Invocation.method(#marquerLu, [conversationId]),
returnValue: _i6.Future<void>.value(),
returnValueForMissingStub: _i6.Future<void>.value(),
)
as _i6.Future<void>);
@override
_i6.Future<void> supprimerMessage(
String? conversationId,
String? messageId,
) =>
(super.noSuchMethod(
Invocation.method(#supprimerMessage, [conversationId, messageId]),
returnValue: _i6.Future<void>.value(),
returnValueForMissingStub: _i6.Future<void>.value(),
)
as _i6.Future<void>);
@override
_i6.Future<void> bloquerMembre({
required String? membreABloquerId,
String? organisationId,
String? raison,
}) =>
(super.noSuchMethod(
Invocation.method(#bloquerMembre, [], {
#membreABloquerId: membreABloquerId,
#organisationId: organisationId,
#raison: raison,
}),
returnValue: _i6.Future<void>.value(),
returnValueForMissingStub: _i6.Future<void>.value(),
)
as _i6.Future<void>);
@override
_i6.Future<void> debloquerMembre(
String? membreId, {
String? organisationId,
}) =>
(super.noSuchMethod(
Invocation.method(
#debloquerMembre,
[membreId],
{#organisationId: organisationId},
),
returnValue: _i6.Future<void>.value(),
returnValueForMissingStub: _i6.Future<void>.value(),
)
as _i6.Future<void>);
@override
_i6.Future<List<Map<String, dynamic>>> getMesBlocages() =>
(super.noSuchMethod(
Invocation.method(#getMesBlocages, []),
returnValue: _i6.Future<List<Map<String, dynamic>>>.value(
<Map<String, dynamic>>[],
),
)
as _i6.Future<List<Map<String, dynamic>>>);
@override
_i6.Future<_i4.ContactPolicy> getPolitique(String? organisationId) =>
(super.noSuchMethod(
Invocation.method(#getPolitique, [organisationId]),
returnValue: _i6.Future<_i4.ContactPolicy>.value(
_FakeContactPolicy_2(
this,
Invocation.method(#getPolitique, [organisationId]),
),
),
)
as _i6.Future<_i4.ContactPolicy>);
@override
_i6.Future<_i4.ContactPolicy> mettreAJourPolitique(
String? organisationId, {
required String? typePolitique,
required bool? autoriserMembreVersMembre,
required bool? autoriserMembreVersRole,
required bool? autoriserNotesVocales,
}) =>
(super.noSuchMethod(
Invocation.method(
#mettreAJourPolitique,
[organisationId],
{
#typePolitique: typePolitique,
#autoriserMembreVersMembre: autoriserMembreVersMembre,
#autoriserMembreVersRole: autoriserMembreVersRole,
#autoriserNotesVocales: autoriserNotesVocales,
},
),
returnValue: _i6.Future<_i4.ContactPolicy>.value(
_FakeContactPolicy_2(
this,
Invocation.method(
#mettreAJourPolitique,
[organisationId],
{
#typePolitique: typePolitique,
#autoriserMembreVersMembre: autoriserMembreVersMembre,
#autoriserMembreVersRole: autoriserMembreVersRole,
#autoriserNotesVocales: autoriserNotesVocales,
},
),
),
),
)
as _i6.Future<_i4.ContactPolicy>);
}
/// A class which mocks [WebSocketService].
///
/// See the documentation for Mockito's code generation for more information.
class MockWebSocketService extends _i1.Mock implements _i7.WebSocketService {
MockWebSocketService() {
_i1.throwOnMissingStub(this);
}
@override
_i6.Stream<_i7.WebSocketEvent> get eventStream =>
(super.noSuchMethod(
Invocation.getter(#eventStream),
returnValue: _i6.Stream<_i7.WebSocketEvent>.empty(),
)
as _i6.Stream<_i7.WebSocketEvent>);
@override
_i6.Stream<bool> get connectionStatusStream =>
(super.noSuchMethod(
Invocation.getter(#connectionStatusStream),
returnValue: _i6.Stream<bool>.empty(),
)
as _i6.Stream<bool>);
@override
bool get isConnected =>
(super.noSuchMethod(Invocation.getter(#isConnected), returnValue: false)
as bool);
@override
void connect() => super.noSuchMethod(
Invocation.method(#connect, []),
returnValueForMissingStub: null,
);
@override
void disconnect() => super.noSuchMethod(
Invocation.method(#disconnect, []),
returnValueForMissingStub: null,
);
@override
void dispose() => super.noSuchMethod(
Invocation.method(#dispose, []),
returnValueForMissingStub: null,
);
}