2011-05-24 22:56:28 +02:00
|
|
|
|
#!perl
|
|
|
|
|
# vim:ts=4:sw=4:expandtab
|
|
|
|
|
#
|
2012-09-10 14:09:01 +02:00
|
|
|
|
# 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)
|
|
|
|
|
#
|
2011-05-24 22:56:28 +02:00
|
|
|
|
# Tests if assignments work
|
|
|
|
|
#
|
2011-11-25 17:39:19 +01:00
|
|
|
|
use i3test i3_autostart => 0;
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
2011-11-23 17:22:43 +01:00
|
|
|
|
sub open_special {
|
|
|
|
|
my %args = @_;
|
|
|
|
|
$args{name} //= 'special window';
|
|
|
|
|
|
2012-02-21 13:40:53 +01:00
|
|
|
|
# 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(
|
2011-11-23 17:22:43 +01:00
|
|
|
|
%args,
|
2013-09-24 21:53:48 +02:00
|
|
|
|
wm_class => 'special',
|
2012-02-21 13:40:53 +01:00
|
|
|
|
dont_map => 1,
|
2011-11-23 17:22:43 +01:00
|
|
|
|
);
|
2012-02-21 13:40:53 +01:00
|
|
|
|
$window->map;
|
|
|
|
|
return $window;
|
2011-11-23 17:22:43 +01:00
|
|
|
|
}
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
2017-08-28 04:14:03 +02:00
|
|
|
|
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
|
|
|
|
|
}
|
|
|
|
|
|
2011-05-24 22:56:28 +02:00
|
|
|
|
#####################################################################
|
|
|
|
|
# start a window and see that it does not get assigned with an empty config
|
|
|
|
|
#####################################################################
|
|
|
|
|
|
2011-08-03 02:02:38 +02:00
|
|
|
|
my $config = <<EOT;
|
|
|
|
|
# i3 config file (v4)
|
|
|
|
|
font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
|
|
|
|
|
EOT
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
2011-10-05 00:34:23 +02:00
|
|
|
|
my $pid = launch_with_config($config);
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
|
|
|
|
my $tmp = fresh_workspace;
|
|
|
|
|
|
|
|
|
|
ok(@{get_ws_content($tmp)} == 0, 'no containers yet');
|
|
|
|
|
|
2011-11-23 17:22:43 +01:00
|
|
|
|
my $window = open_special;
|
2012-06-29 23:20:46 +02:00
|
|
|
|
wait_for_map($window);
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
|
|
|
|
ok(@{get_ws_content($tmp)} == 1, 'special window got managed to current (random) workspace');
|
|
|
|
|
|
2011-10-05 00:34:23 +02:00
|
|
|
|
exit_gracefully($pid);
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
|
|
|
|
$window->destroy;
|
|
|
|
|
|
|
|
|
|
#####################################################################
|
|
|
|
|
# start a window and see that it gets assigned to a formerly unused
|
|
|
|
|
# workspace
|
|
|
|
|
#####################################################################
|
|
|
|
|
|
2011-08-03 02:02:38 +02:00
|
|
|
|
$config = <<EOT;
|
|
|
|
|
# i3 config file (v4)
|
|
|
|
|
font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
|
2012-10-08 13:21:48 +02:00
|
|
|
|
assign [class="special"] → targetws
|
2011-08-03 02:02:38 +02:00
|
|
|
|
EOT
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
2011-10-05 00:34:23 +02:00
|
|
|
|
$pid = launch_with_config($config);
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
|
|
|
|
$tmp = fresh_workspace;
|
|
|
|
|
|
|
|
|
|
ok(@{get_ws_content($tmp)} == 0, 'no containers yet');
|
|
|
|
|
my $workspaces = get_workspace_names;
|
|
|
|
|
ok(!("targetws" ~~ @{$workspaces}), 'targetws does not exist yet');
|
|
|
|
|
|
2011-11-23 17:22:43 +01:00
|
|
|
|
$window = open_special;
|
2012-12-26 22:04:35 +01:00
|
|
|
|
sync_with_i3;
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
|
|
|
|
ok(@{get_ws_content($tmp)} == 0, 'still no containers');
|
|
|
|
|
ok("targetws" ~~ @{get_workspace_names()}, 'targetws exists');
|
|
|
|
|
|
|
|
|
|
$window->destroy;
|
|
|
|
|
|
2011-10-05 00:34:23 +02:00
|
|
|
|
exit_gracefully($pid);
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
|
|
|
|
#####################################################################
|
2017-08-28 04:14:03 +02:00
|
|
|
|
# start a window and see that it gets assigned to a formerly unused
|
|
|
|
|
# numbered workspace
|
2011-05-24 22:56:28 +02:00
|
|
|
|
#####################################################################
|
|
|
|
|
|
2017-08-28 04:14:03 +02:00
|
|
|
|
my $config_numbered = <<EOT;
|
|
|
|
|
# i3 config file (v4)
|
|
|
|
|
font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
|
|
|
|
|
assign [class="special"] → workspace number 2
|
|
|
|
|
EOT
|
|
|
|
|
|
|
|
|
|
$pid = launch_with_config($config_numbered);
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
|
|
|
|
$tmp = fresh_workspace;
|
|
|
|
|
|
|
|
|
|
ok(@{get_ws_content($tmp)} == 0, 'no containers yet');
|
2017-08-28 04:14:03 +02:00
|
|
|
|
$workspaces = get_workspace_names;
|
|
|
|
|
ok(!("2" ~~ @{$workspaces}), 'workspace number 2 does not exist yet');
|
2011-09-24 14:08:02 +02:00
|
|
|
|
|
2017-08-28 04:14:03 +02:00
|
|
|
|
$window = open_special;
|
2011-11-22 01:13:37 +01:00
|
|
|
|
sync_with_i3;
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
|
|
|
|
ok(@{get_ws_content($tmp)} == 0, 'still no containers');
|
2017-08-28 04:14:03 +02:00
|
|
|
|
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 numbered
|
|
|
|
|
# workspace which has content already, next to the existing node.
|
|
|
|
|
#####################################################################
|
|
|
|
|
|
|
|
|
|
$pid = launch_with_config($config_numbered);
|
|
|
|
|
|
|
|
|
|
$window = test_workspace_assignment("2");
|
|
|
|
|
$window->destroy;
|
|
|
|
|
|
|
|
|
|
exit_gracefully($pid);
|
|
|
|
|
|
|
|
|
|
#####################################################################
|
|
|
|
|
# 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.
|
|
|
|
|
#####################################################################
|
|
|
|
|
|
|
|
|
|
$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);
|
|
|
|
|
|
|
|
|
|
#####################################################################
|
|
|
|
|
# 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");
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
2011-10-05 00:34:23 +02:00
|
|
|
|
exit_gracefully($pid);
|
2011-05-24 22:56:28 +02:00
|
|
|
|
|
2011-06-13 17:42:59 +02:00
|
|
|
|
#####################################################################
|
|
|
|
|
# start a window and see that it gets assigned to a workspace which has content
|
|
|
|
|
# already, next to the existing node.
|
|
|
|
|
#####################################################################
|
|
|
|
|
|
2011-08-03 02:02:38 +02:00
|
|
|
|
$config = <<EOT;
|
|
|
|
|
# i3 config file (v4)
|
|
|
|
|
font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
|
2012-10-08 13:21:48 +02:00
|
|
|
|
for_window [class="special"] floating enable
|
2011-08-03 02:02:38 +02:00
|
|
|
|
EOT
|
2011-07-25 13:35:56 +02:00
|
|
|
|
|
2011-10-05 00:34:23 +02:00
|
|
|
|
$pid = launch_with_config($config);
|
2011-06-13 17:42:59 +02:00
|
|
|
|
|
|
|
|
|
$tmp = fresh_workspace;
|
|
|
|
|
|
|
|
|
|
ok(@{get_ws_content($tmp)} == 0, 'no containers yet');
|
2011-11-21 21:04:00 +01:00
|
|
|
|
$workspaces = get_workspace_names;
|
2011-06-13 17:42:59 +02:00
|
|
|
|
ok(!("targetws" ~~ @{$workspaces}), 'targetws does not exist yet');
|
|
|
|
|
|
2011-11-23 17:22:43 +01:00
|
|
|
|
$window = open_special;
|
2012-12-26 22:04:35 +01:00
|
|
|
|
sync_with_i3;
|
2011-06-13 17:42:59 +02:00
|
|
|
|
|
|
|
|
|
my $content = get_ws($tmp);
|
|
|
|
|
ok(@{$content->{nodes}} == 0, 'no tiling cons');
|
|
|
|
|
ok(@{$content->{floating_nodes}} == 1, 'one floating con');
|
|
|
|
|
|
|
|
|
|
$window->destroy;
|
|
|
|
|
|
2011-10-05 00:34:23 +02:00
|
|
|
|
exit_gracefully($pid);
|
2011-06-13 17:42:59 +02:00
|
|
|
|
|
2011-08-28 15:43:51 +02:00
|
|
|
|
#####################################################################
|
|
|
|
|
# regression test: dock clients with floating assignments should not crash
|
|
|
|
|
# (instead, nothing should happen - dock clients can’t float)
|
|
|
|
|
# ticket #501
|
|
|
|
|
#####################################################################
|
|
|
|
|
|
2012-02-21 13:58:49 +01:00
|
|
|
|
# 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]+$, } </proc/*>;
|
|
|
|
|
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;
|
|
|
|
|
}
|
|
|
|
|
|
2011-08-28 15:43:51 +02:00
|
|
|
|
$config = <<EOT;
|
|
|
|
|
# i3 config file (v4)
|
|
|
|
|
font -misc-fixed-medium-r-normal--13-120-75-75-C-70-iso10646-1
|
2012-06-29 21:28:10 +02:00
|
|
|
|
for_window [title="special"] floating enable
|
2011-08-28 15:43:51 +02:00
|
|
|
|
EOT
|
|
|
|
|
|
2011-10-05 00:34:23 +02:00
|
|
|
|
$pid = launch_with_config($config);
|
|
|
|
|
|
2011-08-28 15:43:51 +02:00
|
|
|
|
$tmp = fresh_workspace;
|
|
|
|
|
|
|
|
|
|
ok(@{get_ws_content($tmp)} == 0, 'no containers yet');
|
|
|
|
|
my @docked = get_dock_clients;
|
2012-06-29 21:28:10 +02:00
|
|
|
|
is(@docked, 0, 'one dock client yet');
|
2011-08-28 15:43:51 +02:00
|
|
|
|
|
2011-11-23 17:22:43 +01:00
|
|
|
|
$window = open_special(
|
2011-08-28 15:43:51 +02:00
|
|
|
|
window_type => $x->atom(name => '_NET_WM_WINDOW_TYPE_DOCK'),
|
|
|
|
|
);
|
2012-12-26 22:04:35 +01:00
|
|
|
|
sync_with_i3;
|
2011-08-28 15:43:51 +02:00
|
|
|
|
|
2011-11-21 21:04:00 +01:00
|
|
|
|
$content = get_ws($tmp);
|
2011-08-28 15:43:51 +02:00
|
|
|
|
ok(@{$content->{nodes}} == 0, 'no tiling cons');
|
|
|
|
|
ok(@{$content->{floating_nodes}} == 0, 'one floating con');
|
|
|
|
|
@docked = get_dock_clients;
|
2012-06-29 21:28:10 +02:00
|
|
|
|
is(@docked, 1, 'one dock client now');
|
2011-08-28 15:43:51 +02:00
|
|
|
|
|
|
|
|
|
$window->destroy;
|
|
|
|
|
|
|
|
|
|
does_i3_live;
|
|
|
|
|
|
2011-10-05 00:34:23 +02:00
|
|
|
|
exit_gracefully($pid);
|
2011-08-28 15:43:51 +02:00
|
|
|
|
|
2011-05-24 22:56:28 +02:00
|
|
|
|
done_testing;
|