annotate src/testdir/test63.in @ 0:76efa0be13f1

Initial revision
author atsuki
date Sat, 10 Nov 2007 15:07:22 +0900
parents
children
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
rev   line source
0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
1 Test for ":match", ":2match", ":3match", "clearmatches()", "getmatches()",
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
2 "matchadd()", "matcharg()", "matchdelete()", and "setmatches()".
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
3
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
4 STARTTEST
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
5 :so small.vim
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
6 :" --- Check that "matcharg()" returns the correct group and pattern if a match
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
7 :" --- is defined.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
8 :let @r = "*** Test 1: "
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
9 :highlight MyGroup1 ctermbg=red
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
10 :highlight MyGroup2 ctermbg=green
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
11 :highlight MyGroup3 ctermbg=blue
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
12 :match MyGroup1 /TODO/
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
13 :2match MyGroup2 /FIXME/
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
14 :3match MyGroup3 /XXX/
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
15 :if matcharg(1) == ['MyGroup1', 'TODO'] && matcharg(2) == ['MyGroup2', 'FIXME'] && matcharg(3) == ['MyGroup3', 'XXX']
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
16 : let @r .= "OK\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
17 :else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
18 : let @r .= "FAILED\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
19 :endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
20 :" --- Check that "matcharg()" returns an empty list if the argument is not 1,
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
21 :" --- 2 or 3 (only 0 and 4 are tested).
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
22 :let @r .= "*** Test 2: "
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
23 :if matcharg(0) == [] && matcharg(4) == []
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
24 : let @r .= "OK\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
25 :else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
26 : let @r .= "FAILED\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
27 :endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
28 :" --- Check that "matcharg()" returns ['', ''] if a match is not defined.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
29 :let @r .= "*** Test 3: "
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
30 :match
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
31 :2match
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
32 :3match
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
33 :if matcharg(1) == ['', ''] && matcharg(2) == ['', ''] && matcharg(3) == ['', '']
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
34 : let @r .= "OK\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
35 :else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
36 : let @r .= "FAILED\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
37 :endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
38 :" --- Check that "matchadd()" and "getmatches()" agree on added matches and
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
39 :" --- that default values apply.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
40 :let @r .= "*** Test 4: "
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
41 :let m1 = matchadd("MyGroup1", "TODO")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
42 :let m2 = matchadd("MyGroup2", "FIXME", 42)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
43 :let m3 = matchadd("MyGroup3", "XXX", 60, 17)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
44 :if getmatches() == [{'group': 'MyGroup1', 'pattern': 'TODO', 'priority': 10, 'id': 4}, {'group': 'MyGroup2', 'pattern': 'FIXME', 'priority': 42, 'id': 5}, {'group': 'MyGroup3', 'pattern': 'XXX', 'priority': 60, 'id': 17}]
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
45 : let @r .= "OK\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
46 :else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
47 : let @r .= "FAILED\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
48 :endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
49 :" --- Check that "matchdelete()" deletes the matches defined in the previous
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
50 :" --- test correctly.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
51 :let @r .= "*** Test 5: "
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
52 :call matchdelete(m1)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
53 :call matchdelete(m2)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
54 :call matchdelete(m3)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
55 :unlet m1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
56 :unlet m2
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
57 :unlet m3
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
58 :if getmatches() == []
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
59 : let @r .= "OK\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
60 :else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
61 : let @r .= "FAILED\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
62 :endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
63 :" --- Check that "matchdelete()" returns 0 if successful and otherwise -1.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
64 :let @r .= "*** Test 6: "
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
65 :let m = matchadd("MyGroup1", "TODO")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
66 :let r1 = matchdelete(m)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
67 :let r2 = matchdelete(42)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
68 :if r1 == 0 && r2 == -1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
69 : let @r .= "OK\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
70 :else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
71 : let @r .= "FAILED\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
72 :endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
73 :unlet m
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
74 :unlet r1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
75 :unlet r2
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
76 :" --- Check that "clearmatches()" clears all matches defined by ":match" and
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
77 :" --- "matchadd()".
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
78 :let @r .= "*** Test 7: "
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
79 :let m1 = matchadd("MyGroup1", "TODO")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
80 :let m2 = matchadd("MyGroup2", "FIXME", 42)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
81 :let m3 = matchadd("MyGroup3", "XXX", 60, 17)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
82 :match MyGroup1 /COFFEE/
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
83 :2match MyGroup2 /HUMPPA/
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
84 :3match MyGroup3 /VIM/
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
85 :call clearmatches()
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
86 :if getmatches() == []
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
87 : let @r .= "OK\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
88 :else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
89 : let @r .= "FAILED\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
90 :endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
91 :unlet m1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
92 :unlet m2
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
93 :unlet m3
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
94 :" --- Check that "setmatches()" restores a list of matches saved by
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
95 :" --- "getmatches()" without changes. (Matches with equal priority must also
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
96 :" --- remain in the same order.)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
97 :let @r .= "*** Test 8: "
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
98 :let m1 = matchadd("MyGroup1", "TODO")
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
99 :let m2 = matchadd("MyGroup2", "FIXME", 42)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
100 :let m3 = matchadd("MyGroup3", "XXX", 60, 17)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
101 :match MyGroup1 /COFFEE/
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
102 :2match MyGroup2 /HUMPPA/
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
103 :3match MyGroup3 /VIM/
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
104 :let ml = getmatches()
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
105 :call clearmatches()
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
106 :call setmatches(ml)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
107 :if getmatches() == ml
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
108 : let @r .= "OK\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
109 :else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
110 : let @r .= "FAILED\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
111 :endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
112 :call clearmatches()
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
113 :unlet m1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
114 :unlet m2
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
115 :unlet m3
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
116 :unlet ml
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
117 :" --- Check that "setmatches()" will not add two matches with the same ID. The
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
118 :" --- expected behaviour (for now) is to add the first match but not the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
119 :" --- second and to return 0 (even though it is a matter of debate whether
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
120 :" --- this can be considered successful behaviour).
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
121 :let @r .= "*** Test 9: "
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
122 :let r1 = setmatches([{'group': 'MyGroup1', 'pattern': 'TODO', 'priority': 10, 'id': 1}, {'group': 'MyGroup2', 'pattern': 'FIXME', 'priority': 10, 'id': 1}])
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
123 :if getmatches() == [{'group': 'MyGroup1', 'pattern': 'TODO', 'priority': 10, 'id': 1}] && r1 == 0
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
124 : let @r .= "OK\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
125 :else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
126 : let @r .= "FAILED\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
127 :endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
128 :call clearmatches()
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
129 :unlet r1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
130 :" --- Check that "setmatches()" returns 0 if successful and otherwise -1.
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
131 :" --- (A range of valid and invalid input values are tried out to generate the
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
132 :" --- return values.)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
133 :let @r .= "*** Test 10: "
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
134 :let rs1 = setmatches([])
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
135 :let rs2 = setmatches([{'group': 'MyGroup1', 'pattern': 'TODO', 'priority': 10, 'id': 1}])
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
136 :call clearmatches()
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
137 :let rf1 = setmatches(0)
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
138 :let rf2 = setmatches([0])
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
139 :let rf3 = setmatches([{'wrong key': 'wrong value'}])
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
140 :if rs1 == 0 && rs2 == 0 && rf1 == -1 && rf2 == -1 && rf3 == -1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
141 : let @r .= "OK\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
142 :else
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
143 : let @r .= "FAILED\n"
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
144 :endif
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
145 :unlet rs1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
146 :unlet rs2
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
147 :unlet rf1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
148 :unlet rf2
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
149 :unlet rf3
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
150 :highlight clear MyGroup1
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
151 :highlight clear MyGroup2
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
152 :highlight clear MyGroup3
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
153 G"rp
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
154 :/^Results/,$wq! test.out
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
155 ENDTEST
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
156
76efa0be13f1 Initial revision
atsuki
parents:
diff changeset
157 Results of test63: