From 3aa1801392da0596a821b8d5447a6f1b2b210449 Mon Sep 17 00:00:00 2001 From: Michael Stapelberg Date: Tue, 1 Jun 2010 20:52:59 +0200 Subject: [PATCH] add testcase for crash on closing floating windows whose parent was killed --- testcases/t/27-regress-floating-parent.t | 40 ++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 testcases/t/27-regress-floating-parent.t diff --git a/testcases/t/27-regress-floating-parent.t b/testcases/t/27-regress-floating-parent.t new file mode 100644 index 00000000..827f9207 --- /dev/null +++ b/testcases/t/27-regress-floating-parent.t @@ -0,0 +1,40 @@ +#!perl +# vim:ts=4:sw=4:expandtab +# +# Regression: make a container floating, kill its parent, make it tiling again +# +use i3test tests => 3; +use X11::XCB qw(:all); +use v5.10; + +my $i3 = i3("/tmp/nestedcons"); + +my $tmp = get_unused_workspace(); +$i3->command("workspace $tmp")->recv; + +$i3->command('open')->recv; +$i3->command('open')->recv; +my $old = get_focused($tmp); +$i3->command('split v')->recv; +$i3->command('open')->recv; +my $floating = get_focused($tmp); +diag("focused floating: " . get_focused($tmp)); +$i3->command('mode toggle')->recv; +# TODO: eliminate this race conditition +sleep 1; +$i3->command(qq|[con_id="$old"] focus|)->recv; +is(get_focused($tmp), $old, 'old container focused'); + +$i3->command('kill')->recv; +$i3->command('kill')->recv; +$i3->command(qq|[con_id="$floating"] focus|)->recv; +is(get_focused($tmp), $floating, 'floating window focused'); + +sleep 1; +$i3->command('mode toggle')->recv; + +my $tree = $i3->get_workspaces->recv; +my @nodes = @{$tree->{nodes}}; +ok(@nodes > 0, 'i3 still lives'); + +diag( "Testing i3, Perl $], $^X" );