From 1a604bfb5a630e931fb519a504eaef36c41708da Mon Sep 17 00:00:00 2001 From: poka Date: Tue, 27 Apr 2021 11:51:14 +0200 Subject: [PATCH] Improve test mecanic; Continue test until 2nd derivation view --- android/app/src/main/AndroidManifest.xml | 3 +- lib/screens/myWallets/walletsHome.dart | 2 + lib/screens/onBoarding/12.dart | 3 +- lib/screens/onBoarding/7.dart | 1 + test_driver/app_test.dart | 165 ++++++++++++++--------- 5 files changed, 105 insertions(+), 69 deletions(-) diff --git a/android/app/src/main/AndroidManifest.xml b/android/app/src/main/AndroidManifest.xml index 73c3d1d..3600761 100644 --- a/android/app/src/main/AndroidManifest.xml +++ b/android/app/src/main/AndroidManifest.xml @@ -9,11 +9,12 @@ - getText(String text) async { + return await driver.getText(find.byValueKey( + text, + )); + } + test('OnBoarding - Open wallets management', ( {timeout: const Duration(seconds: 2)}) async { // await driver.runUnsynchronized(() async { // Needed if we want to manage async drivers @@ -48,12 +60,12 @@ void main() { test('OnBoarding - Go to create restore sentance', ( {timeout: const Duration(seconds: 5)}) async { - await driver.tap(find.byValueKey('goStep1')); - await driver.tap(find.byValueKey('goStep2')); - await driver.tap(find.byValueKey('goStep3')); - await driver.tap(find.byValueKey('goStep4')); - await driver.tap(find.byValueKey('goStep5')); - await driver.tap(find.byValueKey('goStep6')); + await tapOn('goStep1'); + await tapOn('goStep2'); + await tapOn('goStep3'); + await tapOn('goStep4'); + await tapOn('goStep5'); + await tapOn('goStep6'); expect( await driver.getText(find.byValueKey( @@ -64,95 +76,114 @@ void main() { test('OnBoarding - Generate sentance and confirme it', ( {timeout: const Duration(seconds: 5)}) async { - await driver.tap(find.byValueKey('goStep7')); + await tapOn('goStep7'); - print('THE SECOND WORD IS:'); - - while (await driver.getText(find.byValueKey( - 'word1', - )) == - '...') { + while (await getText('word1') == '...') { print('Waiting for Mnemonic generation...'); - await Future.delayed(const Duration(seconds: 1)); + await Future.delayed(const Duration(milliseconds: 100)); } - List words = [for (var i = 1; i <= 13; i += 1) i]; + Future selectWord() async { + List words = [for (var i = 1; i <= 13; i += 1) i]; - for (var j = 1; j < 13; j++) { - words[j] = await driver.getText(find.byValueKey( - 'word$j', - )); + for (var j = 1; j < 13; j++) { + words[j] = await getText('word$j'); + } + expect( + await getText('step7'), "C'est le moment de noter votre phrase !"); + + await tapOn('goStep8'); + await Future.delayed(const Duration(milliseconds: 50)); + + String goodWord = words[int.parse( + await getText('askedWord'), + )]; + + // Enter the expected word + await driver.enterText(goodWord); + + // Check if word is valid + await driver.waitFor(find.text("C'est le bon mot !")); + + // Continue onboarding workflow + await tapOn('goStep9'); } - // print word 1, 2 and 12 - // print(words[1] + words[2] + words[12]); + await selectWord(); - expect( - await driver.getText(find.byValueKey( - 'step7', - )), - "C'est le moment de noter votre phrase !"); + //Go back 2 times to mnemonic generation screen + await goBack(); + await goBack(); + await Future.delayed(const Duration(milliseconds: 100)); - await driver.tap(find.byValueKey('goStep8')); + // Generate 3 times mnemonic + await tapOn('generateMnemonic'); + await tapOn('generateMnemonic'); + await tapOn('generateMnemonic'); + await Future.delayed(const Duration(milliseconds: 500)); - final String goodWord = words[int.parse( - await driver.getText( - find.byValueKey( - 'askedWord', - ), - ), - )]; - - await driver.enterText(goodWord); - - await driver.tap(find.byValueKey('goStep9')); + await selectWord(); }); test('OnBoarding - Generate secret code and confirm it', ( {timeout: const Duration(seconds: 5)}) async { - expect( - await driver.getText(find.byValueKey( - 'step9', - )), + expect(await getText('step9'), "Super !\n\nJe vais maintenant créer votre code secret. \n\nVotre code secret chiffre votre trousseau de clefs, ce qui le rend inutilisable par d’autres, par exemple si vous perdez votre téléphone ou si on vous le vole."); - await driver.tap(find.byValueKey('goStep10')); - await driver.tap(find.byValueKey('goStep11')); + await tapOn('goStep10'); + await tapOn('goStep11'); - while (await driver.getText(find.byValueKey( - 'generatedPin', - )) == - '') { + while (await getText('generatedPin') == '') { print('Waiting for pin code generation...'); - await Future.delayed(const Duration(seconds: 1)); + await Future.delayed(const Duration(milliseconds: 100)); } - final pinCode = await driver.getText( - find.byValueKey( - 'generatedPin', - ), - ); + final pinCode = await getText('generatedPin'); - await driver.tap(find.byValueKey('goStep12')); - await Future.delayed(const Duration(seconds: 1)); + await tapOn('goStep12'); + await Future.delayed(const Duration(milliseconds: 300)); + // //Enter bad secret code + // await driver.enterText('abcde'); + // await tapOn('formKey'); + // await Future.delayed(const Duration(milliseconds: 4000)); + // await tapOn('formKey2'); + + //Enter good secret code await driver.enterText(pinCode); - expect( - await driver.getText(find.byValueKey( - 'step13', - )), + expect(await getText('step13'), "Top !\n\nVotre trousseau de clef et votre portefeuille ont été créés avec un immense succès.\n\nFélicitations !"); }); - test('OnBoarding - Create a derivation and display it', ( + test('My wallets - Create a derivation and display it', ( {timeout: const Duration(seconds: 5)}) async { - await driver.tap(find.byValueKey('goWalletHome')); + await tapOn('goWalletHome'); - expect( - await driver.getText(find.byValueKey( - 'myWallets', - )), - "Mes portefeuilles"); + expect(await getText('myWallets'), "Mes portefeuilles"); + await Future.delayed(const Duration(milliseconds: 300)); + + // Add a second derivation + await tapOn('addDerivation'); + await Future.delayed(const Duration(milliseconds: 50)); + + await driver.enterText('Derivation 2'); + + await tapOn('validDerivation'); + await Future.delayed(const Duration(milliseconds: 300)); + + await driver.tap(find.text('Derivation 2')); + + // Wait 3 seconds at the end + await Future.delayed(const Duration(seconds: 3)); }); }); } + +// Function to go back to previous screen +Future goBack() async { + await Process.run( + 'adb', + ['shell', 'input', 'keyevent', 'KEYCODE_BACK'], + runInShell: true, + ); +}