Dump app on keyboard_textfield_test timeout (#98305)

This commit is contained in:
LongCatIsLooong 2022-02-13 17:20:18 -08:00 committed by GitHub
parent 5515400a1b
commit ad612b59e5
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
2 changed files with 20 additions and 4 deletions

View file

@ -62,10 +62,11 @@ class _MyHomePageState extends State<MyHomePage> {
Text('$offset',
key: const ValueKey<String>(keys.kOffsetText),
),
if (isSoftKeyboardVisible) const Text(
'keyboard visible',
key: ValueKey<String>(keys.kKeyboardVisibleView),
Text(
isSoftKeyboardVisible ? 'keyboard visible' : 'keyboard hidden',
key: const ValueKey<String>(keys.kKeyboardVisibleView),
),
const ElevatedButton(onPressed: debugDumpApp, child: Text('dump app')),
Expanded(
child: ListView(
key: const ValueKey<String>(keys.kListView),

View file

@ -40,8 +40,23 @@ void main() {
// Bring up keyboard
await driver.tap(textFieldFinder);
const int keyboardTimeout = 3;
bool keyboardVisible = false;
for (int i = 0; i < keyboardTimeout; i++) {
await Future<void>.delayed(const Duration(seconds: 1));
final String keyboardVisibilityText = await driver.getText(keyboardVisibilityIndicatorFinder);
keyboardVisible = keyboardVisibilityText == 'keyboard visible';
if (keyboardVisible) {
break;
}
}
if (!keyboardVisible) {
await driver.tap(find.text('dump app'));
}
// TODO(jmagman): Remove timeout once flake has been diagnosed. https://github.com/flutter/flutter/issues/96787
await driver.waitFor(keyboardVisibilityIndicatorFinder, timeout: const Duration(seconds: 5));
expect(keyboardVisible, isTrue);
// Ensure that TextField is visible again
await driver.waitFor(textFieldFinder);