You can not select more than 25 topics
			Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
		
		
		
		
		
			
		
			
				
					
					
						
							99 lines
						
					
					
						
							4.0 KiB
						
					
					
				
			
		
		
	
	
							99 lines
						
					
					
						
							4.0 KiB
						
					
					
				| /* Copyright 2017 Fred Sundvik
 | |
|  *
 | |
|  * This program is free software: you can redistribute it and/or modify
 | |
|  * it under the terms of the GNU General Public License as published by
 | |
|  * the Free Software Foundation, either version 2 of the License, or
 | |
|  * (at your option) any later version.
 | |
|  *
 | |
|  * This program is distributed in the hope that it will be useful,
 | |
|  * but WITHOUT ANY WARRANTY; without even the implied warranty of
 | |
|  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
 | |
|  * GNU General Public License for more details.
 | |
|  *
 | |
|  * You should have received a copy of the GNU General Public License
 | |
|  * along with this program.  If not, see <http://www.gnu.org/licenses/>.
 | |
|  */
 | |
| 
 | |
| #include "test_common.hpp"
 | |
| #include "time.h"
 | |
| 
 | |
| using testing::InSequence;
 | |
| using testing::InvokeWithoutArgs;
 | |
| 
 | |
| class Macro : public TestFixture {};
 | |
| 
 | |
| #define AT_TIME(t) WillOnce(InvokeWithoutArgs([current_time]() {EXPECT_EQ(timer_elapsed32(current_time), t);}))
 | |
| 
 | |
| TEST_F(Macro, PlayASimpleMacro) {
 | |
|     TestDriver driver;
 | |
|     InSequence s;
 | |
|     press_key(8, 0);
 | |
|     uint32_t current_time = timer_read32();
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_LSFT)))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_LSFT, KC_H)))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_LSFT)))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_E)))
 | |
|         .AT_TIME(0);
 | |
|     // The macro system could actually skip these empty keyboard reports
 | |
|     // it should be enough to just send a report with the next key down
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_L)))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_L)))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_O)))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_SPACE)))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|         .AT_TIME(0);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_LSFT)))
 | |
|         .AT_TIME(100);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_LSFT, KC_W)))
 | |
|         .AT_TIME(100);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_LSFT)))
 | |
|         .AT_TIME(100);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|         .AT_TIME(100);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_O)))
 | |
|     // BUG: The timer should not really have advanced 10 ms here
 | |
|     // See issue #1477
 | |
|         .AT_TIME(110);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|     // BUG: The timer should not advance on both keydown and key-up
 | |
|     // See issue #1477
 | |
|         .AT_TIME(120);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_R)))
 | |
|         .AT_TIME(130);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|         .AT_TIME(140);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_L)))
 | |
|         .AT_TIME(150);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|         .AT_TIME(160);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_D)))
 | |
|         .AT_TIME(170);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|         .AT_TIME(180);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_LSFT)))
 | |
|         .AT_TIME(190);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_LSFT, KC_1)))
 | |
|         .AT_TIME(200);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_LSFT)))
 | |
|         .AT_TIME(210);
 | |
|     EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport()))
 | |
|         .AT_TIME(220);
 | |
|     run_one_scan_loop();
 | |
| } |