]> git.sur5r.net Git - i3/i3/blob - testcases/t/173-get-marks.t
Merge branch 'master' into next
[i3/i3] / testcases / t / 173-get-marks.t
1 #!perl
2 # vim:ts=4:sw=4:expandtab
3 #
4 # Please read the following documents before working on tests:
5 # • http://build.i3wm.org/docs/testsuite.html
6 #   (or docs/testsuite)
7 #
8 # • http://build.i3wm.org/docs/lib-i3test.html
9 #   (alternatively: perldoc ./testcases/lib/i3test.pm)
10 #
11 # • http://build.i3wm.org/docs/ipc.html
12 #   (or docs/ipc)
13 #
14 # • http://onyxneon.com/books/modern_perl/modern_perl_a4.pdf
15 #   (unless you are already familiar with Perl)
16 #
17 # checks if the IPC message type get_marks works correctly
18 #
19 use i3test;
20
21 sub get_marks {
22     return i3(get_socket_path())->get_marks->recv;
23 }
24
25 ##############################################################
26 # 1: check that get_marks returns no marks yet
27 ##############################################################
28
29 my $tmp = fresh_workspace;
30
31 my $marks = get_marks();
32 is_deeply($marks, [], 'no marks set so far');
33
34 ##############################################################
35 # 2: check that setting a mark is reflected in the get_marks reply
36 ##############################################################
37
38 cmd 'open';
39 cmd 'mark foo';
40
41 is_deeply(get_marks(), [ 'foo' ], 'mark foo set');
42
43 ##############################################################
44 # 3: check that the mark is gone after killing the container
45 ##############################################################
46
47 cmd 'kill';
48
49 is_deeply(get_marks(), [ ], 'mark gone');
50
51 done_testing;