1
0
Fork 0

Unicode, Unicodemap and UCIS refactor (#21659)

This commit is contained in:
Ryan 2023-08-27 13:30:19 +10:00 committed by GitHub
parent 95681b8ff4
commit 70e34e491c
No known key found for this signature in database
GPG key ID: 4AEE18F83AFDEB23
34 changed files with 1196 additions and 386 deletions

8
tests/unicode/config.h Normal file
View 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
View file

@ -0,0 +1,5 @@
# --------------------------------------------------------------------------------
# Keep this file, even if it is empty, as a marker that this folder contains tests
# --------------------------------------------------------------------------------
UNICODE_COMMON = yes

View 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("");
VERIFY_AND_CLEAR(driver);
}

View 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

View file

@ -0,0 +1,5 @@
# --------------------------------------------------------------------------------
# Keep this file, even if it is empty, as a marker that this folder contains tests
# --------------------------------------------------------------------------------
UNICODE_ENABLE = yes

View 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);
}

View 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

View file

@ -0,0 +1,5 @@
# --------------------------------------------------------------------------------
# Keep this file, even if it is empty, as a marker that this folder contains tests
# --------------------------------------------------------------------------------
UNICODEMAP_ENABLE = yes

View 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);
}

View 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

View file

@ -0,0 +1,5 @@
# --------------------------------------------------------------------------------
# Keep this file, even if it is empty, as a marker that this folder contains tests
# --------------------------------------------------------------------------------
UCIS_ENABLE = yes

View 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);
}