forked from mfulz_github/qmk_firmware
		
	* 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();
 | 
						|
    }
 | 
						|
}
 |