Merge pull request #2133 from Airblader/feature-2115

Added test for #2097.
This commit is contained in:
Michael Stapelberg 2016-01-04 09:04:51 +01:00
commit ebda8dc372
3 changed files with 117 additions and 49 deletions

View File

@ -15,6 +15,8 @@ our @EXPORT = qw(
set_xkb_group set_xkb_group
xtest_key_press xtest_key_press
xtest_key_release xtest_key_release
xtest_button_press
xtest_button_release
listen_for_binding listen_for_binding
start_binding_capture start_binding_capture
binding_events binding_events
@ -107,7 +109,7 @@ bool set_xkb_group(int group) {
return true; return true;
} }
bool xtest_key(int type, int detail) { bool xtest_input(int type, int detail, int x, int y) {
xcb_generic_error_t *err; xcb_generic_error_t *err;
xcb_void_cookie_t cookie; xcb_void_cookie_t cookie;
@ -117,8 +119,8 @@ bool xtest_key(int type, int detail) {
detail, /* detail */ detail, /* detail */
XCB_CURRENT_TIME, /* time */ XCB_CURRENT_TIME, /* time */
XCB_NONE, /* root */ XCB_NONE, /* root */
0, /* rootX */ x, /* rootX */
0, /* rootY */ y, /* rootY */
XCB_NONE); /* deviceid */ XCB_NONE); /* deviceid */
if ((err = xcb_request_check(conn, cookie)) != NULL) { if ((err = xcb_request_check(conn, cookie)) != NULL) {
fprintf(stderr, "X error code %d\n", err->error_code); fprintf(stderr, "X error code %d\n", err->error_code);
@ -128,6 +130,10 @@ bool xtest_key(int type, int detail) {
return true; return true;
} }
bool xtest_key(int type, int detail) {
return xtest_input(type, detail, 0, 0);
}
bool xtest_key_press(int detail) { bool xtest_key_press(int detail) {
return xtest_key(XCB_KEY_PRESS, detail); return xtest_key(XCB_KEY_PRESS, detail);
} }
@ -136,6 +142,14 @@ bool xtest_key_release(int detail) {
return xtest_key(XCB_KEY_RELEASE, detail); return xtest_key(XCB_KEY_RELEASE, detail);
} }
bool xtest_button_press(int button, int x, int y) {
return xtest_input(XCB_BUTTON_PRESS, button, x, y);
}
bool xtest_button_release(int button, int x, int y) {
return xtest_input(XCB_BUTTON_RELEASE, button, x, y);
}
END_OF_C_CODE END_OF_C_CODE
sub import { sub import {
@ -240,14 +254,26 @@ Returns false when there was an X11 error changing the group, true otherwise.
Sends a KeyPress event via XTEST, with the specified C<$detail>, i.e. key code. Sends a KeyPress event via XTEST, with the specified C<$detail>, i.e. key code.
Use C<xev(1)> to find key codes. Use C<xev(1)> to find key codes.
Returns false when there was an X11 error changing the group, true otherwise. Returns false when there was an X11 error, true otherwise.
=head2 xtest_key_release($detail) =head2 xtest_key_release($detail)
Sends a KeyRelease event via XTEST, with the specified C<$detail>, i.e. key code. Sends a KeyRelease event via XTEST, with the specified C<$detail>, i.e. key code.
Use C<xev(1)> to find key codes. Use C<xev(1)> to find key codes.
Returns false when there was an X11 error changing the group, true otherwise. Returns false when there was an X11 error, true otherwise.
=head2 xtest_button_press($button, $x, $y)
Sends a ButtonPress event via XTEST, with the specified C<$button>.
Returns false when there was an X11 error, true otherwise.
=head2 xtest_button_release($button, $x, $y)
Sends a ButtonRelease event via XTEST, with the specified C<$button>.
Returns false when there was an X11 error, true otherwise.
=head1 AUTHOR =head1 AUTHOR

View File

@ -0,0 +1,42 @@
#!perl
# vim:ts=4:sw=4:expandtab
#
# Please read the following documents before working on tests:
# • http://build.i3wm.org/docs/testsuite.html
# (or docs/testsuite)
#
# • http://build.i3wm.org/docs/lib-i3test.html
# (alternatively: perldoc ./testcases/lib/i3test.pm)
#
# • http://build.i3wm.org/docs/ipc.html
# (or docs/ipc)
#
# • http://onyxneon.com/books/modern_perl/modern_perl_a4.pdf
# (unless you are already familiar with Perl)
#
# Verifies that mouse bindings work on the root window if
# --whole-window is set.
# Ticket: #2115
use i3test i3_autostart => 0;
use i3test::XTEST;
my $config = <<EOT;
# i3 config file (v4)
font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
workspace_auto_back_and_forth no
bindsym --whole-window button4 workspace special
EOT
my $pid = launch_with_config($config);
fresh_workspace;
xtest_button_press(4, 50, 50);
xtest_button_release(4, 50, 50);
sync_with_i3;
is(focused_ws(), 'special', 'the binding was triggered');
exit_gracefully($pid);
done_testing;

View File

@ -17,6 +17,7 @@
# Ensures that mouse bindings on the i3bar work correctly. # Ensures that mouse bindings on the i3bar work correctly.
# Ticket: #1695 # Ticket: #1695
use i3test i3_autostart => 0; use i3test i3_autostart => 0;
use i3test::XTEST;
my ($cv, $timer); my ($cv, $timer);
sub reset_test { sub reset_test {
@ -41,17 +42,13 @@ bar {
} }
EOT EOT
SKIP: { my $pid = launch_with_config($config);
qx(command -v xdotool 2> /dev/null); my $i3 = i3(get_socket_path());
skip 'xdotool is required for this test', 1 if $?; $i3->connect()->recv;
my $ws = fresh_workspace;
my $pid = launch_with_config($config); reset_test;
my $i3 = i3(get_socket_path()); $i3->subscribe({
$i3->connect()->recv;
my $ws = fresh_workspace;
reset_test;
$i3->subscribe({
window => sub { window => sub {
my ($event) = @_; my ($event) = @_;
if ($event->{change} eq 'focus') { if ($event->{change} eq 'focus') {
@ -60,45 +57,48 @@ SKIP: {
}, },
})->recv; })->recv;
my $left = open_window; my $left = open_window;
my $right = open_window; my $right = open_window;
sync_with_i3; sync_with_i3;
my $con = $cv->recv; my $con = $cv->recv;
is($con->{window}, $right->{id}, 'focus is initially on the right container'); is($con->{window}, $right->{id}, 'focus is initially on the right container');
reset_test; reset_test;
qx(xdotool mousemove 3 3 click 1); xtest_button_press(1, 3, 3);
sync_with_i3; xtest_button_release(1, 3, 3);
$con = $cv->recv; sync_with_i3;
is($con->{window}, $left->{id}, 'button 1 moves focus left'); $con = $cv->recv;
reset_test; is($con->{window}, $left->{id}, 'button 1 moves focus left');
reset_test;
qx(xdotool mousemove 3 3 click 2); xtest_button_press(2, 3, 3);
sync_with_i3; xtest_button_release(2, 3, 3);
$con = $cv->recv; sync_with_i3;
is($con->{window}, $right->{id}, 'button 2 moves focus right'); $con = $cv->recv;
reset_test; is($con->{window}, $right->{id}, 'button 2 moves focus right');
reset_test;
qx(xdotool mousemove 3 3 click 3); xtest_button_press(3, 3, 3);
sync_with_i3; xtest_button_release(3, 3, 3);
$con = $cv->recv; sync_with_i3;
is($con->{window}, $left->{id}, 'button 3 moves focus left'); $con = $cv->recv;
reset_test; is($con->{window}, $left->{id}, 'button 3 moves focus left');
reset_test;
qx(xdotool mousemove 3 3 click 4); xtest_button_press(4, 3, 3);
sync_with_i3; xtest_button_release(4, 3, 3);
$con = $cv->recv; sync_with_i3;
is($con->{window}, $right->{id}, 'button 4 moves focus right'); $con = $cv->recv;
reset_test; is($con->{window}, $right->{id}, 'button 4 moves focus right');
reset_test;
qx(xdotool mousemove 3 3 click 5); xtest_button_press(5, 3, 3);
sync_with_i3; xtest_button_release(5, 3, 3);
$con = $cv->recv; sync_with_i3;
is($con->{window}, $left->{id}, 'button 5 moves focus left'); $con = $cv->recv;
reset_test; is($con->{window}, $left->{id}, 'button 5 moves focus left');
reset_test;
exit_gracefully($pid); exit_gracefully($pid);
}
done_testing; done_testing;