X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=testcases%2Ft%2F119-match.t;h=0aaeddd732ddfc676380cc451f0c2f28fd666fe3;hb=1dbdd4fece86c5f85bde54e40f58fa1a91810933;hp=e6a4e832fdb3daa2a7da0d7abe565d68c9cba049;hpb=db174234ce41c3ac317ef25d5fff323540295e9a;p=i3%2Fi3 diff --git a/testcases/t/119-match.t b/testcases/t/119-match.t index e6a4e832..0aaeddd7 100644 --- a/testcases/t/119-match.t +++ b/testcases/t/119-match.t @@ -1,10 +1,22 @@ #!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) +# # Tests all kinds of matching methods # use i3test; -use X11::XCB qw(PROP_MODE_REPLACE); my $tmp = fresh_workspace; @@ -26,8 +38,7 @@ my $win = $content->[0]; cmd q|[class=".*"] kill|; cmd q|[con_id="99999"] kill|; -$content = get_ws_content($tmp); -ok(@{$content} == 1, 'window still there'); +is_num_children($tmp, 1, 'window still there'); # now kill the window cmd 'nop now killing the window'; @@ -37,8 +48,7 @@ cmd qq|[con_id="$id"] kill|; wait_for_unmap $window; cmd 'nop checking if its gone'; -$content = get_ws_content($tmp); -ok(@{$content} == 0, 'window killed'); +is_num_children($tmp, 0, 'window killed'); # TODO: same test, but with pcre expressions @@ -50,51 +60,20 @@ ok(@{$content} == 0, 'window killed'); $tmp = fresh_workspace; -# TODO: move to X11::XCB -sub set_wm_class { - my ($id, $class, $instance) = @_; - - # Add a _NET_WM_STRUT_PARTIAL hint - my $atomname = $x->atom(name => 'WM_CLASS'); - my $atomtype = $x->atom(name => 'STRING'); - - $x->change_property( - PROP_MODE_REPLACE, - $id, - $atomname->id, - $atomtype->id, - 8, - length($class) + length($instance) + 2, - "$instance\x00$class\x00" - ); -} - -sub open_special { - my %args = @_; - my $wm_class = delete($args{wm_class}) || 'special'; - - return open_window( - %args, - before_map => sub { set_wm_class($_->id, $wm_class, $wm_class) }, - ); -} - -my $left = open_special(name => 'left'); +my $left = open_window(wm_class => 'special', name => 'left'); ok($left->mapped, 'left window mapped'); -my $right = open_special(name => 'right'); +my $right = open_window(wm_class => 'special', name => 'right'); ok($right->mapped, 'right window mapped'); # two windows should be here -$content = get_ws_content($tmp); -ok(@{$content} == 2, 'two windows opened'); +is_num_children($tmp, 2, 'two windows opened'); cmd '[class="special" title="left"] kill'; sync_with_i3; -$content = get_ws_content($tmp); -is(@{$content}, 1, 'one window still there'); +is_num_children($tmp, 1, 'one window still there'); ###################################################################### # check that regular expressions work @@ -102,19 +81,13 @@ is(@{$content}, 1, 'one window still there'); $tmp = fresh_workspace; -$left = open_special(name => 'left', wm_class => 'special7'); +$left = open_window(name => 'left', wm_class => 'special7'); ok($left->mapped, 'left window mapped'); - -# two windows should be here -$content = get_ws_content($tmp); -ok(@{$content} == 1, 'window opened'); +is_num_children($tmp, 1, 'window opened'); cmd '[class="^special[0-9]$"] kill'; - wait_for_unmap $left; - -$content = get_ws_content($tmp); -is(@{$content}, 0, 'window killed'); +is_num_children($tmp, 0, 'window killed'); ###################################################################### # check that UTF-8 works when matching @@ -122,18 +95,12 @@ is(@{$content}, 0, 'window killed'); $tmp = fresh_workspace; -$left = open_special(name => 'ä 3', wm_class => 'special7'); +$left = open_window(name => 'ä 3', wm_class => 'special7'); ok($left->mapped, 'left window mapped'); - -# two windows should be here -$content = get_ws_content($tmp); -ok(@{$content} == 1, 'window opened'); +is_num_children($tmp, 1, 'window opened'); cmd '[title="^\w [3]$"] kill'; - wait_for_unmap $left; - -$content = get_ws_content($tmp); -is(@{$content}, 0, 'window killed'); +is_num_children($tmp, 0, 'window killed'); done_testing;