Update testcases (and skip some tests for the moment)
This commit is contained in:
parent
6897e15e72
commit
285692c92c
|
@ -1,5 +1,5 @@
|
||||||
test:
|
test:
|
||||||
PERL_DL_NONLAZY=1 /usr/bin/perl "-MExtUtils::Command::MM" "-e" "test_harness(1)" -It/lib t/22*
|
PERL_DL_NONLAZY=1 /usr/bin/perl "-MExtUtils::Command::MM" "-e" "test_harness(1)" -It/lib t/*.t
|
||||||
|
|
||||||
all: test
|
all: test
|
||||||
|
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#!perl
|
#!perl
|
||||||
# vim:ts=4:sw=4:expandtab
|
# vim:ts=4:sw=4:expandtab
|
||||||
|
|
||||||
use i3test tests => 3;
|
use i3test tests => 2;
|
||||||
use X11::XCB qw(:all);
|
use X11::XCB qw(:all);
|
||||||
use Time::HiRes qw(sleep);
|
use Time::HiRes qw(sleep);
|
||||||
|
|
||||||
|
@ -11,15 +11,14 @@ BEGIN {
|
||||||
|
|
||||||
my $x = X11::XCB::Connection->new;
|
my $x = X11::XCB::Connection->new;
|
||||||
|
|
||||||
my $i3 = i3;
|
my $i3 = i3("/tmp/nestedcons");
|
||||||
|
my $tmp = get_unused_workspace();
|
||||||
|
$i3->command("workspace $tmp")->recv;
|
||||||
|
|
||||||
#####################################################################
|
#####################################################################
|
||||||
# Ensure IPC works by switching workspaces
|
# Ensure IPC works by switching workspaces
|
||||||
#####################################################################
|
#####################################################################
|
||||||
|
|
||||||
# Switch to the first workspace to get a clean testing environment
|
|
||||||
$i3->command('1')->recv;
|
|
||||||
|
|
||||||
# Create a window so we can get a focus different from NULL
|
# Create a window so we can get a focus different from NULL
|
||||||
my $window = i3test::open_standard_window($x);
|
my $window = i3test::open_standard_window($x);
|
||||||
diag("window->id = " . $window->id);
|
diag("window->id = " . $window->id);
|
||||||
|
@ -30,7 +29,8 @@ my $focus = $x->input_focus;
|
||||||
diag("old focus = $focus");
|
diag("old focus = $focus");
|
||||||
|
|
||||||
# Switch to the nineth workspace
|
# Switch to the nineth workspace
|
||||||
$i3->command('9')->recv;
|
my $otmp = get_unused_workspace();
|
||||||
|
$i3->command("workspace $otmp")->recv;
|
||||||
|
|
||||||
my $new_focus = $x->input_focus;
|
my $new_focus = $x->input_focus;
|
||||||
isnt($focus, $new_focus, "Focus changed");
|
isnt($focus, $new_focus, "Focus changed");
|
||||||
|
|
|
@ -1,10 +1,7 @@
|
||||||
#!perl
|
#!perl
|
||||||
# vim:ts=4:sw=4:expandtab
|
# 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 i3test tests => 13;
|
use i3test tests => 6;
|
||||||
use X11::XCB qw(:all);
|
use X11::XCB qw(:all);
|
||||||
use Time::HiRes qw(sleep);
|
use Time::HiRes qw(sleep);
|
||||||
|
|
||||||
|
@ -14,17 +11,17 @@ BEGIN {
|
||||||
|
|
||||||
my $x = X11::XCB::Connection->new;
|
my $x = X11::XCB::Connection->new;
|
||||||
|
|
||||||
my $i3 = i3;
|
my $i3 = i3("/tmp/nestedcons");
|
||||||
|
my $tmp = get_unused_workspace();
|
||||||
# Switch to the nineth workspace
|
$i3->command("workspace $tmp")->recv;
|
||||||
$i3->command('9')->recv;
|
|
||||||
|
|
||||||
#####################################################################
|
#####################################################################
|
||||||
# Create two windows and make sure focus switching works
|
# Create two windows and make sure focus switching works
|
||||||
#####################################################################
|
#####################################################################
|
||||||
|
|
||||||
# Change mode of the container to "default" for following tests
|
# Change mode of the container to "default" for following tests
|
||||||
$i3->command('d')->recv;
|
$i3->command('layout default')->recv;
|
||||||
|
$i3->command('split v')->recv;
|
||||||
|
|
||||||
my $top = i3test::open_standard_window($x);
|
my $top = i3test::open_standard_window($x);
|
||||||
my $mid = i3test::open_standard_window($x);
|
my $mid = i3test::open_standard_window($x);
|
||||||
|
@ -49,64 +46,64 @@ sub focus_after {
|
||||||
$focus = $x->input_focus;
|
$focus = $x->input_focus;
|
||||||
is($focus, $bottom->id, "Latest window focused");
|
is($focus, $bottom->id, "Latest window focused");
|
||||||
|
|
||||||
$focus = focus_after("k");
|
$focus = focus_after("prev v");
|
||||||
is($focus, $mid->id, "Middle window focused");
|
is($focus, $mid->id, "Middle window focused");
|
||||||
|
|
||||||
$focus = focus_after("k");
|
$focus = focus_after("prev v");
|
||||||
is($focus, $top->id, "Top window focused");
|
is($focus, $top->id, "Top window focused");
|
||||||
|
|
||||||
#####################################################################
|
#####################################################################
|
||||||
# Test focus wrapping
|
# Test focus wrapping
|
||||||
#####################################################################
|
#####################################################################
|
||||||
|
|
||||||
$focus = focus_after("k");
|
$focus = focus_after("prev v");
|
||||||
is($focus, $bottom->id, "Bottom window focused (wrapping to the top works)");
|
is($focus, $bottom->id, "Bottom window focused (wrapping to the top works)");
|
||||||
|
|
||||||
$focus = focus_after("j");
|
$focus = focus_after("next v");
|
||||||
is($focus, $top->id, "Top window focused (wrapping to the bottom works)");
|
is($focus, $top->id, "Top window focused (wrapping to the bottom works)");
|
||||||
|
|
||||||
###############################################
|
###############################################
|
||||||
# Test focus with empty containers and colspan
|
# Test focus with empty containers and colspan
|
||||||
###############################################
|
###############################################
|
||||||
|
|
||||||
# Switch to the 10. workspace
|
#my $otmp = get_unused_workspace();
|
||||||
$i3->command('10')->recv;
|
#$i3->command("workspace $otmp")->recv;
|
||||||
|
#
|
||||||
$top = i3test::open_standard_window($x);
|
#$top = i3test::open_standard_window($x);
|
||||||
$bottom = i3test::open_standard_window($x);
|
#$bottom = i3test::open_standard_window($x);
|
||||||
sleep 0.25;
|
#sleep 0.25;
|
||||||
|
#
|
||||||
$focus = focus_after("mj");
|
#$focus = focus_after("mj");
|
||||||
$focus = focus_after("mh");
|
#$focus = focus_after("mh");
|
||||||
$focus = focus_after("k");
|
#$focus = focus_after("k");
|
||||||
is($focus, $bottom->id, "Selecting top window without snapping doesn't work");
|
#is($focus, $bottom->id, "Selecting top window without snapping doesn't work");
|
||||||
|
#
|
||||||
$focus = focus_after("sl");
|
#$focus = focus_after("sl");
|
||||||
is($focus, $bottom->id, "Bottom window focused");
|
#is($focus, $bottom->id, "Bottom window focused");
|
||||||
|
#
|
||||||
$focus = focus_after("k");
|
#$focus = focus_after("k");
|
||||||
is($focus, $top->id, "Top window focused");
|
#is($focus, $top->id, "Top window focused");
|
||||||
|
#
|
||||||
# Same thing, but left/right instead of top/bottom
|
## Same thing, but left/right instead of top/bottom
|
||||||
|
#
|
||||||
# Switch to the 11. workspace
|
#my $o2tmp = get_unused_workspace();
|
||||||
$i3->command('11')->recv;
|
#$i3->command("workspace $o2tmp")->recv;
|
||||||
|
#
|
||||||
my $left = i3test::open_standard_window($x);
|
#my $left = i3test::open_standard_window($x);
|
||||||
my $right = i3test::open_standard_window($x);
|
#my $right = i3test::open_standard_window($x);
|
||||||
sleep 0.25;
|
#sleep 0.25;
|
||||||
|
#
|
||||||
$focus = focus_after("ml");
|
#$focus = focus_after("ml");
|
||||||
$focus = focus_after("h");
|
#$focus = focus_after("h");
|
||||||
$focus = focus_after("mk");
|
#$focus = focus_after("mk");
|
||||||
$focus = focus_after("l");
|
#$focus = focus_after("l");
|
||||||
is($focus, $left->id, "Selecting right window without snapping doesn't work");
|
#is($focus, $left->id, "Selecting right window without snapping doesn't work");
|
||||||
|
#
|
||||||
$focus = focus_after("sj");
|
#$focus = focus_after("sj");
|
||||||
is($focus, $left->id, "left window focused");
|
#is($focus, $left->id, "left window focused");
|
||||||
|
#
|
||||||
$focus = focus_after("l");
|
#$focus = focus_after("l");
|
||||||
is($focus, $right->id, "right window focused");
|
#is($focus, $right->id, "right window focused");
|
||||||
|
|
||||||
|
|
||||||
diag( "Testing i3, Perl $], $^X" );
|
diag( "Testing i3, Perl $], $^X" );
|
||||||
|
|
|
@ -12,6 +12,9 @@ BEGIN {
|
||||||
use_ok('X11::XCB::Connection') or BAIL_OUT('Cannot load X11::XCB::Connection');
|
use_ok('X11::XCB::Connection') or BAIL_OUT('Cannot load X11::XCB::Connection');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SKIP: {
|
||||||
|
skip "Testcase not yet modified for new move concept", 7;
|
||||||
|
|
||||||
my $x = X11::XCB::Connection->new;
|
my $x = X11::XCB::Connection->new;
|
||||||
|
|
||||||
my $i3 = i3;
|
my $i3 = i3;
|
||||||
|
@ -76,3 +79,4 @@ for my $cmd (qw(m12 t m13 12 13)) {
|
||||||
$i3->command($cmd)->recv;
|
$i3->command($cmd)->recv;
|
||||||
}
|
}
|
||||||
ok(1, "Still living");
|
ok(1, "Still living");
|
||||||
|
}
|
||||||
|
|
|
@ -13,17 +13,16 @@ BEGIN {
|
||||||
|
|
||||||
my $x = X11::XCB::Connection->new;
|
my $x = X11::XCB::Connection->new;
|
||||||
|
|
||||||
my $i3 = i3;
|
my $i3 = i3("/tmp/nestedcons");
|
||||||
|
my $tmp = get_unused_workspace();
|
||||||
|
$i3->command("workspace $tmp")->recv;
|
||||||
|
|
||||||
# Switch to the nineth workspace
|
|
||||||
$i3->command('9')->recv;
|
|
||||||
|
|
||||||
|
$i3->command('split h')->recv;
|
||||||
my $tiled_left = i3test::open_standard_window($x);
|
my $tiled_left = i3test::open_standard_window($x);
|
||||||
my $tiled_right = i3test::open_standard_window($x);
|
my $tiled_right = i3test::open_standard_window($x);
|
||||||
|
|
||||||
sleep(0.25);
|
sleep 0.25;
|
||||||
|
|
||||||
$i3->command('ml')->recv;
|
|
||||||
|
|
||||||
# Get input focus before creating the floating window
|
# Get input focus before creating the floating window
|
||||||
my $focus = $x->input_focus;
|
my $focus = $x->input_focus;
|
||||||
|
@ -40,12 +39,13 @@ isa_ok($window, 'X11::XCB::Window');
|
||||||
|
|
||||||
$window->map;
|
$window->map;
|
||||||
|
|
||||||
sleep(0.25);
|
sleep 1;
|
||||||
|
sleep 0.25;
|
||||||
is($x->input_focus, $window->id, 'floating window focused');
|
is($x->input_focus, $window->id, 'floating window focused');
|
||||||
|
|
||||||
$window->unmap;
|
$window->unmap;
|
||||||
|
|
||||||
sleep(0.25);
|
sleep 0.25;
|
||||||
|
|
||||||
is($x->input_focus, $focus, 'Focus correctly restored');
|
is($x->input_focus, $focus, 'Focus correctly restored');
|
||||||
|
|
||||||
|
|
|
@ -12,6 +12,9 @@ BEGIN {
|
||||||
use_ok('X11::XCB::Connection') or BAIL_OUT('Cannot load X11::XCB::Connection');
|
use_ok('X11::XCB::Connection') or BAIL_OUT('Cannot load X11::XCB::Connection');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SKIP: {
|
||||||
|
skip "stacking test not yet updated", 21;
|
||||||
|
|
||||||
my $x = X11::XCB::Connection->new;
|
my $x = X11::XCB::Connection->new;
|
||||||
|
|
||||||
my $i3 = i3;
|
my $i3 = i3;
|
||||||
|
@ -126,3 +129,4 @@ is($focus, $bottom->id, "Window above is bottom");
|
||||||
$focus = focus_after("k");
|
$focus = focus_after("k");
|
||||||
is($focus, $mid->id, "Window above is mid");
|
is($focus, $mid->id, "Window above is mid");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -12,12 +12,14 @@ BEGIN {
|
||||||
use_ok('X11::XCB::Connection') or BAIL_OUT('Cannot load X11::XCB::Connection');
|
use_ok('X11::XCB::Connection') or BAIL_OUT('Cannot load X11::XCB::Connection');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
SKIP: {
|
||||||
|
skip "border styles not yet implemented", 14;
|
||||||
|
|
||||||
my $x = X11::XCB::Connection->new;
|
my $x = X11::XCB::Connection->new;
|
||||||
|
|
||||||
my $i3 = i3;
|
my $i3 = i3("/tmp/nestedcons");
|
||||||
|
my $tmp = get_unused_workspace();
|
||||||
# Switch to the nineth workspace
|
$i3->command("workspace $tmp")->recv;
|
||||||
$i3->command('9')->recv;
|
|
||||||
|
|
||||||
#####################################################################
|
#####################################################################
|
||||||
# Create a floating window and see if resizing works
|
# Create a floating window and see if resizing works
|
||||||
|
@ -76,3 +78,5 @@ test_resize;
|
||||||
$i3->command('bp')->recv;
|
$i3->command('bp')->recv;
|
||||||
|
|
||||||
test_resize;
|
test_resize;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
|
@ -1,8 +1,5 @@
|
||||||
#!perl
|
#!perl
|
||||||
# vim:ts=4:sw=4:expandtab
|
# vim:ts=4:sw=4:expandtab
|
||||||
# Beware that this test uses workspace 9 and 10 to perform some tests (it expects
|
|
||||||
# the workspace to be empty).
|
|
||||||
# TODO: skip it by default?
|
|
||||||
|
|
||||||
use i3test tests => 3;
|
use i3test tests => 3;
|
||||||
use X11::XCB qw(:all);
|
use X11::XCB qw(:all);
|
||||||
|
@ -13,10 +10,10 @@ BEGIN {
|
||||||
}
|
}
|
||||||
|
|
||||||
my $x = X11::XCB::Connection->new;
|
my $x = X11::XCB::Connection->new;
|
||||||
my $i3 = i3;
|
my $i3 = i3("/tmp/nestedcons");
|
||||||
|
|
||||||
# Switch to the nineth workspace
|
my $tmp = get_unused_workspace();
|
||||||
$i3->command('9')->recv;
|
$i3->command("workspace $tmp")->recv;
|
||||||
|
|
||||||
#####################################################################
|
#####################################################################
|
||||||
# Create a parent window
|
# Create a parent window
|
||||||
|
@ -37,7 +34,8 @@ sleep 0.25;
|
||||||
# Switch workspace to 10 and open a child window. It should be positioned
|
# Switch workspace to 10 and open a child window. It should be positioned
|
||||||
# on workspace 9.
|
# on workspace 9.
|
||||||
#########################################################################
|
#########################################################################
|
||||||
$i3->command('10')->recv;
|
my $otmp = get_unused_workspace();
|
||||||
|
$i3->command("workspace $otmp")->recv;
|
||||||
|
|
||||||
my $child = $x->root->create_child(
|
my $child = $x->root->create_child(
|
||||||
class => WINDOW_CLASS_INPUT_OUTPUT,
|
class => WINDOW_CLASS_INPUT_OUTPUT,
|
||||||
|
@ -54,6 +52,6 @@ sleep 0.25;
|
||||||
isnt($x->input_focus, $child->id, "Child window focused");
|
isnt($x->input_focus, $child->id, "Child window focused");
|
||||||
|
|
||||||
# Switch back
|
# Switch back
|
||||||
$i3->command('9')->recv;
|
$i3->command("workspace $tmp")->recv;
|
||||||
|
|
||||||
is($x->input_focus, $child->id, "Child window focused");
|
is($x->input_focus, $child->id, "Child window focused");
|
||||||
|
|
|
@ -4,12 +4,15 @@
|
||||||
use i3test tests => 2;
|
use i3test tests => 2;
|
||||||
use List::MoreUtils qw(all);
|
use List::MoreUtils qw(all);
|
||||||
|
|
||||||
my $i3 = i3;
|
my $i3 = i3("/tmp/nestedcons");
|
||||||
|
|
||||||
####################
|
####################
|
||||||
# Request workspaces
|
# Request workspaces
|
||||||
####################
|
####################
|
||||||
|
|
||||||
|
SKIP: {
|
||||||
|
skip "IPC API not yet stabilized", 2;
|
||||||
|
|
||||||
my $workspaces = $i3->get_workspaces->recv;
|
my $workspaces = $i3->get_workspaces->recv;
|
||||||
|
|
||||||
ok(@{$workspaces} > 0, "More than zero workspaces found");
|
ok(@{$workspaces} > 0, "More than zero workspaces found");
|
||||||
|
@ -17,4 +20,6 @@ ok(@{$workspaces} > 0, "More than zero workspaces found");
|
||||||
my $name_exists = all { defined($_->{name}) } @{$workspaces};
|
my $name_exists = all { defined($_->{name}) } @{$workspaces};
|
||||||
ok($name_exists, "All workspaces have a name");
|
ok($name_exists, "All workspaces have a name");
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
diag( "Testing i3, Perl $], $^X" );
|
diag( "Testing i3, Perl $], $^X" );
|
||||||
|
|
|
@ -1,7 +1,7 @@
|
||||||
#!perl
|
#!perl
|
||||||
# vim:ts=4:sw=4:expandtab
|
# vim:ts=4:sw=4:expandtab
|
||||||
|
|
||||||
use i3test tests => 8;
|
use i3test tests => 7;
|
||||||
use List::MoreUtils qw(all none);
|
use List::MoreUtils qw(all none);
|
||||||
|
|
||||||
my $i3 = i3("/tmp/nestedcons");
|
my $i3 = i3("/tmp/nestedcons");
|
||||||
|
@ -11,32 +11,6 @@ my $i3 = i3("/tmp/nestedcons");
|
||||||
####################
|
####################
|
||||||
|
|
||||||
my $tree = $i3->get_workspaces->recv;
|
my $tree = $i3->get_workspaces->recv;
|
||||||
# $VAR1 = {
|
|
||||||
# 'fullscreen_mode' => 0,
|
|
||||||
# 'nodes' => [
|
|
||||||
# {
|
|
||||||
# 'fullscreen_mode' => 0,
|
|
||||||
# 'nodes' => [
|
|
||||||
# {
|
|
||||||
# 'fullscreen_mode' => 0,
|
|
||||||
# 'nodes' => [],
|
|
||||||
# 'window' => undef,
|
|
||||||
# 'name' => '1',
|
|
||||||
# 'orientation' => 0,
|
|
||||||
# 'type' => 2
|
|
||||||
# }
|
|
||||||
# ],
|
|
||||||
# 'window' => undef,
|
|
||||||
# 'name' => 'LVDS1',
|
|
||||||
# 'orientation' => 0,
|
|
||||||
# 'type' => 1
|
|
||||||
# }
|
|
||||||
# ],
|
|
||||||
# 'window' => undef,
|
|
||||||
# 'name' => 'root',
|
|
||||||
# 'orientation' => 0,
|
|
||||||
# 'type' => 0
|
|
||||||
# };
|
|
||||||
|
|
||||||
my $expected = {
|
my $expected = {
|
||||||
fullscreen_mode => 0,
|
fullscreen_mode => 0,
|
||||||
|
@ -49,6 +23,8 @@ my $expected = {
|
||||||
rect => ignore(),
|
rect => ignore(),
|
||||||
layout => 0,
|
layout => 0,
|
||||||
focus => ignore(),
|
focus => ignore(),
|
||||||
|
urgent => 0,
|
||||||
|
'floating-nodes' => ignore(),
|
||||||
};
|
};
|
||||||
|
|
||||||
cmp_deeply($tree, $expected, 'root node OK');
|
cmp_deeply($tree, $expected, 'root node OK');
|
||||||
|
@ -65,8 +41,8 @@ for my $ws (map { @{$_->{nodes}} } @nodes) {
|
||||||
push @workspaces, $ws;
|
push @workspaces, $ws;
|
||||||
}
|
}
|
||||||
|
|
||||||
ok((all { $_->{type} == 2 } @workspaces), 'all workspaces are of type CT_CON');
|
ok((all { $_->{type} == 4 } @workspaces), 'all workspaces are of type CT_WORKSPACE');
|
||||||
ok((all { @{$_->{nodes}} == 0 } @workspaces), 'all workspaces are empty yet');
|
#ok((all { @{$_->{nodes}} == 0 } @workspaces), 'all workspaces are empty yet');
|
||||||
ok((none { defined($_->{window}) } @workspaces), 'no CT_OUTPUT contains a window');
|
ok((none { defined($_->{window}) } @workspaces), 'no CT_OUTPUT contains a window');
|
||||||
|
|
||||||
# TODO: get the focused container
|
# TODO: get the focused container
|
||||||
|
@ -76,9 +52,9 @@ $i3->command('open')->recv;
|
||||||
# TODO: get the focused container, check if it changed.
|
# TODO: get the focused container, check if it changed.
|
||||||
# TODO: get the old focused container, check if there is a new child
|
# TODO: get the old focused container, check if there is a new child
|
||||||
|
|
||||||
diag(Dumper(\@workspaces));
|
#diag(Dumper(\@workspaces));
|
||||||
|
|
||||||
diag(Dumper($tree));
|
#diag(Dumper($tree));
|
||||||
|
|
||||||
|
|
||||||
diag( "Testing i3, Perl $], $^X" );
|
diag( "Testing i3, Perl $], $^X" );
|
||||||
|
|
Loading…
Reference in New Issue