Add basic timing support, and SFT_T tests
Also expose some bugs...
This commit is contained in:
parent
a62f449659
commit
4e69a8bda6
9 changed files with 157 additions and 27 deletions
|
@ -3,6 +3,13 @@
|
|||
#include "test_driver.h"
|
||||
#include "test_matrix.h"
|
||||
#include "keyboard.h"
|
||||
#include "action.h"
|
||||
#include "action_tapping.h"
|
||||
|
||||
extern "C" {
|
||||
void set_time(uint32_t t);
|
||||
void advance_time(uint32_t ms);
|
||||
}
|
||||
|
||||
using testing::_;
|
||||
using testing::AnyNumber;
|
||||
|
@ -25,12 +32,20 @@ TestFixture::~TestFixture() {
|
|||
TestDriver driver;
|
||||
clear_all_keys();
|
||||
// Run for a while to make sure all keys are completely released
|
||||
// Should probably wait until tapping term etc, has timed out
|
||||
EXPECT_CALL(driver, send_keyboard_mock(_)).Times(AnyNumber());
|
||||
for (int i=0; i<100; i++) {
|
||||
keyboard_task();
|
||||
}
|
||||
idle_for(TAPPING_TERM + 10);
|
||||
testing::Mock::VerifyAndClearExpectations(&driver);
|
||||
// Verify that the matrix really is cleared
|
||||
EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport())).Times(Between(0, 1));
|
||||
}
|
||||
|
||||
void TestFixture::run_one_scan_loop() {
|
||||
keyboard_task();
|
||||
advance_time(1);
|
||||
}
|
||||
|
||||
void TestFixture::idle_for(uint time) {
|
||||
for (uint i=0; i<time; i++) {
|
||||
run_one_scan_loop();
|
||||
}
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue