Unicode, Unicodemap and UCIS refactor (#21659)
This commit is contained in:
parent
95681b8ff4
commit
70e34e491c
34 changed files with 1196 additions and 386 deletions
8
tests/unicode/config.h
Normal file
8
tests/unicode/config.h
Normal file
|
@ -0,0 +1,8 @@
|
|||
// Copyright 2023 QMK
|
||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "test_common.h"
|
||||
|
||||
#define UNICODE_SELECTED_MODES UNICODE_MODE_LINUX, UNICODE_MODE_MACOS
|
5
tests/unicode/test.mk
Normal file
5
tests/unicode/test.mk
Normal file
|
@ -0,0 +1,5 @@
|
|||
# --------------------------------------------------------------------------------
|
||||
# Keep this file, even if it is empty, as a marker that this folder contains tests
|
||||
# --------------------------------------------------------------------------------
|
||||
|
||||
UNICODE_COMMON = yes
|
86
tests/unicode/test_unicode.cpp
Normal file
86
tests/unicode/test_unicode.cpp
Normal file
|
@ -0,0 +1,86 @@
|
|||
// 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 Unicode : public TestFixture {};
|
||||
|
||||
TEST_F(Unicode, sends_bmp_unicode_sequence) {
|
||||
TestDriver driver;
|
||||
|
||||
set_unicode_input_mode(UNICODE_MODE_LINUX);
|
||||
|
||||
EXPECT_UNICODE(driver, 0x03A8); // Ψ
|
||||
register_unicode(0x03A8);
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
||||
|
||||
TEST_F(Unicode, sends_smp_unicode_sequence) {
|
||||
TestDriver driver;
|
||||
|
||||
set_unicode_input_mode(UNICODE_MODE_LINUX);
|
||||
|
||||
EXPECT_UNICODE(driver, 0x1F9D9); // 🧙
|
||||
register_unicode(0x1F9D9);
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
||||
|
||||
TEST_F(Unicode, sends_surrogate_pair_for_macos) {
|
||||
TestDriver driver;
|
||||
|
||||
set_unicode_input_mode(UNICODE_MODE_MACOS);
|
||||
|
||||
// EXPECT_UNICODE() assumes Linux input mode
|
||||
{
|
||||
testing::InSequence s;
|
||||
|
||||
// Alt+D83EDDD9 🧙
|
||||
EXPECT_REPORT(driver, (KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_D, KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_8, KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_3, KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_E, KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_D, KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_D, KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_D, KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_9, KC_LEFT_ALT));
|
||||
EXPECT_REPORT(driver, (KC_LEFT_ALT));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
}
|
||||
|
||||
register_unicode(0x1F9D9);
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
||||
|
||||
TEST_F(Unicode, sends_unicode_string) {
|
||||
TestDriver driver;
|
||||
|
||||
set_unicode_input_mode(UNICODE_MODE_LINUX);
|
||||
|
||||
{
|
||||
testing::InSequence s;
|
||||
|
||||
EXPECT_UNICODE(driver, 0xFF31);
|
||||
EXPECT_UNICODE(driver, 0xFF2D);
|
||||
EXPECT_UNICODE(driver, 0xFF2B);
|
||||
EXPECT_UNICODE(driver, 0xFF01);
|
||||
}
|
||||
send_unicode_string("QMK!");
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
8
tests/unicode/unicode_basic/config.h
Normal file
8
tests/unicode/unicode_basic/config.h
Normal file
|
@ -0,0 +1,8 @@
|
|||
// Copyright 2023 QMK
|
||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "test_common.h"
|
||||
|
||||
#define UNICODE_SELECTED_MODES UNICODE_MODE_LINUX, UNICODE_MODE_MACOS
|
5
tests/unicode/unicode_basic/test.mk
Normal file
5
tests/unicode/unicode_basic/test.mk
Normal file
|
@ -0,0 +1,5 @@
|
|||
# --------------------------------------------------------------------------------
|
||||
# Keep this file, even if it is empty, as a marker that this folder contains tests
|
||||
# --------------------------------------------------------------------------------
|
||||
|
||||
UNICODE_ENABLE = yes
|
26
tests/unicode/unicode_basic/test_unicode_basic.cpp
Normal file
26
tests/unicode/unicode_basic/test_unicode_basic.cpp
Normal file
|
@ -0,0 +1,26 @@
|
|||
// 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 UnicodeBasic : public TestFixture {};
|
||||
|
||||
TEST_F(UnicodeBasic, sends_unicode_sequence) {
|
||||
TestDriver driver;
|
||||
|
||||
set_unicode_input_mode(UNICODE_MODE_LINUX);
|
||||
|
||||
auto key_uc = KeymapKey(0, 0, 0, UC(0x03A8)); // Ψ
|
||||
|
||||
set_keymap({key_uc});
|
||||
|
||||
EXPECT_UNICODE(driver, 0x03A8);
|
||||
tap_key(key_uc);
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
8
tests/unicode/unicode_map/config.h
Normal file
8
tests/unicode/unicode_map/config.h
Normal file
|
@ -0,0 +1,8 @@
|
|||
// Copyright 2023 QMK
|
||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "test_common.h"
|
||||
|
||||
#define UNICODE_SELECTED_MODES UNICODE_MODE_LINUX
|
5
tests/unicode/unicode_map/test.mk
Normal file
5
tests/unicode/unicode_map/test.mk
Normal file
|
@ -0,0 +1,5 @@
|
|||
# --------------------------------------------------------------------------------
|
||||
# Keep this file, even if it is empty, as a marker that this folder contains tests
|
||||
# --------------------------------------------------------------------------------
|
||||
|
||||
UNICODEMAP_ENABLE = yes
|
54
tests/unicode/unicode_map/test_unicode_map.cpp
Normal file
54
tests/unicode/unicode_map/test_unicode_map.cpp
Normal file
|
@ -0,0 +1,54 @@
|
|||
// 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::_;
|
||||
|
||||
const uint32_t PROGMEM unicode_map[] = {
|
||||
0x03A8, // Ψ
|
||||
0x2318 // ⌘
|
||||
};
|
||||
|
||||
class UnicodeMap : public TestFixture {};
|
||||
|
||||
TEST_F(UnicodeMap, sends_unicodemap_code_point_from_keycode) {
|
||||
TestDriver driver;
|
||||
|
||||
auto key_um = KeymapKey(0, 0, 0, UM(0));
|
||||
|
||||
set_keymap({key_um});
|
||||
|
||||
EXPECT_UNICODE(driver, 0x03A8);
|
||||
tap_key(key_um);
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
||||
|
||||
TEST_F(UnicodeMap, sends_unicodemap_pair_from_keycode) {
|
||||
TestDriver driver;
|
||||
|
||||
auto key_shift = KeymapKey(0, 0, 0, KC_LEFT_SHIFT);
|
||||
auto key_up = KeymapKey(0, 1, 0, UP(0, 1));
|
||||
|
||||
set_keymap({key_shift, key_up});
|
||||
|
||||
EXPECT_UNICODE(driver, 0x03A8);
|
||||
tap_key(key_up);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_LEFT_SHIFT));
|
||||
key_shift.press();
|
||||
run_one_scan_loop();
|
||||
|
||||
EXPECT_UNICODE(driver, 0x2318);
|
||||
tap_key(key_up);
|
||||
|
||||
EXPECT_NO_REPORT(driver);
|
||||
key_shift.release();
|
||||
run_one_scan_loop();
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
8
tests/unicode/unicode_ucis/config.h
Normal file
8
tests/unicode/unicode_ucis/config.h
Normal file
|
@ -0,0 +1,8 @@
|
|||
// Copyright 2023 QMK
|
||||
// SPDX-License-Identifier: GPL-2.0-or-later
|
||||
|
||||
#pragma once
|
||||
|
||||
#include "test_common.h"
|
||||
|
||||
#define UNICODE_SELECTED_MODES UNICODE_MODE_LINUX
|
5
tests/unicode/unicode_ucis/test.mk
Normal file
5
tests/unicode/unicode_ucis/test.mk
Normal file
|
@ -0,0 +1,5 @@
|
|||
# --------------------------------------------------------------------------------
|
||||
# Keep this file, even if it is empty, as a marker that this folder contains tests
|
||||
# --------------------------------------------------------------------------------
|
||||
|
||||
UCIS_ENABLE = yes
|
221
tests/unicode/unicode_ucis/test_unicode_ucis.cpp
Normal file
221
tests/unicode/unicode_ucis/test_unicode_ucis.cpp
Normal file
|
@ -0,0 +1,221 @@
|
|||
// 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::_;
|
||||
|
||||
// clang-format off
|
||||
const ucis_symbol_t ucis_symbol_table[] = UCIS_TABLE(
|
||||
UCIS_SYM("qmk", 0x03A8) // Ψ
|
||||
);
|
||||
// clang-format on
|
||||
|
||||
class UnicodeUCIS : public TestFixture {};
|
||||
|
||||
TEST_F(UnicodeUCIS, matches_sequence) {
|
||||
TestDriver driver;
|
||||
|
||||
auto key_q = KeymapKey(0, 0, 0, KC_Q);
|
||||
auto key_m = KeymapKey(0, 1, 0, KC_M);
|
||||
auto key_k = KeymapKey(0, 2, 0, KC_K);
|
||||
auto key_enter = KeymapKey(0, 3, 0, KC_ENTER);
|
||||
|
||||
set_keymap({key_q, key_m, key_k, key_enter});
|
||||
|
||||
EXPECT_UNICODE(driver, 0x2328); // ⌨
|
||||
ucis_start();
|
||||
|
||||
EXPECT_EQ(ucis_active(), true);
|
||||
EXPECT_EQ(ucis_count(), 0);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_Q));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_q);
|
||||
EXPECT_EQ(ucis_count(), 1);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_M));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_m);
|
||||
EXPECT_EQ(ucis_count(), 2);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_K));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_k);
|
||||
EXPECT_EQ(ucis_count(), 3);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_BACKSPACE)).Times(4);
|
||||
EXPECT_EMPTY_REPORT(driver).Times(4);
|
||||
EXPECT_UNICODE(driver, 0x03A8);
|
||||
tap_key(key_enter);
|
||||
|
||||
EXPECT_EQ(ucis_active(), false);
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
||||
|
||||
TEST_F(UnicodeUCIS, cancels_sequence) {
|
||||
TestDriver driver;
|
||||
|
||||
auto key_q = KeymapKey(0, 0, 0, KC_Q);
|
||||
auto key_m = KeymapKey(0, 1, 0, KC_M);
|
||||
auto key_k = KeymapKey(0, 2, 0, KC_K);
|
||||
auto key_escape = KeymapKey(0, 3, 0, KC_ESCAPE);
|
||||
|
||||
set_keymap({key_q, key_m, key_k, key_escape});
|
||||
|
||||
EXPECT_UNICODE(driver, 0x2328); // ⌨
|
||||
ucis_start();
|
||||
|
||||
EXPECT_EQ(ucis_active(), true);
|
||||
EXPECT_EQ(ucis_count(), 0);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_Q));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_q);
|
||||
EXPECT_EQ(ucis_count(), 1);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_M));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_m);
|
||||
EXPECT_EQ(ucis_count(), 2);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_K));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_k);
|
||||
EXPECT_EQ(ucis_count(), 3);
|
||||
|
||||
EXPECT_NO_REPORT(driver);
|
||||
tap_key(key_escape);
|
||||
|
||||
EXPECT_EQ(ucis_active(), false);
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
||||
|
||||
TEST_F(UnicodeUCIS, matches_sequence_with_corrected_typo) {
|
||||
TestDriver driver;
|
||||
|
||||
auto key_q = KeymapKey(0, 0, 0, KC_Q);
|
||||
auto key_m = KeymapKey(0, 1, 0, KC_M);
|
||||
auto key_j = KeymapKey(0, 2, 0, KC_J);
|
||||
auto key_k = KeymapKey(0, 3, 0, KC_K);
|
||||
auto key_backspace = KeymapKey(0, 4, 0, KC_BACKSPACE);
|
||||
auto key_enter = KeymapKey(0, 5, 0, KC_ENTER);
|
||||
|
||||
set_keymap({key_q, key_m, key_j, key_k, key_backspace, key_enter});
|
||||
|
||||
EXPECT_UNICODE(driver, 0x2328); // ⌨
|
||||
ucis_start();
|
||||
|
||||
EXPECT_EQ(ucis_active(), true);
|
||||
EXPECT_EQ(ucis_count(), 0);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_Q));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_q);
|
||||
EXPECT_EQ(ucis_count(), 1);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_M));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_m);
|
||||
EXPECT_EQ(ucis_count(), 2);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_J));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_j);
|
||||
EXPECT_EQ(ucis_count(), 3);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_BACKSPACE));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_backspace);
|
||||
EXPECT_EQ(ucis_count(), 2);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_K));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_k);
|
||||
EXPECT_EQ(ucis_count(), 3);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_BACKSPACE)).Times(4);
|
||||
EXPECT_EMPTY_REPORT(driver).Times(4);
|
||||
EXPECT_UNICODE(driver, 0x03A8);
|
||||
tap_key(key_enter);
|
||||
|
||||
EXPECT_EQ(ucis_active(), false);
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
||||
|
||||
TEST_F(UnicodeUCIS, does_not_match_longer_sequence) {
|
||||
TestDriver driver;
|
||||
|
||||
auto key_q = KeymapKey(0, 0, 0, KC_Q);
|
||||
auto key_m = KeymapKey(0, 1, 0, KC_M);
|
||||
auto key_k = KeymapKey(0, 2, 0, KC_K);
|
||||
auto key_enter = KeymapKey(0, 3, 0, KC_ENTER);
|
||||
|
||||
set_keymap({key_q, key_m, key_k, key_enter});
|
||||
|
||||
EXPECT_UNICODE(driver, 0x2328); // ⌨
|
||||
ucis_start();
|
||||
|
||||
EXPECT_EQ(ucis_active(), true);
|
||||
EXPECT_EQ(ucis_count(), 0);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_Q));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_q);
|
||||
EXPECT_EQ(ucis_count(), 1);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_M));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_m);
|
||||
EXPECT_EQ(ucis_count(), 2);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_K));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_k);
|
||||
EXPECT_EQ(ucis_count(), 3);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_K));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_k);
|
||||
EXPECT_EQ(ucis_count(), 4);
|
||||
|
||||
EXPECT_NO_REPORT(driver);
|
||||
tap_key(key_enter);
|
||||
|
||||
EXPECT_EQ(ucis_active(), false);
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
||||
|
||||
TEST_F(UnicodeUCIS, does_not_match_shorter_sequence) {
|
||||
TestDriver driver;
|
||||
|
||||
auto key_q = KeymapKey(0, 0, 0, KC_Q);
|
||||
auto key_enter = KeymapKey(0, 1, 0, KC_ENTER);
|
||||
|
||||
set_keymap({key_q, key_enter});
|
||||
|
||||
EXPECT_UNICODE(driver, 0x2328); // ⌨
|
||||
ucis_start();
|
||||
|
||||
EXPECT_EQ(ucis_active(), true);
|
||||
EXPECT_EQ(ucis_count(), 0);
|
||||
|
||||
EXPECT_REPORT(driver, (KC_Q));
|
||||
EXPECT_EMPTY_REPORT(driver);
|
||||
tap_key(key_q);
|
||||
EXPECT_EQ(ucis_count(), 1);
|
||||
|
||||
EXPECT_NO_REPORT(driver);
|
||||
tap_key(key_enter);
|
||||
|
||||
EXPECT_EQ(ucis_active(), false);
|
||||
|
||||
VERIFY_AND_CLEAR(driver);
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue