From 6c7e8129663024329e30e6905573fb76bdb96e0a Mon Sep 17 00:00:00 2001 From: Connor Brewster Date: Wed, 6 Jul 2016 22:38:23 -0600 Subject: [PATCH] Add unit test for setting selection with selection direction --- tests/unit/script/textinput.rs | 23 +++++++++++++++++++++++ 1 file changed, 23 insertions(+) diff --git a/tests/unit/script/textinput.rs b/tests/unit/script/textinput.rs index d5e9c1268d6..01d8931ff67 100644 --- a/tests/unit/script/textinput.rs +++ b/tests/unit/script/textinput.rs @@ -458,3 +458,26 @@ fn test_textinput_cursor_position_correct_after_clearing_selection() { assert_eq!(textinput.edit_point.index, 0); assert_eq!(textinput.edit_point.line, 0); } + + +#[test] +fn test_textinput_set_selection_with_direction() { + let mut textinput = text_input(Lines::Single, "abcdef"); + textinput.selection_direction = SelectionDirection::Forward; + textinput.set_selection_range(2, 6); + assert_eq!(textinput.edit_point.line, 0); + assert_eq!(textinput.edit_point.index, 6); + + assert!(textinput.selection_begin.is_some()); + assert_eq!(textinput.selection_begin.unwrap().line, 0); + assert_eq!(textinput.selection_begin.unwrap().index, 2); + + textinput.selection_direction = SelectionDirection::Backward; + textinput.set_selection_range(2, 6); + assert_eq!(textinput.edit_point.line, 0); + assert_eq!(textinput.edit_point.index, 2); + + assert!(textinput.selection_begin.is_some()); + assert_eq!(textinput.selection_begin.unwrap().line, 0); + assert_eq!(textinput.selection_begin.unwrap().index, 6); +}