mirror of
https://github.com/AppFlowy-IO/AppFlowy.git
synced 2024-08-30 18:12:39 +00:00
test: added tests for key events in selection menu widget
This commit is contained in:
parent
10b6b9e5ad
commit
f49e2571fa
@ -118,6 +118,79 @@ void main() async {
|
|||||||
findsNothing,
|
findsNothing,
|
||||||
);
|
);
|
||||||
});
|
});
|
||||||
|
|
||||||
|
group('tab and arrow keys move selection in desired direction', () {
|
||||||
|
|
||||||
|
testWidgets('left and right keys move selection in desired direction',
|
||||||
|
(tester) async {
|
||||||
|
final editor = await _prepare(tester);
|
||||||
|
|
||||||
|
var initialSelection = getSelectedMenuItem(tester);
|
||||||
|
expect(defaultSelectionMenuItems.indexOf(initialSelection.item), 0);
|
||||||
|
|
||||||
|
await editor.pressLogicKey(LogicalKeyboardKey.arrowRight);
|
||||||
|
|
||||||
|
var newSelection = getSelectedMenuItem(tester);
|
||||||
|
expect(defaultSelectionMenuItems.indexOf(newSelection.item), 5);
|
||||||
|
|
||||||
|
await editor.pressLogicKey(LogicalKeyboardKey.arrowLeft);
|
||||||
|
|
||||||
|
var finalSelection = getSelectedMenuItem(tester);
|
||||||
|
expect(defaultSelectionMenuItems.indexOf(initialSelection.item), 0);
|
||||||
|
});
|
||||||
|
|
||||||
|
testWidgets('up and down keys move selection in desired direction',
|
||||||
|
(tester) async {
|
||||||
|
final editor = await _prepare(tester);
|
||||||
|
|
||||||
|
var initialSelection = getSelectedMenuItem(tester);
|
||||||
|
expect(defaultSelectionMenuItems.indexOf(initialSelection.item), 0);
|
||||||
|
|
||||||
|
await editor.pressLogicKey(LogicalKeyboardKey.arrowDown);
|
||||||
|
|
||||||
|
var newSelection = getSelectedMenuItem(tester);
|
||||||
|
expect(defaultSelectionMenuItems.indexOf(newSelection.item), 1);
|
||||||
|
|
||||||
|
await editor.pressLogicKey(LogicalKeyboardKey.arrowUp);
|
||||||
|
|
||||||
|
var finalSelection = getSelectedMenuItem(tester);
|
||||||
|
expect(defaultSelectionMenuItems.indexOf(finalSelection.item), 0);
|
||||||
|
});
|
||||||
|
|
||||||
|
testWidgets('arrow keys and tab move same selection',
|
||||||
|
(tester) async {
|
||||||
|
final editor = await _prepare(tester);
|
||||||
|
|
||||||
|
var initialSelection = getSelectedMenuItem(tester);
|
||||||
|
expect(defaultSelectionMenuItems.indexOf(initialSelection.item), 0);
|
||||||
|
|
||||||
|
await editor.pressLogicKey(LogicalKeyboardKey.arrowDown);
|
||||||
|
|
||||||
|
var newSelection = getSelectedMenuItem(tester);
|
||||||
|
expect(defaultSelectionMenuItems.indexOf(newSelection.item), 1);
|
||||||
|
|
||||||
|
await editor.pressLogicKey(LogicalKeyboardKey.tab);
|
||||||
|
|
||||||
|
var finalSelection = getSelectedMenuItem(tester);
|
||||||
|
expect(defaultSelectionMenuItems.indexOf(finalSelection.item), 6);
|
||||||
|
});
|
||||||
|
|
||||||
|
testWidgets('tab moves selection to next row Item on reaching end of current row',
|
||||||
|
(tester) async {
|
||||||
|
final editor = await _prepare(tester);
|
||||||
|
|
||||||
|
final initialSelection = getSelectedMenuItem(tester);
|
||||||
|
|
||||||
|
expect(defaultSelectionMenuItems.indexOf(initialSelection.item), 0);
|
||||||
|
|
||||||
|
await editor.pressLogicKey(LogicalKeyboardKey.tab);
|
||||||
|
await editor.pressLogicKey(LogicalKeyboardKey.tab);
|
||||||
|
|
||||||
|
final finalSelection = getSelectedMenuItem(tester);
|
||||||
|
|
||||||
|
expect(defaultSelectionMenuItems.indexOf(finalSelection.item), 1);
|
||||||
|
});
|
||||||
|
});
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -178,3 +251,11 @@ Future<void> _testDefaultSelectionMenuItems(
|
|||||||
expect(node?.attributes.check, false);
|
expect(node?.attributes.check, false);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SelectionMenuItemWidget getSelectedMenuItem(WidgetTester tester) {
|
||||||
|
return tester
|
||||||
|
.state(find.byWidgetPredicate(
|
||||||
|
(widget) => widget is SelectionMenuItemWidget && widget.isSelected,
|
||||||
|
))
|
||||||
|
.widget as SelectionMenuItemWidget;
|
||||||
|
}
|
Loading…
x
Reference in New Issue
Block a user