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:
@@ -30,24 +30,14 @@ import 'package:unionflow_mobile_apps/features/events/domain/repositories/evenem
|
||||
|
||||
class _FakeEvenementSearchResult_0 extends _i1.SmartFake
|
||||
implements _i2.EvenementSearchResult {
|
||||
_FakeEvenementSearchResult_0(
|
||||
Object parent,
|
||||
Invocation parentInvocation,
|
||||
) : super(
|
||||
parent,
|
||||
parentInvocation,
|
||||
);
|
||||
_FakeEvenementSearchResult_0(Object parent, Invocation parentInvocation)
|
||||
: super(parent, parentInvocation);
|
||||
}
|
||||
|
||||
class _FakeEvenementModel_1 extends _i1.SmartFake
|
||||
implements _i3.EvenementModel {
|
||||
_FakeEvenementModel_1(
|
||||
Object parent,
|
||||
Invocation parentInvocation,
|
||||
) : super(
|
||||
parent,
|
||||
parentInvocation,
|
||||
);
|
||||
_FakeEvenementModel_1(Object parent, Invocation parentInvocation)
|
||||
: super(parent, parentInvocation);
|
||||
}
|
||||
|
||||
/// A class which mocks [IEvenementRepository].
|
||||
@@ -66,56 +56,46 @@ class MockIEvenementRepository extends _i1.Mock
|
||||
String? recherche,
|
||||
}) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#getEvenements,
|
||||
[],
|
||||
{
|
||||
#page: page,
|
||||
#size: size,
|
||||
#recherche: recherche,
|
||||
},
|
||||
),
|
||||
returnValue: _i5.Future<_i2.EvenementSearchResult>.value(
|
||||
_FakeEvenementSearchResult_0(
|
||||
this,
|
||||
Invocation.method(
|
||||
#getEvenements,
|
||||
[],
|
||||
{
|
||||
Invocation.method(#getEvenements, [], {
|
||||
#page: page,
|
||||
#size: size,
|
||||
#recherche: recherche,
|
||||
},
|
||||
),
|
||||
)),
|
||||
) as _i5.Future<_i2.EvenementSearchResult>);
|
||||
}),
|
||||
returnValue: _i5.Future<_i2.EvenementSearchResult>.value(
|
||||
_FakeEvenementSearchResult_0(
|
||||
this,
|
||||
Invocation.method(#getEvenements, [], {
|
||||
#page: page,
|
||||
#size: size,
|
||||
#recherche: recherche,
|
||||
}),
|
||||
),
|
||||
),
|
||||
)
|
||||
as _i5.Future<_i2.EvenementSearchResult>);
|
||||
|
||||
@override
|
||||
_i5.Future<_i3.EvenementModel?> getEvenementById(String? id) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#getEvenementById,
|
||||
[id],
|
||||
),
|
||||
returnValue: _i5.Future<_i3.EvenementModel?>.value(),
|
||||
) as _i5.Future<_i3.EvenementModel?>);
|
||||
Invocation.method(#getEvenementById, [id]),
|
||||
returnValue: _i5.Future<_i3.EvenementModel?>.value(),
|
||||
)
|
||||
as _i5.Future<_i3.EvenementModel?>);
|
||||
|
||||
@override
|
||||
_i5.Future<_i3.EvenementModel> createEvenement(
|
||||
_i3.EvenementModel? evenement) =>
|
||||
_i3.EvenementModel? evenement,
|
||||
) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#createEvenement,
|
||||
[evenement],
|
||||
),
|
||||
returnValue: _i5.Future<_i3.EvenementModel>.value(_FakeEvenementModel_1(
|
||||
this,
|
||||
Invocation.method(
|
||||
#createEvenement,
|
||||
[evenement],
|
||||
),
|
||||
)),
|
||||
) as _i5.Future<_i3.EvenementModel>);
|
||||
Invocation.method(#createEvenement, [evenement]),
|
||||
returnValue: _i5.Future<_i3.EvenementModel>.value(
|
||||
_FakeEvenementModel_1(
|
||||
this,
|
||||
Invocation.method(#createEvenement, [evenement]),
|
||||
),
|
||||
),
|
||||
)
|
||||
as _i5.Future<_i3.EvenementModel>);
|
||||
|
||||
@override
|
||||
_i5.Future<_i3.EvenementModel> updateEvenement(
|
||||
@@ -123,34 +103,24 @@ class MockIEvenementRepository extends _i1.Mock
|
||||
_i3.EvenementModel? evenement,
|
||||
) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#updateEvenement,
|
||||
[
|
||||
id,
|
||||
evenement,
|
||||
],
|
||||
),
|
||||
returnValue: _i5.Future<_i3.EvenementModel>.value(_FakeEvenementModel_1(
|
||||
this,
|
||||
Invocation.method(
|
||||
#updateEvenement,
|
||||
[
|
||||
id,
|
||||
evenement,
|
||||
],
|
||||
),
|
||||
)),
|
||||
) as _i5.Future<_i3.EvenementModel>);
|
||||
Invocation.method(#updateEvenement, [id, evenement]),
|
||||
returnValue: _i5.Future<_i3.EvenementModel>.value(
|
||||
_FakeEvenementModel_1(
|
||||
this,
|
||||
Invocation.method(#updateEvenement, [id, evenement]),
|
||||
),
|
||||
),
|
||||
)
|
||||
as _i5.Future<_i3.EvenementModel>);
|
||||
|
||||
@override
|
||||
_i5.Future<void> deleteEvenement(String? id) => (super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#deleteEvenement,
|
||||
[id],
|
||||
),
|
||||
returnValue: _i5.Future<void>.value(),
|
||||
returnValueForMissingStub: _i5.Future<void>.value(),
|
||||
) as _i5.Future<void>);
|
||||
_i5.Future<void> deleteEvenement(String? id) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(#deleteEvenement, [id]),
|
||||
returnValue: _i5.Future<void>.value(),
|
||||
returnValueForMissingStub: _i5.Future<void>.value(),
|
||||
)
|
||||
as _i5.Future<void>);
|
||||
|
||||
@override
|
||||
_i5.Future<_i2.EvenementSearchResult> getEvenementsAVenir({
|
||||
@@ -158,27 +128,21 @@ class MockIEvenementRepository extends _i1.Mock
|
||||
int? size = 20,
|
||||
}) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#getEvenementsAVenir,
|
||||
[],
|
||||
{
|
||||
#page: page,
|
||||
#size: size,
|
||||
},
|
||||
),
|
||||
returnValue: _i5.Future<_i2.EvenementSearchResult>.value(
|
||||
_FakeEvenementSearchResult_0(
|
||||
this,
|
||||
Invocation.method(
|
||||
#getEvenementsAVenir,
|
||||
[],
|
||||
{
|
||||
Invocation.method(#getEvenementsAVenir, [], {
|
||||
#page: page,
|
||||
#size: size,
|
||||
},
|
||||
),
|
||||
)),
|
||||
) as _i5.Future<_i2.EvenementSearchResult>);
|
||||
}),
|
||||
returnValue: _i5.Future<_i2.EvenementSearchResult>.value(
|
||||
_FakeEvenementSearchResult_0(
|
||||
this,
|
||||
Invocation.method(#getEvenementsAVenir, [], {
|
||||
#page: page,
|
||||
#size: size,
|
||||
}),
|
||||
),
|
||||
),
|
||||
)
|
||||
as _i5.Future<_i2.EvenementSearchResult>);
|
||||
|
||||
@override
|
||||
_i5.Future<_i2.EvenementSearchResult> getEvenementsEnCours({
|
||||
@@ -186,27 +150,21 @@ class MockIEvenementRepository extends _i1.Mock
|
||||
int? size = 20,
|
||||
}) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#getEvenementsEnCours,
|
||||
[],
|
||||
{
|
||||
#page: page,
|
||||
#size: size,
|
||||
},
|
||||
),
|
||||
returnValue: _i5.Future<_i2.EvenementSearchResult>.value(
|
||||
_FakeEvenementSearchResult_0(
|
||||
this,
|
||||
Invocation.method(
|
||||
#getEvenementsEnCours,
|
||||
[],
|
||||
{
|
||||
Invocation.method(#getEvenementsEnCours, [], {
|
||||
#page: page,
|
||||
#size: size,
|
||||
},
|
||||
),
|
||||
)),
|
||||
) as _i5.Future<_i2.EvenementSearchResult>);
|
||||
}),
|
||||
returnValue: _i5.Future<_i2.EvenementSearchResult>.value(
|
||||
_FakeEvenementSearchResult_0(
|
||||
this,
|
||||
Invocation.method(#getEvenementsEnCours, [], {
|
||||
#page: page,
|
||||
#size: size,
|
||||
}),
|
||||
),
|
||||
),
|
||||
)
|
||||
as _i5.Future<_i2.EvenementSearchResult>);
|
||||
|
||||
@override
|
||||
_i5.Future<_i2.EvenementSearchResult> getEvenementsPasses({
|
||||
@@ -214,80 +172,67 @@ class MockIEvenementRepository extends _i1.Mock
|
||||
int? size = 20,
|
||||
}) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#getEvenementsPasses,
|
||||
[],
|
||||
{
|
||||
#page: page,
|
||||
#size: size,
|
||||
},
|
||||
),
|
||||
returnValue: _i5.Future<_i2.EvenementSearchResult>.value(
|
||||
_FakeEvenementSearchResult_0(
|
||||
this,
|
||||
Invocation.method(
|
||||
#getEvenementsPasses,
|
||||
[],
|
||||
{
|
||||
Invocation.method(#getEvenementsPasses, [], {
|
||||
#page: page,
|
||||
#size: size,
|
||||
},
|
||||
),
|
||||
)),
|
||||
) as _i5.Future<_i2.EvenementSearchResult>);
|
||||
}),
|
||||
returnValue: _i5.Future<_i2.EvenementSearchResult>.value(
|
||||
_FakeEvenementSearchResult_0(
|
||||
this,
|
||||
Invocation.method(#getEvenementsPasses, [], {
|
||||
#page: page,
|
||||
#size: size,
|
||||
}),
|
||||
),
|
||||
),
|
||||
)
|
||||
as _i5.Future<_i2.EvenementSearchResult>);
|
||||
|
||||
@override
|
||||
_i5.Future<void> inscrireEvenement(String? evenementId) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#inscrireEvenement,
|
||||
[evenementId],
|
||||
),
|
||||
returnValue: _i5.Future<void>.value(),
|
||||
returnValueForMissingStub: _i5.Future<void>.value(),
|
||||
) as _i5.Future<void>);
|
||||
Invocation.method(#inscrireEvenement, [evenementId]),
|
||||
returnValue: _i5.Future<void>.value(),
|
||||
returnValueForMissingStub: _i5.Future<void>.value(),
|
||||
)
|
||||
as _i5.Future<void>);
|
||||
|
||||
@override
|
||||
_i5.Future<void> desinscrireEvenement(String? evenementId) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#desinscrireEvenement,
|
||||
[evenementId],
|
||||
),
|
||||
returnValue: _i5.Future<void>.value(),
|
||||
returnValueForMissingStub: _i5.Future<void>.value(),
|
||||
) as _i5.Future<void>);
|
||||
Invocation.method(#desinscrireEvenement, [evenementId]),
|
||||
returnValue: _i5.Future<void>.value(),
|
||||
returnValueForMissingStub: _i5.Future<void>.value(),
|
||||
)
|
||||
as _i5.Future<void>);
|
||||
|
||||
@override
|
||||
_i5.Future<bool> getInscriptionStatus(String? evenementId) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#getInscriptionStatus,
|
||||
[evenementId],
|
||||
),
|
||||
returnValue: _i5.Future<bool>.value(false),
|
||||
) as _i5.Future<bool>);
|
||||
Invocation.method(#getInscriptionStatus, [evenementId]),
|
||||
returnValue: _i5.Future<bool>.value(false),
|
||||
)
|
||||
as _i5.Future<bool>);
|
||||
|
||||
@override
|
||||
_i5.Future<List<Map<String, dynamic>>> getParticipants(String? evenementId) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#getParticipants,
|
||||
[evenementId],
|
||||
),
|
||||
returnValue: _i5.Future<List<Map<String, dynamic>>>.value(
|
||||
<Map<String, dynamic>>[]),
|
||||
) as _i5.Future<List<Map<String, dynamic>>>);
|
||||
Invocation.method(#getParticipants, [evenementId]),
|
||||
returnValue: _i5.Future<List<Map<String, dynamic>>>.value(
|
||||
<Map<String, dynamic>>[],
|
||||
),
|
||||
)
|
||||
as _i5.Future<List<Map<String, dynamic>>>);
|
||||
|
||||
@override
|
||||
_i5.Future<Map<String, dynamic>> getEvenementsStats() => (super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#getEvenementsStats,
|
||||
[],
|
||||
),
|
||||
returnValue:
|
||||
_i5.Future<Map<String, dynamic>>.value(<String, dynamic>{}),
|
||||
) as _i5.Future<Map<String, dynamic>>);
|
||||
_i5.Future<Map<String, dynamic>> getEvenementsStats() =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(#getEvenementsStats, []),
|
||||
returnValue: _i5.Future<Map<String, dynamic>>.value(
|
||||
<String, dynamic>{},
|
||||
),
|
||||
)
|
||||
as _i5.Future<Map<String, dynamic>>);
|
||||
|
||||
@override
|
||||
_i5.Future<void> submitFeedback({
|
||||
@@ -296,27 +241,23 @@ class MockIEvenementRepository extends _i1.Mock
|
||||
String? commentaire,
|
||||
}) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#submitFeedback,
|
||||
[],
|
||||
{
|
||||
#evenementId: evenementId,
|
||||
#note: note,
|
||||
#commentaire: commentaire,
|
||||
},
|
||||
),
|
||||
returnValue: _i5.Future<void>.value(),
|
||||
returnValueForMissingStub: _i5.Future<void>.value(),
|
||||
) as _i5.Future<void>);
|
||||
Invocation.method(#submitFeedback, [], {
|
||||
#evenementId: evenementId,
|
||||
#note: note,
|
||||
#commentaire: commentaire,
|
||||
}),
|
||||
returnValue: _i5.Future<void>.value(),
|
||||
returnValueForMissingStub: _i5.Future<void>.value(),
|
||||
)
|
||||
as _i5.Future<void>);
|
||||
|
||||
@override
|
||||
_i5.Future<Map<String, dynamic>> getFeedbacks(String? evenementId) =>
|
||||
(super.noSuchMethod(
|
||||
Invocation.method(
|
||||
#getFeedbacks,
|
||||
[evenementId],
|
||||
),
|
||||
returnValue:
|
||||
_i5.Future<Map<String, dynamic>>.value(<String, dynamic>{}),
|
||||
) as _i5.Future<Map<String, dynamic>>);
|
||||
Invocation.method(#getFeedbacks, [evenementId]),
|
||||
returnValue: _i5.Future<Map<String, dynamic>>.value(
|
||||
<String, dynamic>{},
|
||||
),
|
||||
)
|
||||
as _i5.Future<Map<String, dynamic>>);
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user