mirror of
https://github.com/Keychron/qmk_firmware.git
synced 2024-11-23 17:06:52 +06:00
fc9fb2c775
* Initial pass at enabling logging for unit tests * Add to docs * Bind debug for more test types * Force everything * Tidy up slightly
60 lines
1.4 KiB
C++
60 lines
1.4 KiB
C++
#include "test_fixture.hpp"
|
|
#include "gmock/gmock.h"
|
|
#include "test_driver.hpp"
|
|
#include "test_matrix.h"
|
|
#include "keyboard.h"
|
|
#include "action.h"
|
|
#include "action_tapping.h"
|
|
|
|
extern "C" {
|
|
#include "debug.h"
|
|
#include "eeconfig.h"
|
|
#include "action_layer.h"
|
|
|
|
void set_time(uint32_t t);
|
|
void advance_time(uint32_t ms);
|
|
}
|
|
|
|
using testing::_;
|
|
using testing::AnyNumber;
|
|
using testing::Between;
|
|
using testing::Return;
|
|
|
|
void TestFixture::SetUpTestCase() {
|
|
// The following is enough to bootstrap the values set in main
|
|
eeconfig_init_quantum();
|
|
eeconfig_update_debug(debug_config.raw);
|
|
|
|
TestDriver driver;
|
|
EXPECT_CALL(driver, send_keyboard_mock(_));
|
|
keyboard_init();
|
|
}
|
|
|
|
void TestFixture::TearDownTestCase() {}
|
|
|
|
TestFixture::TestFixture() {}
|
|
|
|
TestFixture::~TestFixture() {
|
|
TestDriver driver;
|
|
// Run for a while to make sure all keys are completely released
|
|
EXPECT_CALL(driver, send_keyboard_mock(_)).Times(AnyNumber());
|
|
layer_clear();
|
|
clear_all_keys();
|
|
idle_for(TAPPING_TERM + 10);
|
|
testing::Mock::VerifyAndClearExpectations(&driver);
|
|
// Verify that the matrix really is cleared
|
|
EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport())).Times(0);
|
|
idle_for(TAPPING_TERM + 10);
|
|
}
|
|
|
|
void TestFixture::run_one_scan_loop() {
|
|
keyboard_task();
|
|
advance_time(1);
|
|
}
|
|
|
|
void TestFixture::idle_for(unsigned time) {
|
|
for (unsigned i = 0; i < time; i++) {
|
|
run_one_scan_loop();
|
|
}
|
|
}
|