forked from mfulz_github/qmk_firmware
		
	Actually test for correct key presses
This commit is contained in:
		
							parent
							
								
									fb95d86b39
								
							
						
					
					
						commit
						bd1729d5be
					
				@ -22,7 +22,8 @@ $(TEST)_SRC= \
 | 
				
			|||||||
	$(TMK_COMMON_SRC) \
 | 
						$(TMK_COMMON_SRC) \
 | 
				
			||||||
	$(QUANTUM_SRC) \
 | 
						$(QUANTUM_SRC) \
 | 
				
			||||||
	tests/test_common/matrix.c \
 | 
						tests/test_common/matrix.c \
 | 
				
			||||||
	tests/test_common/test_driver.cpp
 | 
						tests/test_common/test_driver.cpp \
 | 
				
			||||||
 | 
						tests/test_common/keyboard_report_util.cpp
 | 
				
			||||||
$(TEST)_DEFS=$(TMK_COMMON_DEFS)
 | 
					$(TEST)_DEFS=$(TMK_COMMON_DEFS)
 | 
				
			||||||
$(TEST)_CONFIG=$(TEST_PATH)/config.h
 | 
					$(TEST)_CONFIG=$(TEST_PATH)/config.h
 | 
				
			||||||
VPATH+=$(TOP_DIR)/tests/test_common
 | 
					VPATH+=$(TOP_DIR)/tests/test_common
 | 
				
			||||||
 | 
				
			|||||||
@ -21,6 +21,7 @@
 | 
				
			|||||||
#include "keyboard.h"
 | 
					#include "keyboard.h"
 | 
				
			||||||
#include "test_driver.h"
 | 
					#include "test_driver.h"
 | 
				
			||||||
#include "test_matrix.h"
 | 
					#include "test_matrix.h"
 | 
				
			||||||
 | 
					#include "keyboard_report_util.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
using testing::_;
 | 
					using testing::_;
 | 
				
			||||||
using testing::Return;
 | 
					using testing::Return;
 | 
				
			||||||
