X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=testcases%2Ft%2F166-assign.t;h=68548831bd085519f820ba591611a86bec0eabb3;hb=eaf7a49e28b7ff8e1820a1b23350647574a0ed5a;hp=458e9655890e6ff9565438ae44e6ad41112ebe8d;hpb=c7ea8c42b679be191e843f653f5024846ce42fe9;p=i3%2Fi3 diff --git a/testcases/t/166-assign.t b/testcases/t/166-assign.t index 458e9655..68548831 100644 --- a/testcases/t/166-assign.t +++ b/testcases/t/166-assign.t @@ -1,39 +1,63 @@ #!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 if assignments work # use i3test i3_autostart => 0; -use X11::XCB qw(PROP_MODE_REPLACE); - -# 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'; $args{name} //= 'special window'; - return open_window( + # We use dont_map because i3 will not map the window on the current + # workspace. Thus, open_window would time out in wait_for_map (2 seconds). + my $window = open_window( %args, - before_map => sub { set_wm_class($_->id, $wm_class, $wm_class) }, + wm_class => 'special', + dont_map => 1, ); + $window->map; + return $window; +} + +sub test_workspace_assignment { + my $target_ws = "@_"; + + # initialize the target workspace, then go to a fresh one + ok(!($target_ws ~~ @{get_workspace_names()}), "$target_ws does not exist yet"); + cmd "workspace $target_ws"; + cmp_ok(@{get_ws_content($target_ws)}, '==', 0, "no containers on $target_ws yet"); + cmd 'open'; + cmp_ok(@{get_ws_content($target_ws)}, '==', 1, "one container on $target_ws"); + my $tmp = fresh_workspace; + + ok(@{get_ws_content($tmp)} == 0, 'no containers yet'); + ok($target_ws ~~ @{get_workspace_names()}, "$target_ws does not exist yet"); + + # We use sync_with_i3 instead of wait_for_map here because i3 will not actually + # map the window -- it will be assigned to a different workspace and will only + # be mapped once you switch to that workspace + my $window = open_special(dont_map => 1); + $window->map; + sync_with_i3; + + ok(@{get_ws_content($tmp)} == 0, 'still no containers'); + ok(@{get_ws_content($target_ws)} == 2, "two containers on $target_ws"); + + return $window } ##################################################################### @@ -52,6 +76,7 @@ my $tmp = fresh_workspace; ok(@{get_ws_content($tmp)} == 0, 'no containers yet'); my $window = open_special; +wait_for_map($window); ok(@{get_ws_content($tmp)} == 1, 'special window got managed to current (random) workspace'); @@ -67,7 +92,7 @@ $window->destroy; $config = <destroy; exit_gracefully($pid); -sleep 0.25; - ##################################################################### -# start a window and see that it gets assigned to a workspace which has content -# already, next to the existing node. +# start a window and see that it gets assigned to a formerly unused +# numbered workspace ##################################################################### -$pid = launch_with_config($config); +my $config_numbered = < 1); -$window->map; +$window = open_special; sync_with_i3; ok(@{get_ws_content($tmp)} == 0, 'still no containers'); -ok(@{get_ws_content('targetws')} == 2, 'two containers on targetws'); +ok("2" ~~ @{get_workspace_names()}, 'workspace number 2 exists'); + +$window->destroy; exit_gracefully($pid); ##################################################################### -# start a window and see that it gets assigned to a workspace which has content -# already, next to the existing node. +# start a window and see that it gets assigned to a numbered +# workspace which has content already, next to the existing node. ##################################################################### -$config = <destroy; -ok(@{get_ws_content($tmp)} == 0, 'no containers yet'); -$workspaces = get_workspace_names; -ok(!("targetws" ~~ @{$workspaces}), 'targetws does not exist yet'); +exit_gracefully($pid); -$window = open_special; +##################################################################### +# start a window and see that it gets assigned to a numbered workspace with +# a name which has content already, next to the existing node. +##################################################################### -my $content = get_ws($tmp); -ok(@{$content->{nodes}} == 0, 'no tiling cons'); -ok(@{$content->{floating_nodes}} == 1, 'one floating con'); +$pid = launch_with_config($config_numbered); +cmd 'workspace 2'; # Make sure that we are not testing for "2" again. +$window = test_workspace_assignment("2: targetws"); $window->destroy; exit_gracefully($pid); -sleep 0.25; +##################################################################### +# start a window and see that it gets assigned to a workspace which +# has content already, next to the existing node. +##################################################################### + +$pid = launch_with_config($config); + +test_workspace_assignment("targetws"); + +exit_gracefully($pid); ##################################################################### -# make sure that assignments are case-insensitive in the old syntax. +# start a window and see that it gets assigned to a workspace which has content +# already, next to the existing node. ##################################################################### $config = < 'SPEcial'); +$window = open_special; +sync_with_i3; -$content = get_ws($tmp); +my $content = get_ws($tmp); ok(@{$content->{nodes}} == 0, 'no tiling cons'); ok(@{$content->{floating_nodes}} == 1, 'one floating con'); @@ -179,43 +208,52 @@ $window->destroy; exit_gracefully($pid); -sleep 0.25; - ##################################################################### # regression test: dock clients with floating assignments should not crash # (instead, nothing should happen - dock clients can’t float) # ticket #501 ##################################################################### +# Walks /proc to figure out whether a child process of $i3pid with the name +# 'i3-nagbar' exists. +sub i3nagbar_running { + my ($i3pid) = @_; + + my @procfiles = grep { m,^/proc/[0-9]+$, } ; + for my $path (@procfiles) { + open(my $fh, '<', "$path/stat") or next; + my $line = <$fh>; + close($fh); + my ($comm, $ppid) = ($line =~ /^[0-9]+ \(([^)]+)\) . ([0-9]+)/); + return 1 if $ppid == $i3pid && $comm eq 'i3-nagbar'; + } + return 0; +} + $config = < $x->atom(name => '_NET_WM_WINDOW_TYPE_DOCK'), ); +sync_with_i3; $content = get_ws($tmp); ok(@{$content->{nodes}} == 0, 'no tiling cons'); ok(@{$content->{floating_nodes}} == 0, 'one floating con'); @docked = get_dock_clients; -is(@docked, 2, 'two dock clients now'); +is(@docked, 1, 'one dock client now'); $window->destroy;