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

@@ -31,13 +31,8 @@ import 'package:unionflow_mobile_apps/features/dashboard/domain/repositories/das
// ignore_for_file: invalid_use_of_internal_member
class _FakeEither_0<L, R> extends _i1.SmartFake implements _i2.Either<L, R> {
_FakeEither_0(
Object parent,
Invocation parentInvocation,
) : super(
parent,
parentInvocation,
);
_FakeEither_0(Object parent, Invocation parentInvocation)
: super(parent, parentInvocation);
}
/// A class which mocks [DashboardRepository].
@@ -51,21 +46,20 @@ class MockDashboardRepository extends _i1.Mock
@override
_i4.Future<_i2.Either<_i5.Failure, _i6.CompteAdherentEntity>>
getCompteAdherent() => (super.noSuchMethod(
Invocation.method(
#getCompteAdherent,
[],
),
returnValue: _i4.Future<
_i2.Either<_i5.Failure, _i6.CompteAdherentEntity>>.value(
_FakeEither_0<_i5.Failure, _i6.CompteAdherentEntity>(
this,
Invocation.method(
#getCompteAdherent,
[],
),
)),
) as _i4.Future<_i2.Either<_i5.Failure, _i6.CompteAdherentEntity>>);
getCompteAdherent() =>
(super.noSuchMethod(
Invocation.method(#getCompteAdherent, []),
returnValue:
_i4.Future<
_i2.Either<_i5.Failure, _i6.CompteAdherentEntity>
>.value(
_FakeEither_0<_i5.Failure, _i6.CompteAdherentEntity>(
this,
Invocation.method(#getCompteAdherent, []),
),
),
)
as _i4.Future<_i2.Either<_i5.Failure, _i6.CompteAdherentEntity>>);
@override
_i4.Future<_i2.Either<_i5.Failure, _i7.DashboardEntity>> getDashboardData(
@@ -74,118 +68,100 @@ class MockDashboardRepository extends _i1.Mock
bool? useGlobalDashboard = false,
}) =>
(super.noSuchMethod(
Invocation.method(
#getDashboardData,
[
organizationId,
userId,
],
{#useGlobalDashboard: useGlobalDashboard},
),
returnValue:
_i4.Future<_i2.Either<_i5.Failure, _i7.DashboardEntity>>.value(
_FakeEither_0<_i5.Failure, _i7.DashboardEntity>(
this,
Invocation.method(
#getDashboardData,
[
organizationId,
userId,
],
{#useGlobalDashboard: useGlobalDashboard},
),
)),
) as _i4.Future<_i2.Either<_i5.Failure, _i7.DashboardEntity>>);
Invocation.method(
#getDashboardData,
[organizationId, userId],
{#useGlobalDashboard: useGlobalDashboard},
),
returnValue:
_i4.Future<_i2.Either<_i5.Failure, _i7.DashboardEntity>>.value(
_FakeEither_0<_i5.Failure, _i7.DashboardEntity>(
this,
Invocation.method(
#getDashboardData,
[organizationId, userId],
{#useGlobalDashboard: useGlobalDashboard},
),
),
),
)
as _i4.Future<_i2.Either<_i5.Failure, _i7.DashboardEntity>>);
@override
_i4.Future<
_i2.Either<_i5.Failure, _i7.DashboardStatsEntity>> getDashboardStats(
String? organizationId,
String? userId,
) =>
_i4.Future<_i2.Either<_i5.Failure, _i7.DashboardStatsEntity>>
getDashboardStats(String? organizationId, String? userId) =>
(super.noSuchMethod(
Invocation.method(
#getDashboardStats,
[
organizationId,
userId,
],
),
returnValue:
_i4.Future<_i2.Either<_i5.Failure, _i7.DashboardStatsEntity>>.value(
_FakeEither_0<_i5.Failure, _i7.DashboardStatsEntity>(
this,
Invocation.method(
#getDashboardStats,
[
organizationId,
userId,
],
),
)),
) as _i4.Future<_i2.Either<_i5.Failure, _i7.DashboardStatsEntity>>);
Invocation.method(#getDashboardStats, [organizationId, userId]),
returnValue:
_i4.Future<
_i2.Either<_i5.Failure, _i7.DashboardStatsEntity>
>.value(
_FakeEither_0<_i5.Failure, _i7.DashboardStatsEntity>(
this,
Invocation.method(#getDashboardStats, [
organizationId,
userId,
]),
),
),
)
as _i4.Future<_i2.Either<_i5.Failure, _i7.DashboardStatsEntity>>);
@override
_i4.Future<_i2.Either<_i5.Failure, List<_i7.RecentActivityEntity>>>
getRecentActivities(
getRecentActivities(
String? organizationId,
String? userId, {
int? limit = 10,
}) =>
(super.noSuchMethod(
(super.noSuchMethod(
Invocation.method(
#getRecentActivities,
[
organizationId,
userId,
],
[organizationId, userId],
{#limit: limit},
),
returnValue: _i4.Future<
_i2
.Either<_i5.Failure, List<_i7.RecentActivityEntity>>>.value(
_FakeEither_0<_i5.Failure, List<_i7.RecentActivityEntity>>(
this,
Invocation.method(
#getRecentActivities,
[
organizationId,
userId,
],
{#limit: limit},
),
)),
) as _i4
.Future<_i2.Either<_i5.Failure, List<_i7.RecentActivityEntity>>>);
returnValue:
_i4.Future<
_i2.Either<_i5.Failure, List<_i7.RecentActivityEntity>>
>.value(
_FakeEither_0<_i5.Failure, List<_i7.RecentActivityEntity>>(
this,
Invocation.method(
#getRecentActivities,
[organizationId, userId],
{#limit: limit},
),
),
),
)
as _i4.Future<
_i2.Either<_i5.Failure, List<_i7.RecentActivityEntity>>
>);
@override
_i4.Future<
_i2.Either<_i5.Failure, List<_i7.UpcomingEventEntity>>> getUpcomingEvents(
String? organizationId,
String? userId, {
int? limit = 5,
}) =>
_i4.Future<_i2.Either<_i5.Failure, List<_i7.UpcomingEventEntity>>>
getUpcomingEvents(String? organizationId, String? userId, {int? limit = 5}) =>
(super.noSuchMethod(
Invocation.method(
#getUpcomingEvents,
[
organizationId,
userId,
],
{#limit: limit},
),
returnValue: _i4.Future<
_i2.Either<_i5.Failure, List<_i7.UpcomingEventEntity>>>.value(
_FakeEither_0<_i5.Failure, List<_i7.UpcomingEventEntity>>(
this,
Invocation.method(
#getUpcomingEvents,
[
organizationId,
userId,
],
{#limit: limit},
),
)),
) as _i4.Future<_i2.Either<_i5.Failure, List<_i7.UpcomingEventEntity>>>);
Invocation.method(
#getUpcomingEvents,
[organizationId, userId],
{#limit: limit},
),
returnValue:
_i4.Future<
_i2.Either<_i5.Failure, List<_i7.UpcomingEventEntity>>
>.value(
_FakeEither_0<_i5.Failure, List<_i7.UpcomingEventEntity>>(
this,
Invocation.method(
#getUpcomingEvents,
[organizationId, userId],
{#limit: limit},
),
),
),
)
as _i4.Future<
_i2.Either<_i5.Failure, List<_i7.UpcomingEventEntity>>
>);
}