From 87ced0438aa7a637d7f1f1d4e120a99b8b29a912 Mon Sep 17 00:00:00 2001 From: Michael Stapelberg Date: Wed, 7 Oct 2009 21:50:23 +0200 Subject: [PATCH] Add testcase for the mark/goto command --- testcases/Makefile | 2 +- testcases/t/11-goto.t | 84 +++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 85 insertions(+), 1 deletion(-) create mode 100644 testcases/t/11-goto.t diff --git a/testcases/Makefile b/testcases/Makefile index 45cc1800..678312a9 100644 --- a/testcases/Makefile +++ b/testcases/Makefile @@ -1,4 +1,4 @@ test: - PERL_DL_NONLAZY=1 /usr/bin/perl "-MExtUtils::Command::MM" "-e" "test_harness(1, '/home/michael//X11-XCB/lib/', '/home/michael//X11-XCB/blib/lib', '/home/michael//X11-XCB/blib/arch', '/home/michael/X11-XCB/X11-XCB-XS/lib', '/home/michael/X11-XCB/X11-XCB-XS/blib/arch')" t/*.t + PERL_DL_NONLAZY=1 /usr/bin/perl "-MExtUtils::Command::MM" "-e" "test_harness(1, '/home/michael//X11-XCB/lib/', '/home/michael//X11-XCB/blib/lib', '/home/michael//X11-XCB/blib/arch', '/home/michael/X11-XCB/X11-XCB-XS/lib', '/home/michael/X11-XCB/X11-XCB-XS/blib/arch')" t/11-*.t all: test diff --git a/testcases/t/11-goto.t b/testcases/t/11-goto.t new file mode 100644 index 00000000..b08509f8 --- /dev/null +++ b/testcases/t/11-goto.t @@ -0,0 +1,84 @@ +#!perl +# vim:ts=4:sw=4:expandtab +# Beware that this test uses workspace 9 to perform some tests (it expects +# the workspace to be empty). +# TODO: skip it by default? + +use Test::More tests => 9; +use Test::Deep; +use X11::XCB qw(:all); +use Data::Dumper; +use Time::HiRes qw(sleep); +use FindBin; +use Digest::SHA1 qw(sha1_base64); +use lib "$FindBin::Bin/lib"; +use i3test; + +BEGIN { + use_ok('IO::Socket::UNIX') or BAIL_OUT('Cannot load IO::Socket::UNIX'); + use_ok('X11::XCB::Connection') or BAIL_OUT('Cannot load X11::XCB::Connection'); +} + +X11::XCB::Connection->connect(':0'); + +my $sock = IO::Socket::UNIX->new(Peer => '/tmp/i3-ipc.sock'); +isa_ok($sock, 'IO::Socket::UNIX'); + +# Switch to the nineth workspace +$sock->write(i3test::format_ipc_command("9")); + +sleep(0.25); + +##################################################################### +# Create two windows and make sure focus switching works +##################################################################### + +my $top = i3test::open_standard_window; +sleep(0.25); +my $mid = i3test::open_standard_window; +sleep(0.25); +my $bottom = i3test::open_standard_window; +sleep(0.25); + +diag("top id = " . $top->id); +diag("mid id = " . $mid->id); +diag("bottom id = " . $bottom->id); + +# +# Returns the input focus after sending the given command to i3 via IPC +# end sleeping for half a second to make sure i3 reacted +# +sub focus_after { + my $msg = shift; + + $sock->write(i3test::format_ipc_command($msg)); + sleep(0.5); + return X11::XCB::Connection->input_focus; +} + +$focus = X11::XCB::Connection->input_focus; +is($focus, $bottom->id, "Latest window focused"); + +$focus = focus_after("ml"); +is($focus, $bottom->id, "Right window still focused"); + +$focus = focus_after("h"); +is($focus, $mid->id, "Middle window focused"); + +##################################################################### +# Now goto a mark which does not exist +##################################################################### + +my $random_mark = sha1_base64(rand()); + +$focus = focus_after("goto $random_mark"); +is($focus, $mid->id, "focus unchanged"); + +$sock->write(i3test::format_ipc_command("mark $random_mark")); + +$focus = focus_after("k"); +is($focus, $top->id, "Top window focused"); + +$focus = focus_after("goto $random_mark"); +is($focus, $mid->id, "goto worked"); +