X-Git-Url: https://git.sur5r.net/?a=blobdiff_plain;f=testcases%2Ft%2F166-assign.t;h=6af13fa566eccb4ae7e658b41f99f07845f22a56;hb=71ccb4bef2850bd5beab8a4ef4669bf53b5a9781;hp=458e9655890e6ff9565438ae44e6ad41112ebe8d;hpb=8349190e09c1b75965824c8d88e0aeae6587a6a4;p=i3%2Fi3 diff --git a/testcases/t/166-assign.t b/testcases/t/166-assign.t index 458e9655..6af13fa5 100644 --- a/testcases/t/166-assign.t +++ b/testcases/t/166-assign.t @@ -1,6 +1,19 @@ #!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; @@ -30,10 +43,15 @@ sub open_special { 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) }, + dont_map => 1, ); + $window->map; + return $window; } ##################################################################### @@ -52,6 +70,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 +86,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. @@ -128,7 +145,7 @@ exit_gracefully($pid); $config = <destroy; exit_gracefully($pid); -sleep 0.25; - -##################################################################### -# make sure that assignments are case-insensitive in the old syntax. -##################################################################### - -$config = < 'SPEcial'); - -$content = get_ws($tmp); -ok(@{$content->{nodes}} == 0, 'no tiling cons'); -ok(@{$content->{floating_nodes}} == 1, 'one floating con'); - -$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'), @@ -215,7 +210,7 @@ $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;