## 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>
221 lines
7.5 KiB
Dart
221 lines
7.5 KiB
Dart
// Mocks generated by Mockito 5.4.6 from annotations
|
|
// in unionflow_mobile_apps/test/features/finance_workflow/bloc/approval_bloc_test.dart.
|
|
// Do not manually edit this file.
|
|
|
|
// ignore_for_file: no_leading_underscores_for_library_prefixes
|
|
import 'dart:async' as _i5;
|
|
|
|
import 'package:dartz/dartz.dart' as _i3;
|
|
import 'package:mockito/mockito.dart' as _i1;
|
|
import 'package:unionflow_mobile_apps/core/error/failures.dart' as _i6;
|
|
import 'package:unionflow_mobile_apps/features/finance_workflow/domain/entities/transaction_approval.dart'
|
|
as _i7;
|
|
import 'package:unionflow_mobile_apps/features/finance_workflow/domain/repositories/finance_workflow_repository.dart'
|
|
as _i2;
|
|
import 'package:unionflow_mobile_apps/features/finance_workflow/domain/usecases/approve_transaction.dart'
|
|
as _i9;
|
|
import 'package:unionflow_mobile_apps/features/finance_workflow/domain/usecases/get_approval_by_id.dart'
|
|
as _i8;
|
|
import 'package:unionflow_mobile_apps/features/finance_workflow/domain/usecases/get_pending_approvals.dart'
|
|
as _i4;
|
|
import 'package:unionflow_mobile_apps/features/finance_workflow/domain/usecases/reject_transaction.dart'
|
|
as _i10;
|
|
|
|
// 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 _FakeFinanceWorkflowRepository_0 extends _i1.SmartFake
|
|
implements _i2.FinanceWorkflowRepository {
|
|
_FakeFinanceWorkflowRepository_0(Object parent, Invocation parentInvocation)
|
|
: super(parent, parentInvocation);
|
|
}
|
|
|
|
class _FakeEither_1<L, R> extends _i1.SmartFake implements _i3.Either<L, R> {
|
|
_FakeEither_1(Object parent, Invocation parentInvocation)
|
|
: super(parent, parentInvocation);
|
|
}
|
|
|
|
/// A class which mocks [GetPendingApprovals].
|
|
///
|
|
/// See the documentation for Mockito's code generation for more information.
|
|
class MockGetPendingApprovals extends _i1.Mock
|
|
implements _i4.GetPendingApprovals {
|
|
MockGetPendingApprovals() {
|
|
_i1.throwOnMissingStub(this);
|
|
}
|
|
|
|
@override
|
|
_i2.FinanceWorkflowRepository get repository =>
|
|
(super.noSuchMethod(
|
|
Invocation.getter(#repository),
|
|
returnValue: _FakeFinanceWorkflowRepository_0(
|
|
this,
|
|
Invocation.getter(#repository),
|
|
),
|
|
)
|
|
as _i2.FinanceWorkflowRepository);
|
|
|
|
@override
|
|
_i5.Future<_i3.Either<_i6.Failure, List<_i7.TransactionApproval>>> call({
|
|
String? organizationId,
|
|
}) =>
|
|
(super.noSuchMethod(
|
|
Invocation.method(#call, [], {#organizationId: organizationId}),
|
|
returnValue:
|
|
_i5.Future<
|
|
_i3.Either<_i6.Failure, List<_i7.TransactionApproval>>
|
|
>.value(
|
|
_FakeEither_1<_i6.Failure, List<_i7.TransactionApproval>>(
|
|
this,
|
|
Invocation.method(#call, [], {
|
|
#organizationId: organizationId,
|
|
}),
|
|
),
|
|
),
|
|
)
|
|
as _i5.Future<
|
|
_i3.Either<_i6.Failure, List<_i7.TransactionApproval>>
|
|
>);
|
|
}
|
|
|
|
/// A class which mocks [GetApprovalById].
|
|
///
|
|
/// See the documentation for Mockito's code generation for more information.
|
|
class MockGetApprovalById extends _i1.Mock implements _i8.GetApprovalById {
|
|
MockGetApprovalById() {
|
|
_i1.throwOnMissingStub(this);
|
|
}
|
|
|
|
@override
|
|
_i2.FinanceWorkflowRepository get repository =>
|
|
(super.noSuchMethod(
|
|
Invocation.getter(#repository),
|
|
returnValue: _FakeFinanceWorkflowRepository_0(
|
|
this,
|
|
Invocation.getter(#repository),
|
|
),
|
|
)
|
|
as _i2.FinanceWorkflowRepository);
|
|
|
|
@override
|
|
_i5.Future<_i3.Either<_i6.Failure, _i7.TransactionApproval>> call(
|
|
String? approvalId,
|
|
) =>
|
|
(super.noSuchMethod(
|
|
Invocation.method(#call, [approvalId]),
|
|
returnValue:
|
|
_i5.Future<
|
|
_i3.Either<_i6.Failure, _i7.TransactionApproval>
|
|
>.value(
|
|
_FakeEither_1<_i6.Failure, _i7.TransactionApproval>(
|
|
this,
|
|
Invocation.method(#call, [approvalId]),
|
|
),
|
|
),
|
|
)
|
|
as _i5.Future<_i3.Either<_i6.Failure, _i7.TransactionApproval>>);
|
|
}
|
|
|
|
/// A class which mocks [ApproveTransaction].
|
|
///
|
|
/// See the documentation for Mockito's code generation for more information.
|
|
class MockApproveTransaction extends _i1.Mock
|
|
implements _i9.ApproveTransaction {
|
|
MockApproveTransaction() {
|
|
_i1.throwOnMissingStub(this);
|
|
}
|
|
|
|
@override
|
|
_i2.FinanceWorkflowRepository get repository =>
|
|
(super.noSuchMethod(
|
|
Invocation.getter(#repository),
|
|
returnValue: _FakeFinanceWorkflowRepository_0(
|
|
this,
|
|
Invocation.getter(#repository),
|
|
),
|
|
)
|
|
as _i2.FinanceWorkflowRepository);
|
|
|
|
@override
|
|
_i5.Future<_i3.Either<_i6.Failure, _i7.TransactionApproval>> call({
|
|
required String? approvalId,
|
|
String? comment,
|
|
}) =>
|
|
(super.noSuchMethod(
|
|
Invocation.method(#call, [], {
|
|
#approvalId: approvalId,
|
|
#comment: comment,
|
|
}),
|
|
returnValue:
|
|
_i5.Future<
|
|
_i3.Either<_i6.Failure, _i7.TransactionApproval>
|
|
>.value(
|
|
_FakeEither_1<_i6.Failure, _i7.TransactionApproval>(
|
|
this,
|
|
Invocation.method(#call, [], {
|
|
#approvalId: approvalId,
|
|
#comment: comment,
|
|
}),
|
|
),
|
|
),
|
|
)
|
|
as _i5.Future<_i3.Either<_i6.Failure, _i7.TransactionApproval>>);
|
|
}
|
|
|
|
/// A class which mocks [RejectTransaction].
|
|
///
|
|
/// See the documentation for Mockito's code generation for more information.
|
|
class MockRejectTransaction extends _i1.Mock implements _i10.RejectTransaction {
|
|
MockRejectTransaction() {
|
|
_i1.throwOnMissingStub(this);
|
|
}
|
|
|
|
@override
|
|
_i2.FinanceWorkflowRepository get repository =>
|
|
(super.noSuchMethod(
|
|
Invocation.getter(#repository),
|
|
returnValue: _FakeFinanceWorkflowRepository_0(
|
|
this,
|
|
Invocation.getter(#repository),
|
|
),
|
|
)
|
|
as _i2.FinanceWorkflowRepository);
|
|
|
|
@override
|
|
_i5.Future<_i3.Either<_i6.Failure, _i7.TransactionApproval>> call({
|
|
required String? approvalId,
|
|
required String? reason,
|
|
}) =>
|
|
(super.noSuchMethod(
|
|
Invocation.method(#call, [], {
|
|
#approvalId: approvalId,
|
|
#reason: reason,
|
|
}),
|
|
returnValue:
|
|
_i5.Future<
|
|
_i3.Either<_i6.Failure, _i7.TransactionApproval>
|
|
>.value(
|
|
_FakeEither_1<_i6.Failure, _i7.TransactionApproval>(
|
|
this,
|
|
Invocation.method(#call, [], {
|
|
#approvalId: approvalId,
|
|
#reason: reason,
|
|
}),
|
|
),
|
|
),
|
|
)
|
|
as _i5.Future<_i3.Either<_i6.Failure, _i7.TransactionApproval>>);
|
|
}
|