-
Notifications
You must be signed in to change notification settings - Fork 21
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #992 from Prime-Holding/tests/onboarding-goldens
Tests/onboarding goldens
- Loading branch information
Showing
42 changed files
with
569 additions
and
7 deletions.
There are no files selected for viewing
4 changes: 2 additions & 2 deletions
4
...emplates/bricks/feature_onboarding/__brick__/bin/server/controllers/users_controller.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
30 changes: 30 additions & 0 deletions
30
.../feature_onboarding_email_confirmation/factory/onboarding_email_confirmation_factory.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
{{> licence.dart }} | ||
|
||
import 'package:flutter/material.dart'; | ||
import 'package:flutter_rx_bloc/flutter_rx_bloc.dart'; | ||
import 'package:provider/provider.dart'; | ||
import 'package:{{project_name}}/base/models/errors/error_model.dart'; | ||
import 'package:{{project_name}}/feature_onboarding_email_confirmation/blocs/onboarding_email_confirmation_bloc.dart'; | ||
import 'package:{{project_name}}/feature_onboarding_email_confirmation/views/onboarding_email_confirmation_page.dart'; | ||
|
||
import '../mock/onboarding_email_confirmation_mock.dart'; | ||
|
||
/// Change the parameters according the the needs of the test | ||
Widget onboardingEmailConfirmationFactory({ | ||
bool? isLoading, | ||
ErrorModel? errors, | ||
String? email, | ||
bool? isSendNewLinkActive, | ||
}) => | ||
Scaffold( | ||
body: MultiProvider(providers: [ | ||
RxBlocProvider<OnboardingEmailConfirmationBlocType>.value( | ||
value: onboardingEmailConfirmationMockFactory( | ||
isLoading: isLoading, | ||
errors: errors, | ||
email: email, | ||
isSendNewLinkActive: isSendNewLinkActive, | ||
), | ||
), | ||
], child: const OnboardingEmailConfirmationPage()), | ||
); |
29 changes: 29 additions & 0 deletions
29
...est/feature_onboarding_email_confirmation/factory/onboarding_email_confirmed_factory.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
{{> licence.dart }} | ||
|
||
import 'package:flutter/material.dart'; | ||
import 'package:flutter_rx_bloc/flutter_rx_bloc.dart'; | ||
import 'package:provider/provider.dart'; | ||
import 'package:{{project_name}}/base/models/errors/error_model.dart'; | ||
import 'package:{{project_name}}/base/models/user_model.dart'; | ||
import 'package:{{project_name}}/feature_onboarding_email_confirmation/blocs/onboarding_email_confirmed_bloc.dart'; | ||
import 'package:{{project_name}}/feature_onboarding_email_confirmation/views/onboarding_email_confirmed_page.dart'; | ||
|
||
import '../mock/onboarding_email_confirmed_mock.dart'; | ||
|
||
/// Change the parameters according the the needs of the test | ||
Widget onboardingEmailConfirmedFactory({ | ||
bool? isLoading, | ||
ErrorModel? errors, | ||
UserModel? data, | ||
}) => | ||
Scaffold( | ||
body: MultiProvider(providers: [ | ||
RxBlocProvider<OnboardingEmailConfirmedBlocType>.value( | ||
value: onboardingEmailConfirmedMockFactory( | ||
isLoading: isLoading, | ||
errors: errors, | ||
data: data, | ||
), | ||
), | ||
], child: const OnboardingEmailConfirmedPage()), | ||
); |
56 changes: 56 additions & 0 deletions
56
..._/test/feature_onboarding_email_confirmation/mock/onboarding_email_confirmation_mock.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,56 @@ | ||
{{> licence.dart }} | ||
|
||
import 'package:mockito/annotations.dart'; | ||
import 'package:mockito/mockito.dart'; | ||
import 'package:rxdart/rxdart.dart'; | ||
import 'package:{{project_name}}/base/models/errors/error_model.dart'; | ||
import 'package:{{project_name}}/feature_onboarding_email_confirmation/blocs/onboarding_email_confirmation_bloc.dart'; | ||
|
||
import 'onboarding_email_confirmation_mock.mocks.dart'; | ||
|
||
@GenerateMocks([ | ||
OnboardingEmailConfirmationBlocStates, | ||
OnboardingEmailConfirmationBlocEvents, | ||
OnboardingEmailConfirmationBlocType | ||
]) | ||
OnboardingEmailConfirmationBlocType onboardingEmailConfirmationMockFactory({ | ||
bool? isLoading, | ||
ErrorModel? errors, | ||
String? email, | ||
bool? isSendNewLinkActive, | ||
}) { | ||
final blocMock = MockOnboardingEmailConfirmationBlocType(); | ||
final eventsMock = MockOnboardingEmailConfirmationBlocEvents(); | ||
final statesMock = MockOnboardingEmailConfirmationBlocStates(); | ||
|
||
when(blocMock.events).thenReturn(eventsMock); | ||
when(blocMock.states).thenReturn(statesMock); | ||
|
||
final isLoadingState = isLoading != null | ||
? Stream.value(isLoading).shareReplay(maxSize: 1) | ||
: const Stream<bool>.empty(); | ||
|
||
final errorsState = errors != null | ||
? Stream.value(errors).shareReplay(maxSize: 1) | ||
: const Stream<ErrorModel>.empty(); | ||
|
||
final openMailAppState = const Stream<void>.empty().publishReplay(maxSize: 1) | ||
..connect(); | ||
|
||
final emailState = email != null | ||
? Stream.value(email).shareReplay(maxSize: 1) | ||
: const Stream<String>.empty(); | ||
|
||
final isSendNewLinkActiveState = isSendNewLinkActive != null | ||
? Stream.value(isSendNewLinkActive).shareReplay(maxSize: 1) | ||
: const Stream<bool>.empty(); | ||
|
||
when(statesMock.isLoading).thenAnswer((_) => isLoadingState); | ||
when(statesMock.errors).thenAnswer((_) => errorsState); | ||
when(statesMock.openMailApp).thenAnswer((_) => openMailAppState); | ||
when(statesMock.email).thenAnswer((_) => emailState); | ||
when(statesMock.isSendNewLinkActive) | ||
.thenAnswer((_) => isSendNewLinkActiveState); | ||
|
||
return blocMock; | ||
} |
51 changes: 51 additions & 0 deletions
51
...ck__/test/feature_onboarding_email_confirmation/mock/onboarding_email_confirmed_mock.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,51 @@ | ||
{{> licence.dart }} | ||
|
||
import 'package:mockito/annotations.dart'; | ||
import 'package:mockito/mockito.dart'; | ||
import 'package:rxdart/rxdart.dart'; | ||
import 'package:{{project_name}}/base/models/errors/error_model.dart'; | ||
import 'package:{{project_name}}/base/models/user_model.dart'; | ||
import 'package:{{project_name}}/feature_onboarding_email_confirmation/blocs/onboarding_email_confirmed_bloc.dart'; | ||
|
||
import 'onboarding_email_confirmed_mock.mocks.dart'; | ||
|
||
@GenerateMocks([ | ||
OnboardingEmailConfirmedBlocStates, | ||
OnboardingEmailConfirmedBlocEvents, | ||
OnboardingEmailConfirmedBlocType | ||
]) | ||
OnboardingEmailConfirmedBlocType onboardingEmailConfirmedMockFactory({ | ||
bool? isLoading, | ||
ErrorModel? errors, | ||
UserModel? data, | ||
}) { | ||
final blocMock = MockOnboardingEmailConfirmedBlocType(); | ||
final eventsMock = MockOnboardingEmailConfirmedBlocEvents(); | ||
final statesMock = MockOnboardingEmailConfirmedBlocStates(); | ||
|
||
when(blocMock.events).thenReturn(eventsMock); | ||
when(blocMock.states).thenReturn(statesMock); | ||
|
||
final isLoadingState = isLoading != null | ||
? Stream.value(isLoading).shareReplay(maxSize: 1) | ||
: const Stream<bool>.empty(); | ||
|
||
final errorsState = errors != null | ||
? Stream.value(errors).shareReplay(maxSize: 1) | ||
: const Stream<ErrorModel>.empty(); | ||
|
||
final dataState = (data != null | ||
? Stream.value(data) | ||
: const Stream<UserModel>.empty()) | ||
.publishReplay(maxSize: 1) | ||
..connect(); | ||
final onRoutingState = const Stream<void>.empty().publishReplay(maxSize: 1) | ||
..connect(); | ||
|
||
when(statesMock.isLoading).thenAnswer((_) => isLoadingState); | ||
when(statesMock.errors).thenAnswer((_) => errorsState); | ||
when(statesMock.data).thenAnswer((_) => dataState); | ||
when(statesMock.onRouting).thenAnswer((_) => onRoutingState); | ||
|
||
return blocMock; | ||
} |
24 changes: 24 additions & 0 deletions
24
...bricks/feature_onboarding/__brick__/test/feature_onboarding_email_confirmation/stubs.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,24 @@ | ||
{{> licence.dart }} | ||
|
||
import 'package:{{project_name}}/base/models/confirmed_credentials_model.dart'; | ||
import 'package:{{project_name}}/base/models/user_model.dart'; | ||
import 'package:{{project_name}}/base/models/user_role.dart'; | ||
|
||
class Stubs { | ||
static const email = 'email@example.com'; | ||
static const phone = '1234567890'; | ||
static const id = '1a2b3c'; | ||
|
||
static final confirmedCredentialsModel = ConfirmedCredentialsModel( | ||
email: true, | ||
phone: true, | ||
); | ||
|
||
static final user = UserModel( | ||
id: id, | ||
email: email, | ||
phoneNumber: phone, | ||
role: UserRole.user, | ||
confirmedCredentials: confirmedCredentialsModel, | ||
); | ||
} |
Binary file added
BIN
+472 KB
...confirmation/view/goldens/ci/dark_theme/onboarding_email_confirmation_error.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+375 KB
...nfirmation/view/goldens/ci/dark_theme/onboarding_email_confirmation_loading.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+379 KB
...nfirmation/view/goldens/ci/dark_theme/onboarding_email_confirmation_success.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+290 KB
...il_confirmation/view/goldens/ci/dark_theme/onboarding_email_confirmed_empty.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+187 KB
..._confirmation/view/goldens/ci/dark_theme/onboarding_email_confirmed_loading.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+296 KB
..._confirmation/view/goldens/ci/dark_theme/onboarding_email_confirmed_success.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+309 KB
...onfirmation/view/goldens/ci/light_theme/onboarding_email_confirmation_error.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+396 KB
...firmation/view/goldens/ci/light_theme/onboarding_email_confirmation_loading.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+403 KB
...firmation/view/goldens/ci/light_theme/onboarding_email_confirmation_success.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+298 KB
...l_confirmation/view/goldens/ci/light_theme/onboarding_email_confirmed_empty.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+194 KB
...confirmation/view/goldens/ci/light_theme/onboarding_email_confirmed_loading.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
Binary file added
BIN
+303 KB
...confirmation/view/goldens/ci/light_theme/onboarding_email_confirmed_success.png
Loading
Sorry, something went wrong. Reload?
Sorry, we cannot display this file.
Sorry, this file is invalid so it cannot be displayed.
32 changes: 32 additions & 0 deletions
32
...feature_onboarding_email_confirmation/view/onboarding_email_confirmation_golden_test.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,32 @@ | ||
{{> licence.dart }} | ||
|
||
import 'package:{{project_name}}/base/models/errors/error_model.dart'; | ||
|
||
import '../../helpers/golden_helper.dart'; | ||
import '../factory/onboarding_email_confirmation_factory.dart'; | ||
|
||
void main() { | ||
runGoldenTests([ | ||
buildScenario( | ||
scenario: 'onboarding_email_confirmation_success', | ||
widget: onboardingEmailConfirmationFactory(), | ||
), | ||
buildScenario( | ||
scenario: 'onboarding_email_confirmation_loading', | ||
customPumpBeforeTest: (tester) => | ||
tester.pump(const Duration(microseconds: 350)), | ||
widget: onboardingEmailConfirmationFactory( | ||
isLoading: true, | ||
email: 'test@example.com', | ||
), | ||
), | ||
buildScenario( | ||
scenario: 'onboarding_email_confirmation_error', | ||
widget: onboardingEmailConfirmationFactory( | ||
errors: UnknownErrorModel( | ||
exception: Exception('Something went wrong'), | ||
), | ||
), | ||
), | ||
]); | ||
} |
30 changes: 30 additions & 0 deletions
30
...st/feature_onboarding_email_confirmation/view/onboarding_email_confirmed_golden_test.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
{{> licence.dart }} | ||
|
||
import '../../helpers/golden_helper.dart'; | ||
import '../factory/onboarding_email_confirmed_factory.dart'; | ||
import '../stubs.dart'; | ||
|
||
void main() { | ||
runGoldenTests([ | ||
buildScenario( | ||
customPumpBeforeTest: (widgetTester) => | ||
widgetTester.pump(const Duration(milliseconds: 350)), | ||
scenario: 'onboarding_email_confirmed_empty', | ||
widget: onboardingEmailConfirmedFactory(), | ||
), | ||
buildScenario( | ||
customPumpBeforeTest: (widgetTester) => | ||
widgetTester.pump(const Duration(milliseconds: 350)), | ||
scenario: 'onboarding_email_confirmed_success', | ||
widget: onboardingEmailConfirmedFactory( | ||
data: Stubs.user, | ||
), | ||
), | ||
buildScenario( | ||
scenario: 'onboarding_email_confirmed_loading', | ||
widget: onboardingEmailConfirmedFactory( | ||
isLoading: true, | ||
), | ||
), | ||
]); | ||
} |
30 changes: 30 additions & 0 deletions
30
.../test/feature_onboarding_phone_confirmation/factory/onboarding_phone_confirm_factory.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,30 @@ | ||
{{> licence.dart }} | ||
|
||
import 'package:flutter/material.dart'; | ||
import 'package:flutter_rx_bloc/flutter_rx_bloc.dart'; | ||
import 'package:provider/provider.dart'; | ||
import 'package:{{project_name}}/base/models/errors/error_model.dart'; | ||
|
||
import 'package:{{project_name}}/feature_onboarding_phone_confirmation/blocs/onboarding_phone_confirm_bloc.dart'; | ||
import 'package:{{project_name}}/feature_onboarding_phone_confirmation/views/onboarding_phone_confirm_page.dart'; | ||
import 'package:widget_toolkit_otp/widget_toolkit_otp.dart'; | ||
|
||
import '../mock/onboarding_phone_confirm_mock.dart'; | ||
import '../mock/onboarding_phone_sms_code_service_mock.dart'; | ||
|
||
/// Change the parameters according the the needs of the test | ||
Widget onboardingPhoneConfirmFactory({ | ||
ErrorModel? errors, | ||
}) => | ||
Scaffold( | ||
body: MultiProvider(providers: [ | ||
Provider<SmsCodeService>.value( | ||
value: createSmsCodeService(), | ||
), | ||
RxBlocProvider<OnboardingPhoneConfirmBlocType>.value( | ||
value: onboardingPhoneConfirmMockFactory( | ||
errors: errors, | ||
), | ||
), | ||
], child: const OnboardingPhoneConfirmPage()), | ||
); |
36 changes: 36 additions & 0 deletions
36
..._brick__/test/feature_onboarding_phone_confirmation/factory/onboarding_phone_factory.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,36 @@ | ||
{{> licence.dart }} | ||
|
||
import 'package:flutter/material.dart'; | ||
import 'package:flutter_rx_bloc/flutter_rx_bloc.dart'; | ||
import 'package:provider/provider.dart'; | ||
import 'package:{{project_name}}/base/models/country_code_model.dart'; | ||
import 'package:{{project_name}}/base/models/errors/error_model.dart'; | ||
import 'package:{{project_name}}/base/models/user_model.dart'; | ||
import 'package:{{project_name}}/feature_onboarding_phone_confirmation/blocs/onboarding_phone_bloc.dart'; | ||
import 'package:{{project_name}}/feature_onboarding_phone_confirmation/views/onboarding_phone_page.dart'; | ||
|
||
import '../mock/onboarding_phone_mock.dart'; | ||
|
||
/// Change the parameters according the the needs of the test | ||
Widget onboardingPhoneFactory({ | ||
bool? isLoading, | ||
UserModel? phoneSubmitted, | ||
CountryCodeModel? countryCode, | ||
String? phoneNumber, | ||
ErrorModel? errors, | ||
bool? showErrors, | ||
}) => | ||
Scaffold( | ||
body: MultiProvider(providers: [ | ||
RxBlocProvider<OnboardingPhoneBlocType>.value( | ||
value: onboardingPhoneMockFactory( | ||
isLoading: isLoading, | ||
phoneSubmitted: phoneSubmitted, | ||
countryCode: countryCode, | ||
phoneNumber: phoneNumber, | ||
errors: errors, | ||
showErrors: showErrors, | ||
), | ||
), | ||
], child: const OnboardingPhonePage()), | ||
); |
37 changes: 37 additions & 0 deletions
37
...rick__/test/feature_onboarding_phone_confirmation/mock/onboarding_phone_confirm_mock.dart
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,37 @@ | ||
{{> licence.dart }} | ||
|
||
import 'package:mockito/annotations.dart'; | ||
import 'package:mockito/mockito.dart'; | ||
import 'package:rxdart/rxdart.dart'; | ||
import 'package:{{project_name}}/base/models/errors/error_model.dart'; | ||
import 'package:{{project_name}}/feature_onboarding_phone_confirmation/blocs/onboarding_phone_confirm_bloc.dart'; | ||
|
||
import 'onboarding_phone_confirm_mock.mocks.dart'; | ||
|
||
@GenerateMocks([ | ||
OnboardingPhoneConfirmBlocStates, | ||
OnboardingPhoneConfirmBlocEvents, | ||
OnboardingPhoneConfirmBlocType | ||
]) | ||
OnboardingPhoneConfirmBlocType onboardingPhoneConfirmMockFactory({ | ||
ErrorModel? errors, | ||
}) { | ||
final blocMock = MockOnboardingPhoneConfirmBlocType(); | ||
final eventsMock = MockOnboardingPhoneConfirmBlocEvents(); | ||
final statesMock = MockOnboardingPhoneConfirmBlocStates(); | ||
|
||
when(blocMock.events).thenReturn(eventsMock); | ||
when(blocMock.states).thenReturn(statesMock); | ||
|
||
final errorsState = errors != null | ||
? Stream.value(errors).shareReplay(maxSize: 1) | ||
: const Stream<ErrorModel>.empty(); | ||
|
||
final onRoutingState = const Stream<void>.empty().publishReplay(maxSize: 1) | ||
..connect(); | ||
|
||
when(statesMock.errors).thenAnswer((_) => errorsState); | ||
when(statesMock.onRouting).thenAnswer((_) => onRoutingState); | ||
|
||
return blocMock; | ||
} |
Oops, something went wrong.