summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorJonathan Rascher <jon@bcat.name>2021-10-02 00:27:49 -0400
committerPete Johanson <peter@peterjohanson.com>2021-11-15 05:49:23 -0500
commit6cd1734851c31884cdf14b40fddc5a9df273b296 (patch)
tree76df9c4067a03daf0726a8c1656161d0a57b5283
parenta908396013f4af15dd906cc882e23baa121bf89c (diff)
test(conditional-layers): Add interleaved up/downs
-rw-r--r--app/tests/conditional-layer/tri-layer-alt-order/events.patterns3
-rw-r--r--app/tests/conditional-layer/tri-layer-alt-order/keycode_events.snapshot8
-rw-r--r--app/tests/conditional-layer/tri-layer-alt-order/native_posix.keymap52
3 files changed, 63 insertions, 0 deletions
diff --git a/app/tests/conditional-layer/tri-layer-alt-order/events.patterns b/app/tests/conditional-layer/tri-layer-alt-order/events.patterns
new file mode 100644
index 0000000..14ded79
--- /dev/null
+++ b/app/tests/conditional-layer/tri-layer-alt-order/events.patterns
@@ -0,0 +1,3 @@
+s/.*hid_listener_keycode/kp/p
+s/.*mo_keymap_binding/mo/p
+s/.*conditional_layer/cl/p
diff --git a/app/tests/conditional-layer/tri-layer-alt-order/keycode_events.snapshot b/app/tests/conditional-layer/tri-layer-alt-order/keycode_events.snapshot
new file mode 100644
index 0000000..05337b2
--- /dev/null
+++ b/app/tests/conditional-layer/tri-layer-alt-order/keycode_events.snapshot
@@ -0,0 +1,8 @@
+mo_pressed: position 3 layer 2
+mo_pressed: position 2 layer 1
+cl_activate: layer 3
+kp_pressed: usage_page 0x07 keycode 0x0a implicit_mods 0x00 explicit_mods 0x00
+mo_released: position 3 layer 2
+cl_deactivate: layer 3
+mo_released: position 2 layer 1
+kp_released: usage_page 0x07 keycode 0x0a implicit_mods 0x00 explicit_mods 0x00
diff --git a/app/tests/conditional-layer/tri-layer-alt-order/native_posix.keymap b/app/tests/conditional-layer/tri-layer-alt-order/native_posix.keymap
new file mode 100644
index 0000000..a315403
--- /dev/null
+++ b/app/tests/conditional-layer/tri-layer-alt-order/native_posix.keymap
@@ -0,0 +1,52 @@
+#include <behaviors.dtsi>
+#include <dt-bindings/zmk/keys.h>
+#include <dt-bindings/zmk/kscan_mock.h>
+
+/ {
+ conditional_layers {
+ compatible = "zmk,conditional-layers";
+ tri_layer {
+ if-layers = <1 2>;
+ then-layer = <3>;
+ };
+ };
+
+ keymap {
+ compatible = "zmk,keymap";
+ default_layer {
+ bindings = <
+ &kp A &kp B
+ &mo 1 &mo 2
+ >;
+ };
+ layer_1 {
+ bindings = <
+ &kp C &kp D
+ &trans &trans
+ >;
+ };
+ layer_2 {
+ bindings = <
+ &kp E &kp F
+ &trans &trans
+ >;
+ };
+ layer_3 {
+ bindings = <
+ &kp G &kp H
+ &trans &trans
+ >;
+ };
+ };
+};
+
+&kscan {
+ events = <
+ ZMK_MOCK_PRESS(1,1,10)
+ ZMK_MOCK_PRESS(1,0,10)
+ ZMK_MOCK_PRESS(0,0,10)
+ ZMK_MOCK_RELEASE(1,1,10)
+ ZMK_MOCK_RELEASE(1,0,10)
+ ZMK_MOCK_RELEASE(0,0,10)
+ >;
+};