@ -32,7 +33,7 @@ const uint16_t PROGMEM keymaps[][MATRIX_ROWS][MATRIX_COLS] = {
 | 
				
			|||||||
	},
 | 
						},
 | 
				
			||||||
};
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
TEST(Basic, SendKeyboardIsNotCalledWhenNoKeyIsPressed) {
 | 
					TEST(KeyPress, SendKeyboardIsNotCalledWhenNoKeyIsPressed) {
 | 
				
			||||||
    TestDriver driver;
 | 
					    TestDriver driver;
 | 
				
			||||||
    EXPECT_CALL(driver, send_keyboard_mock(_));
 | 
					    EXPECT_CALL(driver, send_keyboard_mock(_));
 | 
				
			||||||
    keyboard_init();
 | 
					    keyboard_init();
 | 
				
			||||||
@ -41,12 +42,15 @@ TEST(Basic, SendKeyboardIsNotCalledWhenNoKeyIsPressed) {
 | 
				
			|||||||
    keyboard_task();
 | 
					    keyboard_task();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
TEST(Basic, SendKeyboardIsCalledWhenAKeyIsPressed) {
 | 
					TEST(KeyPress, CorrectKeyIsReportedWhenPressed) {
 | 
				
			||||||
    TestDriver driver;
 | 
					    TestDriver driver;
 | 
				
			||||||
    EXPECT_CALL(driver, send_keyboard_mock(_));
 | 
					    EXPECT_CALL(driver, send_keyboard_mock(_));
 | 
				
			||||||
    keyboard_init();
 | 
					    keyboard_init();
 | 
				
			||||||
    press_key(0, 0);
 | 
					    press_key(0, 0);
 | 
				
			||||||
    EXPECT_CALL(driver, keyboard_leds_mock()).WillRepeatedly(Return(0));
 | 
					    EXPECT_CALL(driver, keyboard_leds_mock()).WillRepeatedly(Return(0));
 | 
				
			||||||
 | 
					    EXPECT_CALL(driver, send_keyboard_mock(KeyboardReport(KC_A)));
 | 
				
			||||||
 | 
					    keyboard_task();
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
    EXPECT_CALL(driver, send_keyboard_mock(_));
 | 
					    EXPECT_CALL(driver, send_keyboard_mock(_));
 | 
				
			||||||
    keyboard_task();
 | 
					    keyboard_task();
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
							
								
								
									
										47
									
								
								tests/test_common/keyboard_report_util.cpp
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										47
									
								
								tests/test_common/keyboard_report_util.cpp
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,47 @@
 | 
				
			|||||||
 | 
					/* 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 "keyboard_report_util.h"
 | 
				
			||||||
 | 
					 using namespace testing;
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					bool operator==(const report_keyboard_t& lhs, const report_keyboard_t& rhs) {
 | 
				
			||||||
 | 
					    return memcmp(lhs.raw, rhs.raw, sizeof(lhs.raw))==0;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					std::ostream& operator<<(std::ostream& stream, const report_keyboard_t& value) {
 | 
				
			||||||
 | 
					    stream << "Keyboard report:" << std::endl;
 | 
				
			||||||
 | 
					    stream << (uint32_t)value.keys[0] << std::endl;
 | 
				
			||||||
 | 
					    return stream;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					KeyboardReportMatcher::KeyboardReportMatcher(const std::vector<uint8_t>& keys) {
 | 
				
			||||||
 | 
					    memset(m_report.raw, 0, sizeof(m_report.raw));
 | 
				
			||||||
 | 
					    for (auto k: keys) {
 | 
				
			||||||
 | 
					        add_key_to_report(&m_report, k);
 | 
				
			||||||
 | 
					    }
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					bool KeyboardReportMatcher::MatchAndExplain(report_keyboard_t& report, MatchResultListener* listener) const {
 | 
				
			||||||
 | 
					    return m_report == report;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void KeyboardReportMatcher::DescribeTo(::std::ostream* os) const {
 | 
				
			||||||
 | 
					    *os << "is equal to " << m_report;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					void KeyboardReportMatcher::DescribeNegationTo(::std::ostream* os) const {
 | 
				
			||||||
 | 
					    *os << "is not equal to " << m_report;
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
							
								
								
									
										39
									
								
								tests/test_common/keyboard_report_util.h
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										39
									
								
								tests/test_common/keyboard_report_util.h
									
									
									
									
									
										Normal file
									
								
							@ -0,0 +1,39 @@
 | 
				
			|||||||
 | 
					/* 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/>.
 | 
				
			||||||
 | 
					 */
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					#pragma once
 | 
				
			||||||
 | 
					#include "report.h"
 | 
				
			||||||
 | 
					#include <ostream>
 | 
				
			||||||
 | 
					#include "gmock/gmock.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					bool operator==(const report_keyboard_t& lhs, const report_keyboard_t& rhs);
 | 
				
			||||||
 | 
					std::ostream& operator<<(std::ostream& stream, const report_keyboard_t& value);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					class KeyboardReportMatcher : public testing::MatcherInterface<report_keyboard_t&> {
 | 
				
			||||||
 | 
					 public:
 | 
				
			||||||
 | 
					    KeyboardReportMatcher(const std::vector<uint8_t>& keys);
 | 
				
			||||||
 | 
					    virtual bool MatchAndExplain(report_keyboard_t& report, testing::MatchResultListener* listener) const override;
 | 
				
			||||||
 | 
					    virtual void DescribeTo(::std::ostream* os) const override;
 | 
				
			||||||
 | 
					    virtual void DescribeNegationTo(::std::ostream* os) const override;
 | 
				
			||||||
 | 
					private:
 | 
				
			||||||
 | 
					    report_keyboard_t m_report;
 | 
				
			||||||
 | 
					};
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					template<typename... Ts>
 | 
				
			||||||
 | 
					inline testing::Matcher<report_keyboard_t&> KeyboardReport(Ts... keys) {
 | 
				
			||||||
 | 
					    return testing::MakeMatcher(new KeyboardReportMatcher(std::vector<uint8_t>({keys...})));
 | 
				
			||||||
 | 
					}
 | 
				
			||||||
@ -41,12 +41,12 @@ uint8_t TestDriver::keyboard_leds(void) {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void TestDriver::send_keyboard(report_keyboard_t* report) {
 | 
					void TestDriver::send_keyboard(report_keyboard_t* report) {
 | 
				
			||||||
    m_this->send_keyboard_mock(report);
 | 
					    m_this->send_keyboard_mock(*report);
 | 
				
			||||||
 | 
					
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void TestDriver::send_mouse(report_mouse_t* report) {
 | 
					void TestDriver::send_mouse(report_mouse_t* report) {
 | 
				
			||||||
    m_this->send_mouse_mock(report);
 | 
					    m_this->send_mouse_mock(*report);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void TestDriver::send_system(uint16_t data) {
 | 
					void TestDriver::send_system(uint16_t data) {
 | 
				
			||||||
@ -54,5 +54,5 @@ void TestDriver::send_system(uint16_t data) {
 | 
				
			|||||||
}
 | 
					}
 | 
				
			||||||
 | 
					
 | 
				
			||||||
void TestDriver::send_consumer(uint16_t data) {
 | 
					void TestDriver::send_consumer(uint16_t data) {
 | 
				
			||||||
    m_this->send_consumer_mock(data);
 | 
					    m_this->send_consumer(data);
 | 
				
			||||||
}
 | 
					}
 | 
				
			||||||
 | 
				
			|||||||
@ -20,6 +20,7 @@
 | 
				
			|||||||
#include "gmock/gmock.h"
 | 
					#include "gmock/gmock.h"
 | 
				
			||||||
#include <stdint.h>
 | 
					#include <stdint.h>
 | 
				
			||||||
#include "host.h"
 | 
					#include "host.h"
 | 
				
			||||||
 | 
					#include "keyboard_report_util.h"
 | 
				
			||||||
 | 
					
 | 
				
			||||||
 | 
					
 | 
				
			||||||
class TestDriver {
 | 
					class TestDriver {
 | 
				
			||||||
@ -27,8 +28,8 @@ public:
 | 
				
			|||||||
    TestDriver();
 | 
					    TestDriver();
 | 
				
			||||||
    ~TestDriver();
 | 
					    ~TestDriver();
 | 
				
			||||||
    MOCK_METHOD0(keyboard_leds_mock, uint8_t ());
 | 
					    MOCK_METHOD0(keyboard_leds_mock, uint8_t ());
 | 
				
			||||||
    MOCK_METHOD1(send_keyboard_mock, void (report_keyboard_t*));
 | 
					    MOCK_METHOD1(send_keyboard_mock, void (report_keyboard_t&));
 | 
				
			||||||
    MOCK_METHOD1(send_mouse_mock, void (report_mouse_t*));
 | 
					    MOCK_METHOD1(send_mouse_mock, void (report_mouse_t&));
 | 
				
			||||||
    MOCK_METHOD1(send_system_mock, void (uint16_t));
 | 
					    MOCK_METHOD1(send_system_mock, void (uint16_t));
 | 
				
			||||||
    MOCK_METHOD1(send_consumer_mock, void (uint16_t));
 | 
					    MOCK_METHOD1(send_consumer_mock, void (uint16_t));
 | 
				
			||||||
private:
 | 
					private:
 | 
				
			||||||
 | 
				
			|||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user