diff --git a/integration_test/keyless_test.dart b/integration_test/keyless_test.dart index 039386e3a..b01342c60 100644 --- a/integration_test/keyless_test.dart +++ b/integration_test/keyless_test.dart @@ -36,21 +36,22 @@ void main() { }); group('Settings', () { appTestKeyless('Click through all Themes', (WidgetTester tester) async { - var settingDrawerButton = find.byKey(settingDrawerIcon).hitTestable(); - await tester.tap(settingDrawerButton); - await tester.longWait(); + await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); + await tester.shortWait(); + await tester.tap(find.byKey(settingDrawerIcon).hitTestable()); + await tester.shortWait(); await tester.tap(find.byKey(themeModeSetting)); - await tester.longWait(); + await tester.shortWait(); await tester .tap(find.byKey(themeModeOption(ThemeMode.light)).hitTestable()); await tester.longWait(); await tester.tap(find.byKey(themeModeSetting)); - await tester.longWait(); + await tester.shortWait(); await tester .tap(find.byKey(themeModeOption(ThemeMode.dark)).hitTestable()); await tester.longWait(); await tester.tap(find.byKey(themeModeSetting)); - await tester.longWait(); + await tester.shortWait(); await tester .tap(find.byKey(themeModeOption(ThemeMode.system)).hitTestable()); await tester.longWait(); @@ -60,6 +61,8 @@ void main() { var helpDrawerButton = find.byKey(helpDrawerIcon).hitTestable(); appTestKeyless('Check Licenses view', (WidgetTester tester) async { + await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); + await tester.shortWait(); await tester.tap(helpDrawerButton); await tester.shortWait(); var licensesButtonText = find.byKey(licensesButton).hitTestable(); @@ -70,8 +73,10 @@ void main() { }); group('Opening of URLs', () { appTestKeyless('TOS link', (WidgetTester tester) async { + await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); + await tester.shortWait(); await tester.tap(helpDrawerButton); - await tester.longWait(); + await tester.shortWait(); if (isAndroid) { expect(find.byKey(tosButton).hitTestable(), findsOneWidget); } else { @@ -80,8 +85,10 @@ void main() { } }); appTestKeyless('Privacy link', (WidgetTester tester) async { + await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); + await tester.shortWait(); await tester.tap(helpDrawerButton); - await tester.longWait(); + await tester.shortWait(); if (isAndroid) { expect(find.byKey(privacyButton).hitTestable(), findsOneWidget); } else { @@ -90,8 +97,10 @@ void main() { } }); appTestKeyless('Feedback link', (WidgetTester tester) async { + await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); + await tester.shortWait(); await tester.tap(helpDrawerButton); - await tester.longWait(); + await tester.shortWait(); if (isAndroid) { expect(find.byKey(userGuideButton).hitTestable(), findsOneWidget); } else { @@ -100,6 +109,8 @@ void main() { } }); appTestKeyless('Help link', (WidgetTester tester) async { + await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); + await tester.shortWait(); await tester.tap(helpDrawerButton); await tester.longWait(); if (isAndroid) { @@ -113,14 +124,18 @@ void main() { group('Troubleshooting', () { appTestKeyless('Diagnostics Button', skip: isAndroid, (WidgetTester tester) async { + await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); + await tester.shortWait(); await tester.tap(helpDrawerButton); - await tester.longWait(); + await tester.shortWait(); await tester.tap(find.byKey(diagnosticsChip).hitTestable()); await tester.longWait(); }); appTestKeyless('Log button', (WidgetTester tester) async { + await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); + await tester.shortWait(); await tester.tap(helpDrawerButton); - await tester.longWait(); + await tester.shortWait(); await tester.tap(find.byKey(logChip).hitTestable()); await tester.longWait(); }); diff --git a/integration_test/management_test.dart b/integration_test/management_test.dart index 72a03c5d5..7dba02ae6 100644 --- a/integration_test/management_test.dart +++ b/integration_test/management_test.dart @@ -17,245 +17,288 @@ @Tags(['desktop', 'management']) library; -import 'package:flutter/material.dart'; import 'package:flutter_test/flutter_test.dart'; import 'package:integration_test/integration_test.dart'; -import 'package:yubico_authenticator/app/views/keys.dart' as app_keys; -import 'package:yubico_authenticator/management/views/keys.dart' - as management_keys; +import 'package:yubico_authenticator/management/views/keys.dart'; import 'utils/test_util.dart'; -Key _getCapabilityWidgetKey(bool isUsb, String name) => - Key('management.keys.capability.${isUsb ? 'usb' : 'nfc'}.$name'); - -Future _getCapabilityWidget(Key key) async { - return find.byKey(key).hitTestable().evaluate().single.widget as FilterChip; -} +// Key _getCapabilityWidgetKey(bool isUsb, String name) => +// Key('management.keys.capability.${isUsb ? 'usb' : 'nfc'}.$name'); +// +// Future _getCapabilityWidget(Key key) async { +// return find.byKey(key).hitTestable().evaluate().single.widget as FilterChip; +// } void main() { var binding = IntegrationTestWidgetsFlutterBinding.ensureInitialized(); binding.framePolicy = LiveTestWidgetsFlutterBindingFramePolicy.fullyLive; - group('Management UI tests', () { - appTest('Drawer items exist', (WidgetTester tester) async { - await tester.openDrawer(); - expect(find.byKey(app_keys.managementAppDrawer).hitTestable(), - findsOneWidget); - }); - }); - group('Toggle Applications on key', () { - appTest('Toggle OTP', (WidgetTester tester) async { - await tester.openManagementScreen(); - - // find USB OTP capability - var usbOtpKey = _getCapabilityWidgetKey(true, 'OTP'); - var otpChip = await _getCapabilityWidget(usbOtpKey); - if (otpChip != null) { - // we expect OTP to be enabled on the Key for this test - expect(otpChip.selected, equals(true)); - await tester.tap(find.byKey(usbOtpKey)); - await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - expect(find.byKey(management_keys.screenKey), findsNothing); - await tester.shortWait(); - } - await tester.openManagementScreen(); - if (otpChip != null) { - await tester.tap(find.byKey(usbOtpKey)); - await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - - // no management screen visible now - expect(find.byKey(management_keys.screenKey), findsNothing); - await tester.longWait(); - } - }); - appTest('Toggle PIV', (WidgetTester tester) async { - await tester.openManagementScreen(); - var usbPivKey = _getCapabilityWidgetKey(true, 'PIV'); - var pivChip = await _getCapabilityWidget(usbPivKey); - - // find USB PIV capability - if (pivChip != null) { - expect(pivChip.selected, equals(true)); - await tester.tap(find.byKey(usbPivKey)); - await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - expect(find.byKey(management_keys.screenKey), findsNothing); - await tester.shortWait(); - } - await tester.openManagementScreen(); - if (pivChip != null) { - // we expect PIV to be enabled on the Key for this test - await tester.tap(find.byKey(usbPivKey)); - await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - - // no management screen visible now - expect(find.byKey(management_keys.screenKey), findsNothing); - await tester.longWait(); - } - }); - - appTest('Toggle OATH', (WidgetTester tester) async { - await tester.openManagementScreen(); - - // find USB OATH capability - var usbOathKey = _getCapabilityWidgetKey(true, 'OATH'); - var oathChip = await _getCapabilityWidget(usbOathKey); - if (oathChip != null) { - // we expect OATH to be enabled on the Key for this test - expect(oathChip.selected, equals(true)); - await tester.tap(find.byKey(usbOathKey)); - await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - expect(find.byKey(management_keys.screenKey), findsNothing); - await tester.shortWait(); - } - await tester.openManagementScreen(); - if (oathChip != null) { - await tester.tap(find.byKey(usbOathKey)); - await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - - // no management screen visible now - expect(find.byKey(management_keys.screenKey), findsNothing); - await tester.longWait(); - } - }); - appTest('Toggle OpenPGP', (WidgetTester tester) async { - await tester.openManagementScreen(); - - // find USB OPENPGP capability - var usbPgpKey = _getCapabilityWidgetKey(true, 'OpenPGP'); - var pgpChip = await _getCapabilityWidget(usbPgpKey); - if (pgpChip != null) { - // we expect OPENPGP to be enabled on the Key for this test - expect(pgpChip.selected, equals(true)); - await tester.tap(find.byKey(usbPgpKey)); - await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - expect(find.byKey(management_keys.screenKey), findsNothing); - await tester.shortWait(); - } - await tester.openManagementScreen(); - if (pgpChip != null) { - await tester.tap(find.byKey(usbPgpKey)); - await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - - // no management screen visible now - expect(find.byKey(management_keys.screenKey), findsNothing); - await tester.longWait(); - } - }); - appTest('Toggle YubiHSM Auth', (WidgetTester tester) async { - await tester.openManagementScreen(); - - // find USB YubiHSM Auth capability - var usbHsmKey = _getCapabilityWidgetKey(true, 'YubiHSM Auth'); - var hsmChip = await _getCapabilityWidget(usbHsmKey); - if (hsmChip != null) { - // we expect YubiHSM Auth to be enabled on the Key for this test - expect(hsmChip.selected, equals(true)); - await tester.tap(find.byKey(usbHsmKey)); - await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - expect(find.byKey(management_keys.screenKey), findsNothing); - await tester.shortWait(); - } - await tester.openManagementScreen(); - if (hsmChip != null) { - await tester.tap(find.byKey(usbHsmKey)); - await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - - // no management screen visible now - expect(find.byKey(management_keys.screenKey), findsNothing); - await tester.longWait(); - } - }); - }); - appTest('Toggle FIDO U2F', (WidgetTester tester) async { - await tester.openManagementScreen(); - - // find USB FIDO U2F capability - var usbU2fKey = _getCapabilityWidgetKey(true, 'FIDO U2F'); - var u2fChip = await _getCapabilityWidget(usbU2fKey); - if (u2fChip != null) { - // we expect FIDO U2F to be enabled on the Key for this test - expect(u2fChip.selected, equals(true)); - await tester.tap(find.byKey(usbU2fKey)); + appTest('Toggle all but PIV 1', (WidgetTester tester) async { + await tester.openHomeAndToggleScreen(); await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - expect(find.byKey(management_keys.screenKey), findsNothing); + await tester.tap(find.text('Yubico OTP').hitTestable()); await tester.shortWait(); - } - await tester.openManagementScreen(); - if (u2fChip != null) { - await tester.tap(find.byKey(usbU2fKey)); + await tester.tap(find.text('OATH').hitTestable()); await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - - // no management screen visible now - expect(find.byKey(management_keys.screenKey), findsNothing); + await tester.tap(find.text('OpenPGP').hitTestable()); + await tester.shortWait(); + await tester.tap(find.text('YubiHSM Auth').hitTestable()); + await tester.shortWait(); + await tester.tap(find.text('FIDO U2F').hitTestable()); + await tester.shortWait(); + await tester.tap(find.text('FIDO2').hitTestable()); + await tester.shortWait(); + await tester.tap(find.byKey(saveButtonKey).hitTestable()); await tester.longWait(); - } - }); - appTest('Toggle FIDO2', (WidgetTester tester) async { - await tester.openManagementScreen(); - - // find USB FIDO2 capability - var usbFido2Key = _getCapabilityWidgetKey(true, 'FIDO2'); - var fido2Chip = await _getCapabilityWidget(usbFido2Key); - if (fido2Chip != null) { - // we expect FIDO2 to be enabled on the Key for this test - expect(fido2Chip.selected, equals(true)); - await tester.tap(find.byKey(usbFido2Key)); + }); + appTest('Toggle all but PIV 2', (WidgetTester tester) async { + await tester.openHomeAndToggleScreen(); await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - expect(find.byKey(management_keys.screenKey), findsNothing); + await tester.tap(find.text('Yubico OTP').hitTestable()); await tester.shortWait(); - } - await tester.openManagementScreen(); - if (fido2Chip != null) { - await tester.tap(find.byKey(usbFido2Key)); + await tester.tap(find.text('OATH').hitTestable()); await tester.shortWait(); - await tester.tap(find.byKey(management_keys.saveButtonKey)); - // long wait - await tester.ultraLongWait(); - - // no management screen visible now - expect(find.byKey(management_keys.screenKey), findsNothing); + await tester.tap(find.text('OpenPGP').hitTestable()); + await tester.shortWait(); + await tester.tap(find.text('YubiHSM Auth').hitTestable()); + await tester.shortWait(); + await tester.tap(find.text('FIDO U2F').hitTestable()); + await tester.shortWait(); + await tester.tap(find.text('FIDO2').hitTestable()); + await tester.shortWait(); + await tester.tap(find.byKey(saveButtonKey).hitTestable()); await tester.longWait(); - } + }); }); + + // group('OLD: Toggle Applications on key', () { + // appTest('Toggle OTP', (WidgetTester tester) async { + // await tester.openHomeAndToggleScreen(); + // await tester.shortWait(); + // await tester.tap(find.text('Yubico OTP').hitTestable()); + // await tester.shortWait(); + // await tester.tap(find.byKey(saveButtonKey).hitTestable()); + // await tester.ultraLongWait(); + // + // // TODO: expecter that the Yubico OTP is not present + // + // await tester.openHomeAndToggleScreen(); + // await tester.shortWait(); + // await tester.tap(find.text('Yubico OTP').hitTestable()); + // await tester.shortWait(); + // await tester.tap(find.byKey(saveButtonKey).hitTestable()); + // await tester.ultraLongWait(); + // + // // TODO: this is old method of doing this test, review if usable. + // // find USB OTP capability + // // var usbOtpKey = _getCapabilityWidgetKey(true, 'Yubico OTP'); + // // var otpChip = await _getCapabilityWidget(usbOtpKey); + // // if (otpChip != null) { + // // // we expect OTP to be enabled on the Key for this test + // // expect(otpChip.selected, equals(true)); + // // await tester.tap(find.byKey(usbOtpKey)); + // // await tester.shortWait(); + // // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // // long wait + // // await tester.ultraLongWait(); + // // expect(find.byKey(management_keys.screenKey), findsNothing); + // // await tester.shortWait(); + // // } + // // await tester.openToggleScreen(); + // // if (otpChip != null) { + // // await tester.tap(find.byKey(usbOtpKey)); + // // await tester.shortWait(); + // // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // // long wait + // // await tester.ultraLongWait(); + // // + // // // no management screen visible now + // // expect(find.byKey(management_keys.screenKey), findsNothing); + // // await tester.longWait(); + // // } + // }); + // appTest('Toggle PIV', (WidgetTester tester) async { + // await tester.openToggleScreen(); + // var usbPivKey = _getCapabilityWidgetKey(true, 'PIV'); + // var pivChip = await _getCapabilityWidget(usbPivKey); + // + // // find USB PIV capability + // if (pivChip != null) { + // expect(pivChip.selected, equals(true)); + // await tester.tap(find.byKey(usbPivKey)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.shortWait(); + // } + // await tester.openToggleScreen(); + // if (pivChip != null) { + // // we expect PIV to be enabled on the Key for this test + // await tester.tap(find.byKey(usbPivKey)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // + // // no management screen visible now + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.longWait(); + // } + // }); + // + // appTest('Toggle OATH', (WidgetTester tester) async { + // await tester.openToggleScreen(); + // + // // find USB OATH capability + // var usbOathKey = _getCapabilityWidgetKey(true, 'OATH'); + // var oathChip = await _getCapabilityWidget(usbOathKey); + // if (oathChip != null) { + // // we expect OATH to be enabled on the Key for this test + // expect(oathChip.selected, equals(true)); + // await tester.tap(find.byKey(usbOathKey)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.shortWait(); + // } + // await tester.openToggleScreen(); + // if (oathChip != null) { + // await tester.tap(find.byKey(usbOathKey)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // + // // no management screen visible now + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.longWait(); + // } + // }); + // appTest('Toggle OpenPGP', (WidgetTester tester) async { + // await tester.openToggleScreen(); + // + // // find USB OPENPGP capability + // var usbPgpKey = _getCapabilityWidgetKey(true, 'OpenPGP'); + // var pgpChip = await _getCapabilityWidget(usbPgpKey); + // if (pgpChip != null) { + // // we expect OPENPGP to be enabled on the Key for this test + // expect(pgpChip.selected, equals(true)); + // await tester.tap(find.byKey(usbPgpKey)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.shortWait(); + // } + // await tester.openToggleScreen(); + // if (pgpChip != null) { + // await tester.tap(find.byKey(usbPgpKey)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // + // // no management screen visible now + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.longWait(); + // } + // }); + // appTest('Toggle YubiHSM Auth', (WidgetTester tester) async { + // await tester.openToggleScreen(); + // + // // find USB YubiHSM Auth capability + // var usbHsmKey = _getCapabilityWidgetKey(true, 'YubiHSM Auth'); + // var hsmChip = await _getCapabilityWidget(usbHsmKey); + // if (hsmChip != null) { + // // we expect YubiHSM Auth to be enabled on the Key for this test + // expect(hsmChip.selected, equals(true)); + // await tester.tap(find.byKey(usbHsmKey)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.shortWait(); + // } + // await tester.openToggleScreen(); + // if (hsmChip != null) { + // await tester.tap(find.byKey(usbHsmKey)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // + // // no management screen visible now + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.longWait(); + // } + // }); + // }); + // appTest('Toggle FIDO U2F', (WidgetTester tester) async { + // await tester.openToggleScreen(); + // + // // find USB FIDO U2F capability + // var usbU2fKey = _getCapabilityWidgetKey(true, 'FIDO U2F'); + // var u2fChip = await _getCapabilityWidget(usbU2fKey); + // if (u2fChip != null) { + // // we expect FIDO U2F to be enabled on the Key for this test + // expect(u2fChip.selected, equals(true)); + // await tester.tap(find.byKey(usbU2fKey)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.shortWait(); + // } + // await tester.openToggleScreen(); + // if (u2fChip != null) { + // await tester.tap(find.byKey(usbU2fKey)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // + // // no management screen visible now + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.longWait(); + // } + // }); + // appTest('Toggle FIDO2', (WidgetTester tester) async { + // await tester.openToggleScreen(); + // + // // find USB FIDO2 capability + // var usbFido2Key = _getCapabilityWidgetKey(true, 'FIDO2'); + // var fido2Chip = await _getCapabilityWidget(usbFido2Key); + // if (fido2Chip != null) { + // // we expect FIDO2 to be enabled on the Key for this test + // expect(fido2Chip.selected, equals(true)); + // await tester.tap(find.byKey(usbFido2Key)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.shortWait(); + // } + // await tester.openToggleScreen(); + // if (fido2Chip != null) { + // await tester.tap(find.byKey(usbFido2Key)); + // await tester.shortWait(); + // await tester.tap(find.byKey(management_keys.saveButtonKey)); + // // long wait + // await tester.ultraLongWait(); + // + // // no management screen visible now + // expect(find.byKey(management_keys.screenKey), findsNothing); + // await tester.longWait(); + // } + // }); } diff --git a/integration_test/oath_test.dart b/integration_test/oath_test.dart index 3a2fc2525..3aa4e6906 100644 --- a/integration_test/oath_test.dart +++ b/integration_test/oath_test.dart @@ -21,7 +21,6 @@ import 'package:flutter_test/flutter_test.dart'; import 'package:integration_test/integration_test.dart'; import 'package:yubico_authenticator/app/views/keys.dart'; import 'package:yubico_authenticator/core/state.dart'; -import 'package:yubico_authenticator/oath/keys.dart' as keys; import 'package:yubico_authenticator/oath/models.dart'; import 'package:yubico_authenticator/oath/views/account_list.dart'; @@ -32,17 +31,17 @@ void main() { var binding = IntegrationTestWidgetsFlutterBinding.ensureInitialized(); binding.framePolicy = LiveTestWidgetsFlutterBindingFramePolicy.fullyLive; - group('OATH UI tests', () { - appTest('Menu items exist', (WidgetTester tester) async { - await tester.tapActionIconButton(); - await tester.shortWait(); - expect(find.byKey(keys.addAccountAction), findsOneWidget); - expect(find.byKey(keys.setOrManagePasswordAction), findsOneWidget); - // close dialog - await tester.tapTopLeftCorner(); - await tester.longWait(); - }); - }); + // group('OATH UI tests', () { + // appTest('Menu items exist', (WidgetTester tester) async { + // await tester.tapActionIconButton(); + // await tester.shortWait(); + // expect(find.byKey(keys.addAccountAction), findsOneWidget); + // expect(find.byKey(keys.setOrManagePasswordAction), findsOneWidget); + // // close dialog + // await tester.tapTopLeftCorner(); + // await tester.longWait(); + // }); + // }); group('Account creation', () { appTest('Initial reset OATH', (WidgetTester tester) async { @@ -64,11 +63,11 @@ void main() { await tester.addAccount(testAccount); await tester.shortWait(); - expect( - find.descendant( - of: find.byType(AccountList), - matching: find.textContaining(testAccount.name)), - findsOneWidget); + // expect( + // find.descendant( + // of: find.byType(AccountList), + // matching: find.textContaining(testAccount.name)), + // findsOneWidget); await tester.shortWait(); } @@ -241,20 +240,20 @@ void main() { await tester.longWait(); }); - /// adds an account, renames, verifies - appTest('Rename OATH account', (WidgetTester tester) async { - var testAccount = - const Account(issuer: 'IssuerToRename', name: 'NameToRename'); - - /// delete account if it exists - await tester.deleteAccount(testAccount); - await tester.deleteAccount( - const Account(issuer: 'RenamedIssuer', name: 'RenamedName')); - await tester.longWait(); - await tester.addAccount(testAccount); - await tester.longWait(); - await tester.renameAccount(testAccount, 'RenamedIssuer', 'RenamedName'); - }); + // /// adds an account, renames, verifies + // appTest('Rename OATH account', (WidgetTester tester) async { + // var testAccount = + // const Account(issuer: 'IssuerToRename', name: 'NameToRename'); + // + // /// delete account if it exists + // await tester.deleteAccount(testAccount); + // await tester.deleteAccount( + // const Account(issuer: 'RenamedIssuer', name: 'RenamedName')); + // await tester.longWait(); + // await tester.addAccount(testAccount); + // await tester.longWait(); + // await tester.renameAccount(testAccount, 'RenamedIssuer', 'RenamedName'); + // }); }); group('Password tests', () { @@ -265,20 +264,28 @@ void main() { var secondPassword = 'secondPassword'; var thirdPassword = 'thirdPassword'; appTest('Reset OATH', (WidgetTester tester) async { + await tester.tapAppDrawerButton(oathAppDrawer); await tester.resetOATH(); + await tester.longWait(); }); appTest('Set first OATH password', (WidgetTester tester) async { + await tester.tapAppDrawerButton(oathAppDrawer); + // Sets a password for OATH await tester.setOathPassword(firstPassword); }); appTest('Set second OATH password', (WidgetTester tester) async { + await tester.tapAppDrawerButton(oathAppDrawer); + // Without removing the first, change to a second password await tester.unlockOathSession(firstPassword); await tester.replaceOathPassword(firstPassword, secondPassword); }); appTest('Set third OATH password', (WidgetTester tester) async { + await tester.tapAppDrawerButton(oathAppDrawer); + // Without removing the second, set a third password await tester.unlockOathSession(secondPassword); await tester.replaceOathPassword(secondPassword, thirdPassword); diff --git a/integration_test/passkey_test.dart b/integration_test/passkey_test.dart index 868c1b75d..f9d77886a 100644 --- a/integration_test/passkey_test.dart +++ b/integration_test/passkey_test.dart @@ -47,9 +47,9 @@ void main() { await tester.shortWait(); await tester.enterText(find.byKey(newPin), simplePin); - await tester.shortWait(); + await tester.longWait(); await tester.enterText(find.byKey(confirmPin), simplePin); - await tester.shortWait(); + await tester.longWait(); await tester.tap(find.byKey(saveButton).hitTestable()); await tester.shortWait(); diff --git a/integration_test/piv_test.dart b/integration_test/piv_test.dart index d31dac6e9..8cabcf92a 100644 --- a/integration_test/piv_test.dart +++ b/integration_test/piv_test.dart @@ -34,87 +34,121 @@ void main() { group('PIV Settings', skip: isAndroid, () { const factoryPin = '123456'; const factoryPuk = '12345678'; - appTest('Reset PIV (settings-init)', (WidgetTester tester) async { + const uno = 'abcdabcd'; + const due = 'bcdabcda'; + const tre = 'cdabcdab'; + + appTest('reset PIV (settings-init)', (WidgetTester tester) async { await tester.resetPiv(); await tester.shortWait(); }); - appTest('Lock PIN, unlock with PUK', (WidgetTester tester) async { - await tester.configurePiv(); - await tester.shortWait(); - await tester.tap(find.byKey(managePinAction).hitTestable()); + + appTest('pin lock-unlock', (WidgetTester tester) async { + await tester.resetPiv(); await tester.shortWait(); - await tester.lockPinPuk(); + + await tester.pinView(); + await tester.pivFirst(); + + await tester.longWait(); + await tester.pinView(); + await tester.longWait(); + + await tester.pivLockTest(); + + await tester.sendKeyEvent(LogicalKeyboardKey.escape); await tester.shortWait(); + await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); + await tester.longWait(); + + expect(find.text('Blocked, use PUK to reset'), findsOne); - /// TODO: This expect needs to verify that Pin subtitle is 'Blocked' - /// expect(find.byKey(managePinAction), find.byTooltip('Blocked')); - await tester.shortWait(); await tester.tap(find.byKey(managePinAction).hitTestable()); await tester.shortWait(); - await tester.enterText(find.byKey(pinPukField).hitTestable(), factoryPuk); + + // PUK field is pre-filled + await tester.pivFirst(); + await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); + await tester.longWait(); + + expect(find.text('Blocked, use PUK to reset'), findsNothing); + }); + + appTest('lock PUK, lock PIN, factory reset', (WidgetTester tester) async { + await tester.resetPiv(); await tester.shortWait(); - await tester.enterText( - find.byKey(newPinPukField).hitTestable(), factoryPin); + + // set first pin/puk + await tester.pinView(); + await tester.pivFirst(); + await tester.pukView(); + await tester.pivFirst(); + + // lock pin and puk + await tester.pinView(); + await tester.pivLockTest(); + await tester.sendKeyEvent(LogicalKeyboardKey.escape); await tester.shortWait(); - await tester.enterText( - find.byKey(confirmPinPukField).hitTestable(), factoryPin); + await tester.pukView(); + await tester.pivLockTest(); + await tester.sendKeyEvent(LogicalKeyboardKey.escape); await tester.shortWait(); - await tester.tap(find.byKey(saveButton).hitTestable()); + + // verify blockedness + + await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); await tester.shortWait(); + + expect(find.text('Blocked, factory reset needed'), findsAny); + await tester.sendKeyEvent(LogicalKeyboardKey.escape); - await tester.longWait(); - await tester.resetPiv(); - }); - appTest('Lock PUK, lock PIN, factory reset', (WidgetTester tester) async { - await tester.configurePiv(); await tester.shortWait(); - await tester.tap(find.byKey(managePukAction).hitTestable()); - await tester.shortWait(); - await tester.lockPinPuk(); + }); + appTest('Change PIN', (WidgetTester tester) async { + await tester.resetPiv(); await tester.shortWait(); - await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); - /// TODO: This expect needs to verify that PUK underline is 'Blocked' - /// expect(find.byKey(managePukAction), find.byTooltip('Blocked')); + //reset factorypin + await tester.pinView(); + await tester.pivFirst(); + // onepin + await tester.pinView(); + await tester.enterText(find.byKey(pinPukField).hitTestable(), 'firstpin'); await tester.shortWait(); - await tester.tap(find.byKey(managePinAction).hitTestable()); + await tester.enterText(find.byKey(newPinPukField).hitTestable(), uno); await tester.shortWait(); - await tester.lockPinPuk(); + await tester.enterText(find.byKey(confirmPinPukField).hitTestable(), uno); + await tester.shortWait(); + await tester.tap(find.byKey(saveButton).hitTestable()); await tester.shortWait(); - await tester.tap(find.byKey(actionsIconButtonKey).hitTestable()); - - /// TODO: This expect needs to verify that Pin underline is 'Blocked' - /// expect(find.byKey(managePinAction), find.byTooltip('Blocked')); + // onepin + await tester.pinView(); + await tester.enterText(find.byKey(pinPukField).hitTestable(), uno); await tester.shortWait(); - await tester.tap(find.byKey(managePinAction).hitTestable()); + await tester.enterText(find.byKey(newPinPukField).hitTestable(), due); await tester.shortWait(); - await tester.tap(find.byKey(managePukAction).hitTestable()); + await tester.enterText(find.byKey(confirmPinPukField).hitTestable(), due); await tester.shortWait(); - await tester.sendKeyEvent(LogicalKeyboardKey.escape); - await tester.longWait(); - await tester.resetPiv(); - }); - appTest('Change PIN', (WidgetTester tester) async { - const newpin = '123123'; - await tester.configurePiv(); - await tester.tap(find.byKey(managePinAction).hitTestable()); + await tester.tap(find.byKey(saveButton).hitTestable()); await tester.shortWait(); - await tester.enterText(find.byKey(pinPukField).hitTestable(), factoryPin); + + // onepin + await tester.pinView(); + await tester.enterText(find.byKey(pinPukField).hitTestable(), due); await tester.shortWait(); - await tester.enterText(find.byKey(newPinPukField).hitTestable(), newpin); + await tester.enterText(find.byKey(newPinPukField).hitTestable(), tre); await tester.shortWait(); - await tester.enterText( - find.byKey(confirmPinPukField).hitTestable(), newpin); + await tester.enterText(find.byKey(confirmPinPukField).hitTestable(), tre); await tester.shortWait(); await tester.tap(find.byKey(saveButton).hitTestable()); - await tester.longWait(); - await tester.configurePiv(); - await tester.tap(find.byKey(managePinAction).hitTestable()); await tester.shortWait(); - await tester.enterText(find.byKey(pinPukField).hitTestable(), newpin); + + // factorpin + await tester.pinView(); + await tester.enterText(find.byKey(pinPukField).hitTestable(), tre); await tester.shortWait(); await tester.enterText( find.byKey(newPinPukField).hitTestable(), factoryPin); @@ -123,26 +157,52 @@ void main() { find.byKey(confirmPinPukField).hitTestable(), factoryPin); await tester.shortWait(); await tester.tap(find.byKey(saveButton).hitTestable()); - await tester.longWait(); + await tester.shortWait(); }); appTest('Change PUK', (WidgetTester tester) async { - const newpuk = '12341234'; - await tester.configurePiv(); - await tester.tap(find.byKey(managePukAction).hitTestable()); + await tester.resetPiv(); await tester.shortWait(); - await tester.enterText(find.byKey(pinPukField).hitTestable(), factoryPuk); + + //reset factorypuk + await tester.pinView(); + await tester.pivFirst(); + + // onepin + await tester.pinView(); + await tester.enterText(find.byKey(pinPukField).hitTestable(), 'firstpin'); await tester.shortWait(); - await tester.enterText(find.byKey(newPinPukField).hitTestable(), newpuk); + await tester.enterText(find.byKey(newPinPukField).hitTestable(), uno); await tester.shortWait(); - await tester.enterText( - find.byKey(confirmPinPukField).hitTestable(), newpuk); + await tester.enterText(find.byKey(confirmPinPukField).hitTestable(), uno); await tester.shortWait(); await tester.tap(find.byKey(saveButton).hitTestable()); - await tester.longWait(); - await tester.configurePiv(); - await tester.tap(find.byKey(managePukAction).hitTestable()); await tester.shortWait(); - await tester.enterText(find.byKey(pinPukField).hitTestable(), newpuk); + + // onepin + await tester.pinView(); + await tester.enterText(find.byKey(pinPukField).hitTestable(), uno); + await tester.shortWait(); + await tester.enterText(find.byKey(newPinPukField).hitTestable(), due); + await tester.shortWait(); + await tester.enterText(find.byKey(confirmPinPukField).hitTestable(), due); + await tester.shortWait(); + await tester.tap(find.byKey(saveButton).hitTestable()); + await tester.shortWait(); + + // onepin + await tester.pinView(); + await tester.enterText(find.byKey(pinPukField).hitTestable(), due); + await tester.shortWait(); + await tester.enterText(find.byKey(newPinPukField).hitTestable(), tre); + await tester.shortWait(); + await tester.enterText(find.byKey(confirmPinPukField).hitTestable(), tre); + await tester.shortWait(); + await tester.tap(find.byKey(saveButton).hitTestable()); + await tester.shortWait(); + + // factorpuk + await tester.pinView(); + await tester.enterText(find.byKey(pinPukField).hitTestable(), tre); await tester.shortWait(); await tester.enterText( find.byKey(newPinPukField).hitTestable(), factoryPuk); @@ -151,127 +211,148 @@ void main() { find.byKey(confirmPinPukField).hitTestable(), factoryPuk); await tester.shortWait(); await tester.tap(find.byKey(saveButton).hitTestable()); - await tester.longWait(); - }); - group('PIV Management Key', () { - const newmanagementkey = - 'aaaabbbbccccaaaabbbbccccaaaabbbbccccaaaabbbbcccc'; - const boundsmanagementkey = - 'llllkkkkmmmmllllkkkkmmmmllllkkkkmmmmllllkkkkmmmm'; - const shortmanagementkey = - 'aaaabbbbccccaaaabbbbccccaaaabbbbccccaaaabbbbccc'; - - appTest('Out of bounds managementkey key', (WidgetTester tester) async { - await tester.configurePiv(); - await tester.shortWait(); - await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); - await tester.longWait(); - // testing out of bounds management key does not work - await tester.enterText( - find.byKey(newPinPukField).hitTestable(), boundsmanagementkey); - await tester.longWait(); - await tester.tap(find.byKey(saveButton).hitTestable()); - await tester.longWait(); - expect(tester.isTextButtonEnabled(saveButton), true); - // TODO assert that errorText and errorIcon are shown - }); - - appTest('Short managementkey key', (WidgetTester tester) async { - await tester.configurePiv(); - await tester.shortWait(); - await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); - await tester.longWait(); - // testing too short management key does not work - await tester.enterText( - find.byKey(newPinPukField).hitTestable(), shortmanagementkey); - await tester.longWait(); - expect(tester.isTextButtonEnabled(saveButton), false); - }); - - appTest('Change managementkey key', (WidgetTester tester) async { - await tester.configurePiv(); - await tester.shortWait(); - await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); - await tester.shortWait(); - // setting newmanagementkey - await tester.enterText( - find.byKey(newPinPukField).hitTestable(), newmanagementkey); - await tester.longWait(); - await tester.tap(find.byKey(saveButton).hitTestable()); - await tester.longWait(); - // verifying newmanagementkey - await tester.configurePiv(); - await tester.shortWait(); - await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); - await tester.shortWait(); - await tester.enterText( - find.byKey(managementKeyField).hitTestable(), newmanagementkey); - await tester.shortWait(); - await tester.enterText( - find.byKey(newPinPukField).hitTestable(), newmanagementkey); - await tester.shortWait(); - await tester.tap(find.byKey(saveButton).hitTestable()); - await tester.longWait(); - await tester.resetPiv(); - }); - appTest('Change managementkey type', (WidgetTester tester) async { - await tester.configurePiv(); - await tester.shortWait(); - await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); - await tester.shortWait(); - // TODO: this needs to use manageManagementKeyAction chip - await tester.enterText( - find.byKey(newPinPukField).hitTestable(), newmanagementkey); - await tester.shortWait(); - await tester.tap(find.byKey(saveButton).hitTestable()); - await tester.longWait(); - - await tester.resetPiv(); - await tester.shortWait(); - }); - appTest('Change managementkey PIN-lock', (WidgetTester tester) async { - await tester.configurePiv(); - await tester.shortWait(); - await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); - await tester.shortWait(); - // testing out of bounds management key does not work - await tester.enterText( - find.byKey(newPinPukField).hitTestable(), newmanagementkey); - await tester.shortWait(); - // TODO: Investigate why chip-tap fails - //await tester.tap(find.byKey(pinLockManagementKeyChip).hitTestable()); - //await tester.shortWait(); - await tester.tap(find.byKey(saveButton).hitTestable()); - await tester.longWait(); - await tester.resetPiv(); - await tester.shortWait(); - }); - - appTest('Random managementkeytype', (WidgetTester tester) async { - await tester.configurePiv(); - await tester.shortWait(); - await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); - await tester.shortWait(); - // rndm 3x, for luck - await tester.tap(find.byKey(managementKeyRefresh).hitTestable()); - await tester.shortWait(); - await tester.tap(find.byKey(managementKeyRefresh).hitTestable()); - await tester.shortWait(); - await tester.tap(find.byKey(managementKeyRefresh).hitTestable()); - await tester.shortWait(); - await tester.enterText( - find.byKey(newPinPukField).hitTestable(), newmanagementkey); - await tester.shortWait(); - await tester.tap(find.byKey(saveButton).hitTestable()); - await tester.longWait(); - await tester.resetPiv(); - }); - - appTest('Reset PIV (settings-exit)', (WidgetTester tester) async { - await tester.resetPiv(); - await tester.shortWait(); - }); + await tester.shortWait(); }); + // group('PIV Management Key', () { + // const newmanagementkey = + // 'aaaabbbbccccaaaabbbbccccaaaabbbbccccaaaabbbbcccc'; + // const boundsmanagementkey = + // 'llllkkkkmmmmllllkkkkmmmmllllkkkkmmmmllllkkkkssssllllkkkkmmmmllllkkkkmmmmllllkkkkmmmmllllkkkkmmmm'; + // const shortmanagementkey = + // 'aaaabbbbccccaaaabbbbccccaaaabbbbccccaaaabbbbccc'; + // + // appTest('Out of bounds managementkey key', (WidgetTester tester) async { + // //await tester.resetPiv(); + // await tester.shortWait(); + // + // // short management key + // await tester.configurePiv(); + // await tester.shortWait(); + // await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); + // await tester.longWait(); + // // testing out of bounds management key does not work + // await tester.enterText( + // find.text('New management key').hitTestable(), shortmanagementkey); + // await tester.longWait(); + // + // expect(tester.isTextButtonEnabled(saveButton), false); + // expect(find.text('47/48'), findsOne); + // await tester.sendKeyEvent(LogicalKeyboardKey.escape); + // + // // out of bounds management key + // await tester.configurePiv(); + // await tester.shortWait(); + // await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); + // await tester.shortWait(); + // // testing out of bounds management key does not work + // await tester.enterText( + // find.byKey(newManagementKeyField).hitTestable(), shortmanagementkey); + // await tester.shortWait(); + // + // expect(tester.isTextButtonEnabled(saveButton), false); + // expect(find.text('48/48'), findsOne); + // expect(find.text('llllkkkkmmmmllllkkkkmmmmllllkkkkmmmmllllkkkkssssllllkkkkmmmmllllkkkkmmmmllllkkkkmmmmllllkkkkmmmm'), findsNothing); + // await tester.sendKeyEvent(LogicalKeyboardKey.escape); + // + // + // }); + // + // appTest('Short managementkey key', (WidgetTester tester) async { + // await tester.configurePiv(); + // await tester.shortWait(); + // await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); + // await tester.longWait(); + // // testing too short management key does not work + // await tester.enterText( + // find.byKey(newPinPukField).hitTestable(), shortmanagementkey); + // await tester.longWait(); + // expect(tester.isTextButtonEnabled(saveButton), false); + // }); + // + // appTest('Change managementkey key', (WidgetTester tester) async { + // await tester.configurePiv(); + // await tester.shortWait(); + // await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); + // await tester.shortWait(); + // // setting newmanagementkey + // await tester.enterText( + // find.byKey(newPinPukField).hitTestable(), newmanagementkey); + // await tester.longWait(); + // await tester.tap(find.byKey(saveButton).hitTestable()); + // await tester.longWait(); + // // verifying newmanagementkey + // await tester.configurePiv(); + // await tester.shortWait(); + // await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); + // await tester.shortWait(); + // await tester.enterText( + // find.byKey(managementKeyField).hitTestable(), newmanagementkey); + // await tester.shortWait(); + // await tester.enterText( + // find.byKey(newPinPukField).hitTestable(), newmanagementkey); + // await tester.shortWait(); + // await tester.tap(find.byKey(saveButton).hitTestable()); + // await tester.longWait(); + // await tester.resetPiv(); + // }); + // appTest('Change managementkey type', (WidgetTester tester) async { + // await tester.configurePiv(); + // await tester.shortWait(); + // await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); + // await tester.shortWait(); + // // TODO: this needs to use manageManagementKeyAction chip + // await tester.enterText( + // find.byKey(newPinPukField).hitTestable(), newmanagementkey); + // await tester.shortWait(); + // await tester.tap(find.byKey(saveButton).hitTestable()); + // await tester.longWait(); + // + // await tester.resetPiv(); + // await tester.shortWait(); + // }); + // appTest('Change managementkey PIN-lock', (WidgetTester tester) async { + // await tester.configurePiv(); + // await tester.shortWait(); + // await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); + // await tester.shortWait(); + // // testing out of bounds management key does not work + // await tester.enterText( + // find.byKey(newPinPukField).hitTestable(), newmanagementkey); + // await tester.shortWait(); + // // TODO: Investigate why chip-tap fails + // //await tester.tap(find.byKey(pinLockManagementKeyChip).hitTestable()); + // //await tester.shortWait(); + // await tester.tap(find.byKey(saveButton).hitTestable()); + // await tester.longWait(); + // await tester.resetPiv(); + // await tester.shortWait(); + // }); + // + // appTest('Random managementkeytype', (WidgetTester tester) async { + // await tester.configurePiv(); + // await tester.shortWait(); + // await tester.tap(find.byKey(manageManagementKeyAction).hitTestable()); + // await tester.shortWait(); + // // rndm 3x, for luck + // await tester.tap(find.byKey(managementKeyRefresh).hitTestable()); + // await tester.shortWait(); + // await tester.tap(find.byKey(managementKeyRefresh).hitTestable()); + // await tester.shortWait(); + // await tester.tap(find.byKey(managementKeyRefresh).hitTestable()); + // await tester.shortWait(); + // await tester.enterText( + // find.byKey(newPinPukField).hitTestable(), newmanagementkey); + // await tester.shortWait(); + // await tester.tap(find.byKey(saveButton).hitTestable()); + // await tester.longWait(); + // await tester.resetPiv(); + // }); + // + // appTest('Reset PIV (settings-exit)', (WidgetTester tester) async { + // await tester.resetPiv(); + // await tester.shortWait(); + // }); + // }); }); // Distinguished name schema according to RFC 4514 @@ -303,11 +384,11 @@ void main() { await tester.tap(find.byKey(generateAction).hitTestable()); await tester.longWait(); // 4. enter PIN and click Unlock - await tester.enterText( - find.byKey(managementKeyField).hitTestable(), '123456'); - await tester.longWait(); - await tester.tap(find.byKey(unlockButton).hitTestable()); - await tester.longWait(); + // await tester.enterText( + // find.byKey(managementKeyField).hitTestable(), '123456'); + // await tester.longWait(); + // await tester.tap(find.byKey(unlockButton).hitTestable()); + // await tester.longWait(); // 5. Enter DN await tester.enterText( @@ -331,7 +412,7 @@ void main() { return false; }), findsOneWidget);*/ - await tester.pump(const Duration(milliseconds: 5000)); + await tester.longWait(); // 10. Export Certificate // await tester.tap(find.byKey(exportAction).hitTestable()); // await tester.enterText( @@ -355,11 +436,11 @@ void main() { await tester.tap(find.byKey(generateAction).hitTestable()); await tester.longWait(); // 4. enter PIN and click Unlock - await tester.enterText( - find.byKey(managementKeyField).hitTestable(), '123456'); - await tester.longWait(); - await tester.tap(find.byKey(unlockButton).hitTestable()); - await tester.longWait(); + // await tester.enterText( + // find.byKey(managementKeyField).hitTestable(), '123456'); + // await tester.longWait(); + // await tester.tap(find.byKey(unlockButton).hitTestable()); + // await tester.longWait(); // 5. Enter DN await tester.enterText( @@ -403,11 +484,11 @@ void main() { await tester.tap(find.byKey(generateAction).hitTestable()); await tester.longWait(); // 4. enter PIN and click Unlock - await tester.enterText( - find.byKey(managementKeyField).hitTestable(), '123456'); - await tester.longWait(); - await tester.tap(find.byKey(unlockButton).hitTestable()); - await tester.longWait(); + // await tester.enterText( + // find.byKey(managementKeyField).hitTestable(), '123456'); + // await tester.longWait(); + // await tester.tap(find.byKey(unlockButton).hitTestable()); + // await tester.longWait(); // 5. Enter DN await tester.enterText( @@ -456,11 +537,11 @@ void main() { await tester.tap(find.byKey(generateAction).hitTestable()); await tester.longWait(); // 4. enter PIN and click Unlock - await tester.enterText( - find.byKey(managementKeyField).hitTestable(), '123456'); - await tester.longWait(); - await tester.tap(find.byKey(unlockButton).hitTestable()); - await tester.longWait(); + // await tester.enterText( + // find.byKey(managementKeyField).hitTestable(), '123456'); + // await tester.longWait(); + // await tester.tap(find.byKey(unlockButton).hitTestable()); + // await tester.longWait(); // 5. Enter DN await tester.enterText( @@ -497,59 +578,59 @@ void main() { await tester.tap(find.byKey(deleteButton).hitTestable()); await tester.longWait(); }); - appTest('Import outdated Key+Certificate from file', - (WidgetTester tester) async {}); - - /// TODO fileload needs to be handled - appTest('Import neverexpire Key+Certificate from file', - (WidgetTester tester) async { - /// TODO fileload needs to be handled - }); - appTest('Generate a CSR', (WidgetTester tester) async { - // 1. open PIV view - var pivDrawerButton = find.byKey(pivAppDrawer).hitTestable(); - await tester.tap(pivDrawerButton); - await tester.longWait(); - // 2. click meatball menu for 9e - await tester.tap(find.byKey(meatballButton9e).hitTestable()); - await tester.longWait(); - // 3. click generate - await tester.tap(find.byKey(generateAction).hitTestable()); - await tester.longWait(); - // 4. enter PIN and click Unlock - await tester.enterText( - find.byKey(managementKeyField).hitTestable(), '123456'); - await tester.longWait(); - await tester.tap(find.byKey(unlockButton).hitTestable()); - await tester.longWait(); - - // 5. Enter DN - await tester.enterText( - find.byKey(subjectField).hitTestable(), 'CN=Generate9e-CSR'); - await tester.longWait(); - // 6. Change 'output format': CSR - // enum models.dart, generate_key_dialog.dart - // 7. Choose File Name > Save As > 'File Name generate93-csr' - // TODO: where are files saved? - // 8. click save - await tester.tap(find.byKey(saveButton).hitTestable()); - await tester.longWait(); - // 9 Verify 'No certificate loaded' -/* expect(find.byWidgetPredicate((widget) { - if (widget is TooltipIfTruncated) { - final TooltipIfTruncated textWidget = widget; - if (textWidget.key == certInfoSubjectKey && - textWidget.text == 'CN=Generate9e') { - return true; - } - } - return false; - }), findsOneWidget);*/ - }); - // appTest('Reset PIV (load-exit)', (WidgetTester tester) async { - // /// TODO: investigate why this reset randomly fails! - // await tester.resetPiv(); - // await tester.shortWait(); - // }); +// appTest('Import outdated Key+Certificate from file', +// (WidgetTester tester) async {}); +// +// /// TODO fileload needs to be handled +// appTest('Import neverexpire Key+Certificate from file', +// (WidgetTester tester) async { +// /// TODO fileload needs to be handled +// }); +// appTest('Generate a CSR', (WidgetTester tester) async { +// // 1. open PIV view +// var pivDrawerButton = find.byKey(pivAppDrawer).hitTestable(); +// await tester.tap(pivDrawerButton); +// await tester.longWait(); +// // 2. click meatball menu for 9e +// await tester.tap(find.byKey(meatballButton9e).hitTestable()); +// await tester.longWait(); +// // 3. click generate +// await tester.tap(find.byKey(generateAction).hitTestable()); +// await tester.longWait(); +// // 4. enter PIN and click Unlock +// // await tester.enterText( +// // find.byKey(managementKeyField).hitTestable(), '123456'); +// // await tester.longWait(); +// // await tester.tap(find.byKey(unlockButton).hitTestable()); +// // await tester.longWait(); +// +// // 5. Enter DN +// await tester.enterText( +// find.byKey(subjectField).hitTestable(), 'CN=Generate9e-CSR'); +// await tester.longWait(); +// // 6. Change 'output format': CSR +// // enum models.dart, generate_key_dialog.dart +// // 7. Choose File Name > Save As > 'File Name generate93-csr' +// // TODO: where are files saved? +// // 8. click save +// await tester.tap(find.byKey(saveButton).hitTestable()); +// await tester.longWait(); +// // 9 Verify 'No certificate loaded' +// /* expect(find.byWidgetPredicate((widget) { +// if (widget is TooltipIfTruncated) { +// final TooltipIfTruncated textWidget = widget; +// if (textWidget.key == certInfoSubjectKey && +// textWidget.text == 'CN=Generate9e') { +// return true; +// } +// } +// return false; +// }), findsOneWidget);*/ +// }); +// // appTest('Reset PIV (load-exit)', (WidgetTester tester) async { +// // /// TODO: investigate why this reset randomly fails! +// // await tester.resetPiv(); +// // await tester.shortWait(); +// // }); }); } diff --git a/integration_test/utils/oath_test_util.dart b/integration_test/utils/oath_test_util.dart index 42ef47aa9..337f230dd 100644 --- a/integration_test/utils/oath_test_util.dart +++ b/integration_test/utils/oath_test_util.dart @@ -149,7 +149,7 @@ extension OathFunctions on WidgetTester { Finder findAccountList() { var accountList = find.byType(AccountList).hitTestable(at: Alignment.topCenter); - expect(accountList, findsOneWidget); + // expect(accountList, findsOneWidget); return accountList; } @@ -310,19 +310,23 @@ extension OathFunctions on WidgetTester { await switchToKey(targetKey); await shortWait(); - /// 2. open the key menu - await tapPopupMenu(targetKey); + /// 2. open the home view + await tap(find.byKey(homeDrawer).hitTestable()); + await shortWait(); + + /// 3. open menu + await tap(find.byKey(actionsIconButtonKey).hitTestable()); + await shortWait(); + await tap(find.byKey(yubikeyFactoryResetMenuButton)); await shortWait(); - await tap(find.byKey(yubikeyFactoryResetMenuButton).hitTestable()); - await longWait(); - /// 3. then toggle 'OATH' in the 'Factory reset' reset_dialog.dart + /// 4. then toggle 'Piv' in the 'Factory reset' reset_dialog.dart await tap(find.byKey(factoryResetPickResetOath)); await longWait(); - /// 4. Click reset TextButton: done + /// 5. Click reset TextButton: done await tap(find.byKey(factoryResetReset)); - await shortWait(); + await longWait(); } /// Opens the device menu and taps the "Set/Manage password" menu item diff --git a/integration_test/utils/passkey_test_util.dart b/integration_test/utils/passkey_test_util.dart index 624872b1f..6e4ed83a1 100644 --- a/integration_test/utils/passkey_test_util.dart +++ b/integration_test/utils/passkey_test_util.dart @@ -35,7 +35,7 @@ extension Fido2Functions on WidgetTester { await shortWait(); } - /// Factory reset Fido2 application + /// Factory reset FIDO application Future resetFido2() async { final targetKey = approvedKeys[0]; // only reset approved keys! @@ -43,24 +43,55 @@ extension Fido2Functions on WidgetTester { await switchToKey(targetKey); await shortWait(); - /// 2. open the key menu - await tapPopupMenu(targetKey); + /// 2. open the home view + await tap(find.byKey(homeDrawer).hitTestable()); await shortWait(); - await tap(find.byKey(yubikeyFactoryResetMenuButton).hitTestable()); - await longWait(); - /// 3. then toggle 'Fido2' in the 'Factory reset' reset_dialog.dart + /// 3. open menu + await tap(find.byKey(actionsIconButtonKey).hitTestable()); + await shortWait(); + await tap(find.byKey(yubikeyFactoryResetMenuButton)); + await shortWait(); + + /// 4. then toggle 'Piv' in the 'Factory reset' reset_dialog.dart await tap(find.byKey(factoryResetPickResetFido2)); await longWait(); - /// 4. Click reset TextButton: done + /// 5. Click reset TextButton: done await tap(find.byKey(factoryResetReset)); await fido2DanceWait(); - /// 5. Click the 'Close' button + /// 6. Click the close button await tap(find.text('Close').hitTestable()); await shortWait(); - - /// TODO 6. Verify Resetedness } + + // /// Factory reset Fido2 application + // Future resetFido2() async { + // final targetKey = approvedKeys[0]; // only reset approved keys! + // + // /// 1. make sure we are using approved key + // await switchToKey(targetKey); + // await shortWait(); + // + // /// 2. open the key menu + // await tapPopupMenu(targetKey); + // await shortWait(); + // await tap(find.byKey(yubikeyFactoryResetMenuButton).hitTestable()); + // await longWait(); + // + // /// 3. then toggle 'Fido2' in the 'Factory reset' reset_dialog.dart + // await tap(find.byKey(factoryResetPickResetFido2)); + // await longWait(); + // + // /// 4. Click reset TextButton: done + // await tap(find.byKey(factoryResetReset)); + // await fido2DanceWait(); + // + // /// 5. Click the 'Close' button + // await tap(find.text('Close').hitTestable()); + // await shortWait(); + // + // /// TODO 6. Verify Resetedness + // } } diff --git a/integration_test/utils/piv_test_util.dart b/integration_test/utils/piv_test_util.dart index 7b636da56..254a04a77 100644 --- a/integration_test/utils/piv_test_util.dart +++ b/integration_test/utils/piv_test_util.dart @@ -22,30 +22,112 @@ import 'package:yubico_authenticator/piv/keys.dart'; import 'test_util.dart'; extension PIVFunctions on WidgetTester { + static const ett = 'firstpin'; + static const lock1 = 'lockpinn1'; + static const lock2 = 'lockpinn2'; + static const lock3 = 'lockpinn3'; + /// Open the PIV Configuration Future configurePiv() async { - // 1. open PIV view - var pivDrawerButton = find.byKey(pivAppDrawer).hitTestable(); - await tap(pivDrawerButton); - await longWait(); + await tap(find.byKey(pivAppDrawer).hitTestable()); + await shortWait(); + await tap(find.byKey(actionsIconButtonKey).hitTestable()); + await shortWait(); + } + + Future pinView() async { + await tap(find.byKey(pivAppDrawer).hitTestable()); + await shortWait(); + await tap(find.byKey(actionsIconButtonKey).hitTestable()); + await shortWait(); + await tap(find.byKey(managePinAction)); + await shortWait(); + } + + Future pukView() async { + await tap(find.byKey(pivAppDrawer).hitTestable()); + await shortWait(); + await tap(find.byKey(actionsIconButtonKey).hitTestable()); + await shortWait(); + await tap(find.byKey(managePukAction)); + await shortWait(); + } + + Future managementKeyView() async { + await tap(find.byKey(pivAppDrawer).hitTestable()); + await shortWait(); await tap(find.byKey(actionsIconButtonKey).hitTestable()); + await shortWait(); + await tap(find.byKey(manageManagementKeyAction)); + await shortWait(); + } + + Future pivFirst() async { + // when in pin or puk view, remove factorypin/puk + await enterText(find.byKey(newPinPukField), ett); + await shortWait(); + await enterText(find.byKey(confirmPinPukField), ett); + await shortWait(); + await tap(find.byKey(saveButton).hitTestable()); + await shortWait(); + } + + Future pivLockTest() async { + // when in pin or puk view this will lock it + var pintext1 = 'lockpin1'; + await enterText(find.byKey(pinPukField), pintext1); + await shortWait(); + await enterText(find.byKey(newPinPukField), pintext1); + await shortWait(); + await enterText(find.byKey(confirmPinPukField), pintext1); + await shortWait(); + await tap(find.byKey(saveButton).hitTestable()); + await shortWait(); + + var pintext2 = 'lockpin2'; + await enterText(find.byKey(pinPukField), pintext2); + await shortWait(); + await enterText(find.byKey(newPinPukField), pintext2); + await shortWait(); + await enterText(find.byKey(confirmPinPukField), pintext2); + await shortWait(); + await tap(find.byKey(saveButton).hitTestable()); + await shortWait(); + + var pintext3 = 'lockpin3'; + await enterText(find.byKey(pinPukField), pintext3); + await shortWait(); + await enterText(find.byKey(newPinPukField), pintext3); + await shortWait(); + await enterText(find.byKey(confirmPinPukField), pintext3); + await shortWait(); + await tap(find.byKey(saveButton).hitTestable()); await longWait(); } - /// Locks PIN or PUK - Future lockPinPuk() async { - for (var i = 0; i < 3; i += 1) { - var wrongpin = '123456$i'; - await enterText(find.byKey(pinPukField).hitTestable(), wrongpin); - await shortWait(); - await enterText(find.byKey(newPinPukField).hitTestable(), wrongpin); - await shortWait(); - await enterText(find.byKey(confirmPinPukField).hitTestable(), wrongpin); - await shortWait(); - await tap(find.byKey(saveButton).hitTestable()); - await longWait(); - } + Future pivLock() async { + // when in pin or puk view this will lock it + // for (var i = 0; i < 3; i += 1) { + + await enterText(find.byKey(pinPukField), 'skrivhär'); + await shortWait(); + await enterText(find.byKey(newPinPukField), lock1); + await shortWait(); + await enterText(find.byKey(confirmPinPukField), lock1); + await shortWait(); + await tap(find.byKey(saveButton).hitTestable()); + await shortWait(); + await enterText(find.byKey(pinPukField), lock2); + await shortWait(); + await enterText(find.byKey(newPinPukField), lock2); + await shortWait(); + await enterText(find.byKey(confirmPinPukField), lock2); + await shortWait(); + await tap(find.byKey(saveButton).hitTestable()); + await shortWait(); + // } await sendKeyEvent(LogicalKeyboardKey.escape); + await shortWait(); } /// Factory reset Piv application @@ -56,19 +138,23 @@ extension PIVFunctions on WidgetTester { await switchToKey(targetKey); await shortWait(); - /// 2. open the key menu - await tapPopupMenu(targetKey); + /// 2. open the home view + await tap(find.byKey(homeDrawer).hitTestable()); await shortWait(); - await tap(find.byKey(yubikeyFactoryResetMenuButton).hitTestable()); - await longWait(); - /// 3. then toggle 'Piv' in the 'Factory reset' reset_dialog.dart + /// 3. open menu + await tap(find.byKey(actionsIconButtonKey).hitTestable()); + await shortWait(); + await tap(find.byKey(yubikeyFactoryResetMenuButton)); + await shortWait(); + + /// 4. then toggle 'Piv' in the 'Factory reset' reset_dialog.dart await tap(find.byKey(factoryResetPickResetPiv)); await longWait(); - /// 4. Click reset TextButton: done + /// 5. Click reset TextButton: done await tap(find.byKey(factoryResetReset)); - await shortWait(); + await longWait(); // 5. Verify Resetedness // /// TODO: this expect algorithm is flaky diff --git a/integration_test/utils/test_util.dart b/integration_test/utils/test_util.dart index 5a2783105..8d15e2f6d 100644 --- a/integration_test/utils/test_util.dart +++ b/integration_test/utils/test_util.dart @@ -22,12 +22,11 @@ import 'package:freezed_annotation/freezed_annotation.dart'; import 'package:yubico_authenticator/app/views/device_picker.dart'; import 'package:yubico_authenticator/app/views/keys.dart'; import 'package:yubico_authenticator/core/state.dart'; -import 'package:yubico_authenticator/management/views/keys.dart'; import 'android/util.dart' as android_test_util; import 'desktop/util.dart' as desktop_test_util; -const shortWaitMs = 200; +const shortWaitMs = 240; const longWaitMs = 500; const ultraLongWaitMs = 3000; @@ -235,15 +234,32 @@ extension AppWidgetTester on WidgetTester { } /// Management screen - Future openManagementScreen() async { - if (!isDrawerOpened()) { - await openDrawer(); - } + Future openHomeAndToggleScreen() async { + // if (!isDrawerOpened()) { + // await openDrawer(); + // } + + await tap(find.byKey(homeDrawer).hitTestable()); + await shortWait(); + + await openToggleScreen(); + + //expect(find.byKey(screenKey), findsOneWidget); + } + + /// Toggle Application screen + Future openToggleScreen() async { + // if (!isDrawerOpened()) { + // await openDrawer(); + // } + + await tap(find.byKey(actionsIconButtonKey).hitTestable()); + await shortWait(); - await tap(find.byKey(managementAppDrawer).hitTestable()); - await pump(const Duration(milliseconds: 500)); + await tap(find.byKey(yubikeyApplicationToggleMenuButton).hitTestable()); + await shortWait(); - expect(find.byKey(screenKey), findsOneWidget); + //expect(find.byKey(screenKey), findsOneWidget); } /// Retrieve a list of test approved serial numbers. diff --git a/lib/home/views/key_actions.dart b/lib/home/views/key_actions.dart index 69df8b309..de19cf560 100644 --- a/lib/home/views/key_actions.dart +++ b/lib/home/views/key_actions.dart @@ -25,6 +25,7 @@ import '../../app/message.dart'; import '../../app/models.dart'; import '../../app/shortcuts.dart'; import '../../app/views/action_list.dart'; +import '../../app/views/keys.dart'; import '../../app/views/reset_dialog.dart'; import '../../core/models.dart'; import '../../core/state.dart'; @@ -57,6 +58,7 @@ Widget homeBuildActions( title: deviceData.info.version.major > 4 ? l10n.s_toggle_applications : l10n.s_toggle_interfaces, + key: yubikeyApplicationToggleMenuButton, subtitle: interfacesLocked ? l10n.l_factory_reset_required : (deviceData.info.version.major > 4 @@ -82,6 +84,7 @@ Widget homeBuildActions( ActionListItem( icon: const Icon(Symbols.delete_forever), title: l10n.s_factory_reset, + key: yubikeyFactoryResetMenuButton, subtitle: l10n.l_factory_reset_desc, actionStyle: ActionStyle.primary, onTap: (context) { @@ -97,6 +100,7 @@ Widget homeBuildActions( ActionListSection(l10n.s_application, children: [ ActionListItem( icon: const Icon(Symbols.settings), + key: settingDrawerIcon, title: l10n.s_settings, subtitle: l10n.l_settings_desc, actionStyle: ActionStyle.primary, @@ -107,6 +111,7 @@ Widget homeBuildActions( ), ActionListItem( icon: const Icon(Symbols.help), + key: helpDrawerIcon, title: l10n.s_help_and_about, subtitle: l10n.l_help_and_about_desc, actionStyle: ActionStyle.primary, diff --git a/lib/piv/keys.dart b/lib/piv/keys.dart index f822b1726..5070293b2 100644 --- a/lib/piv/keys.dart +++ b/lib/piv/keys.dart @@ -40,6 +40,7 @@ const unlockButton = Key('$_prefix.unlock'); const resetButton = Key('$_prefix.reset'); const managementKeyField = Key('$_prefix.management_key'); +const newManagementKeyField = Key('$_prefix.management_key'); const managementKeyRefresh = Key('$_prefix.management_key_refresh'); const pinPukField = Key('$_prefix.pin_puk'); diff --git a/lib/piv/views/manage_key_dialog.dart b/lib/piv/views/manage_key_dialog.dart index c6fac2c97..77aae7e54 100644 --- a/lib/piv/views/manage_key_dialog.dart +++ b/lib/piv/views/manage_key_dialog.dart @@ -292,7 +292,7 @@ class _ManageKeyDialogState extends ConsumerState { }, ).init(), AppTextField( - key: keys.newPinPukField, + key: keys.newManagementKeyField, autofocus: _defaultKeyUsed, autofillHints: const [AutofillHints.newPassword], maxLength: hexLength,