Skip to content

Commit

Permalink
ref(#58): adicionar injeção de dependência entre camadas
Browse files Browse the repository at this point in the history
  • Loading branch information
GabrielCostaDeOliveira committed Jan 14, 2025
1 parent 3e32099 commit c2f09a7
Show file tree
Hide file tree
Showing 10 changed files with 53 additions and 20 deletions.
8 changes: 8 additions & 0 deletions lib/core/di/locator.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,8 @@
import 'package:aranduapp/ui/login/di/di.dart';
import 'package:get_it/get_it.dart';

final GetIt locator = GetIt.instance;

void setupLocator() {
setupLoginDI();
}
4 changes: 4 additions & 0 deletions lib/main.dart
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import 'package:aranduapp/config/ThemeApp.dart';
import 'package:aranduapp/core/di/locator.dart';
import 'package:aranduapp/ui/welcome/view/WelcomeView.dart';
import 'package:flutter/material.dart';

Expand All @@ -11,6 +12,9 @@ class MyApp extends StatelessWidget {

@override
Widget build(BuildContext context) {

setupLocator();

return MaterialApp(
theme: ThemeApp.themeData(),
darkTheme: ThemeApp.darkThemeData(),
Expand Down
12 changes: 12 additions & 0 deletions lib/ui/login/di/di.dart
Original file line number Diff line number Diff line change
@@ -0,0 +1,12 @@
import 'package:aranduapp/ui/login/service/login_service.dart';
import 'package:aranduapp/ui/login/viewmodel/login_viewmodel.dart';
import 'package:get_it/get_it.dart';

final GetIt locator = GetIt.instance;

void setupLoginDI() {

locator.registerLazySingleton(() => LoginService());

locator.registerFactory(() => LoginViewModel());
}
Original file line number Diff line number Diff line change
Expand Up @@ -7,7 +7,7 @@ import 'package:aranduapp/ui/login/model/LoginResponse.dart';
import 'package:dio/dio.dart';

class LoginService {
static Future<Response> login(LoginRequest loginRequest) async {
Future<Response> login(LoginRequest loginRequest) async {
Log.d('${loginRequest.email} ${loginRequest.password}');

Response response = await BaseApi.getInstance(auth: false).post(
Expand All @@ -27,7 +27,7 @@ class LoginService {
return response;
}

static Future<void> validateToken() async {
Future<void> validateToken() async {
await AuthService().refreshToken();
}
}
8 changes: 4 additions & 4 deletions lib/ui/login/view/login_view.dart
Original file line number Diff line number Diff line change
Expand Up @@ -3,10 +3,11 @@ import 'package:aranduapp/ui/navbar/view/navBarView.dart';
import 'package:aranduapp/ui/shared/TextAndLink.dart';
import 'package:aranduapp/ui/shared/requestbutton.dart';
import 'package:flutter/material.dart';
import 'package:get_it/get_it.dart';
import 'package:provider/provider.dart';
import 'package:font_awesome_flutter/font_awesome_flutter.dart';

import 'package:aranduapp/ui/login/viewModel/login_view_model.dart';
import 'package:aranduapp/ui/login/viewmodel/login_viewmodel.dart';

import 'package:aranduapp/ui/recover_account/view/recover_account_view.dart';
import 'package:aranduapp/ui/register_account/view/register_account_view.dart';
Expand All @@ -19,11 +20,10 @@ import 'package:aranduapp/ui/shared/OrDivider.dart';

class Login extends StatelessWidget {
const Login({super.key});

@override
Widget build(BuildContext context) {
return ChangeNotifierProvider(
create: (context) => LoginViewModel(),
return ChangeNotifierProvider<LoginViewModel>.value(
value: GetIt.instance<LoginViewModel>(),
child: const LoginScreen(),
);
}
Expand Down
Original file line number Diff line number Diff line change
@@ -1,10 +1,10 @@
import 'package:aranduapp/core/log/Log.dart';
import 'package:aranduapp/core/state/command.dart';
import 'package:aranduapp/ui/navbar/view/navBarView.dart';
import 'package:async/async.dart';
import 'package:flutter/material.dart';
import 'package:get_it/get_it.dart';
import 'package:local_auth/local_auth.dart';
import 'package:aranduapp/ui/login/service/LoginService.dart';
import 'package:aranduapp/ui/login/service/login_service.dart';
import 'package:aranduapp/ui/login/model/LoginRequest.dart';

class LoginViewModel extends ChangeNotifier {
Expand Down Expand Up @@ -32,14 +32,14 @@ class LoginViewModel extends ChangeNotifier {
return Result.error(Exception('Valores inválidos'));
}

await LoginService.login(
await GetIt.instance<LoginService>().login(
LoginRequest(emailController.text, passwordController.text));

return Result.value(null);
}

Future<Result<void>> validateToken() async {
await LoginService.validateToken();
await GetIt.instance<LoginService>().validateToken();

return Result.value(null);
}
Expand Down
8 changes: 8 additions & 0 deletions pubspec.lock
Original file line number Diff line number Diff line change
Expand Up @@ -341,6 +341,14 @@ packages:
url: "https://pub.dev"
source: hosted
version: "4.0.0"
get_it:
dependency: "direct main"
description:
name: get_it
sha256: f126a3e286b7f5b578bf436d5592968706c4c1de28a228b870ce375d9f743103
url: "https://pub.dev"
source: hosted
version: "8.0.3"
glob:
dependency: transitive
description:
Expand Down
1 change: 1 addition & 0 deletions pubspec.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -47,6 +47,7 @@ dependencies:
mockito: ^5.4.4
build_runner: ^2.4.13
async: ^2.11.0
get_it: ^8.0.3


dev_dependencies:
Expand Down
18 changes: 9 additions & 9 deletions test/ui/login/view/login_view_test.dart
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
import 'package:aranduapp/core/state/command.dart';
import 'package:aranduapp/ui/login/view/login_view.dart';
import 'package:aranduapp/ui/login/viewModel/login_view_model.dart';
import 'package:aranduapp/ui/login/viewmodel/login_viewmodel.dart';
import 'package:aranduapp/ui/navbar/view/navBarView.dart';
import 'package:aranduapp/ui/shared/TextEmail.dart';
import 'package:aranduapp/ui/shared/TextPassword.dart';
import 'package:async/async.dart';
import 'package:flutter/material.dart';
import 'package:flutter_test/flutter_test.dart';
import 'package:get_it/get_it.dart';
import 'package:mockito/annotations.dart';
import 'package:mockito/mockito.dart';
import 'package:provider/provider.dart';

@GenerateNiceMocks([MockSpec<LoginViewModel>(), MockSpec<Command0>()])
import 'login_view_test.mocks.dart';
Expand All @@ -19,7 +19,7 @@ void main() {
late MockCommand0 mockLoginCommand;
late MockCommand0 mockValidadeTokenCommand;

setUp(() {
setUp(() async {
mockViewModel = MockLoginViewModel();
when(mockViewModel.formKey).thenReturn(GlobalKey<FormState>());
when(mockViewModel.emailController).thenReturn(TextEditingController());
Expand All @@ -38,14 +38,14 @@ void main() {
when(mockValidadeTokenCommand.running).thenReturn(false);
when(mockValidadeTokenCommand.isError).thenReturn(false);
when(mockValidadeTokenCommand.isOk).thenReturn(false);

await GetIt.instance.reset();
GetIt.I.registerLazySingleton<LoginViewModel>(() => mockViewModel);
});

Widget createLoginScreen() {
return ChangeNotifierProvider<LoginViewModel>.value(
value: mockViewModel,
child: const MaterialApp(
home: LoginScreen(),
),
return const MaterialApp(
home: Login(),
);
}

Expand Down Expand Up @@ -125,6 +125,6 @@ void main() {
});

testWidgets('Displays error when login fails', (WidgetTester tester) async {
//TODO:
//TODO:
});
}
2 changes: 1 addition & 1 deletion test/ui/login/view/login_view_test.mocks.dart
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
import 'dart:async' as _i6;

import 'package:aranduapp/core/state/command.dart' as _i2;
import 'package:aranduapp/ui/login/viewModel/login_view_model.dart' as _i5;
import 'package:aranduapp/ui/login/viewmodel/login_viewmodel.dart' as _i5;
import 'package:async/async.dart' as _i4;
import 'package:flutter/material.dart' as _i3;
import 'package:mockito/mockito.dart' as _i1;
Expand Down

0 comments on commit c2f09a7

Please sign in to comment.