forked from mirrors/qmk_userspace
Refactor Leader key feature (#19632)
Co-authored-by: Drashna Jaelre <drashna@live.com>
This commit is contained in:
parent
d10350cd2c
commit
bbf7a20b33
77 changed files with 2457 additions and 1968 deletions
5
tests/leader/leader_per_key_timeout/config.h
Normal file
5
tests/leader/leader_per_key_timeout/config.h
Normal file
|
@ -0,0 +1,5 @@
|
|||
#pragma once
|
||||
|
||||
#include "test_common.h"
|
||||
|
||||
#define LEADER_PER_KEY_TIMING
|
7
tests/leader/leader_per_key_timeout/test.mk
Normal file
7
tests/leader/leader_per_key_timeout/test.mk
Normal file
|
@ -0,0 +1,7 @@
|
|||
# --------------------------------------------------------------------------------
|
||||
# Keep this file, even if it is empty, as a marker that this folder contains tests
|
||||
# --------------------------------------------------------------------------------
|
||||
|
||||
LEADER_ENABLE = yes
|
||||
|
||||
SRC += ../leader_sequences.c
|
|
@ -0,0 +1,40 @@
|
|||
// Copyright 2023 QMK
|
||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||
|
||||
#include "keyboard_report_util.hpp"
|
||||
#include "keycode.h"
|
||||
#include "test_common.hpp"
|
||||
#include "test_keymap_key.hpp"
|
||||
|
||||
using testing::_;
|
||||
|
||||
class Leader : public TestFixture {};
|
||||
|
||||
TEST_F(Leader, does_not_timeout_during_sequence) {
|
||||
TestDriver driver;
|
||||
|
||||
auto key_leader = KeymapKey(0, 0, 0, QK_LEADER);
|
||||
auto key_a = KeymapKey(0, 1, 0, KC_A);
|
||||
auto key_b = KeymapKey(0, 2, 0, KC_B);
|
||||
auto key_c = KeymapKey(0, 3, 0, KC_C);
|
||||
|
||||
set_keymap({key_leader, key_a, key_b, key_c});
|
||||
|
||||
tap_key(key_leader);
|
||||
|
||||
EXPECT_NO_REPORT(driver);
|
||||
tap_key(key_a);
|
||||
|
||||
idle_for(150);
|
||||
|
||||
EXPECT_NO_REPORT(driver);
|
||||
tap_key(key_b);
|
||||
|
||||
idle_for(150);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_3));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_c);
|
||||
|
||||
idle_for(300);
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue