7
|
1 #
|
1326
|
2 # Makefile to run all tests for Vim
|
7
|
3 #
|
|
4
|
|
5 VIMPROG = ../vim
|
5774
|
6 SCRIPTSOURCE = ../../runtime
|
7
|
7
|
1920
|
8 # Uncomment this line to use valgrind for memory leaks and extra warnings.
|
|
9 # The output goes into a file "valgrind.testN"
|
|
10 # Vim should be compiled with EXITFREE to avoid false warnings.
|
|
11 # This will make testing about 10 times as slow.
|
|
12 # VALGRIND = valgrind --tool=memcheck --leak-check=yes --num-callers=15 --log-file=valgrind.$*
|
1357
|
13
|
2607
|
14
|
7
|
15 SCRIPTS = test1.out test2.out test3.out test4.out test5.out test6.out \
|
|
16 test7.out test8.out test9.out test10.out test11.out \
|
3986
|
17 test12.out test13.out test14.out test15.out test17.out \
|
7
|
18 test18.out test19.out test20.out test21.out test22.out \
|
|
19 test23.out test24.out test25.out test26.out test27.out \
|
|
20 test28.out test29.out test30.out test31.out test32.out \
|
|
21 test33.out test34.out test35.out test36.out test37.out \
|
|
22 test38.out test39.out test40.out test41.out test42.out \
|
|
23 test43.out test44.out test45.out test46.out test47.out \
|
40
|
24 test48.out test49.out test51.out test52.out test53.out \
|
391
|
25 test54.out test55.out test56.out test57.out test58.out \
|
1357
|
26 test59.out test60.out test61.out test62.out test63.out \
|
2004
|
27 test64.out test65.out test66.out test67.out test68.out \
|
2607
|
28 test69.out test70.out test71.out test72.out test73.out \
|
2904
|
29 test74.out test75.out test76.out test77.out test78.out \
|
3443
|
30 test79.out test80.out test81.out test82.out test83.out \
|
4113
|
31 test84.out test85.out test86.out test87.out test88.out \
|
4274
|
32 test89.out test90.out test91.out test92.out test93.out \
|
5351
|
33 test94.out test95.out test96.out test97.out test98.out \
|
5641
|
34 test99.out test100.out test101.out test102.out test103.out \
|
5948
|
35 test104.out test105.out test106.out test107.out \
|
6522
|
36 test_argument_0count.out \
|
6398
|
37 test_argument_count.out \
|
5848
|
38 test_autoformat_join.out \
|
5995
|
39 test_breakindent.out \
|
6096
|
40 test_changelist.out \
|
6398
|
41 test_close_count.out \
|
6424
|
42 test_command_count.out \
|
6712
|
43 test_erasebackword.out \
|
5848
|
44 test_eval.out \
|
6868
|
45 test_increment.out \
|
6098
|
46 test_insertcount.out \
|
6777
|
47 test_listchars.out \
|
6140
|
48 test_listlbr.out \
|
|
49 test_listlbr_utf8.out \
|
6299
|
50 test_mapping.out \
|
6616
|
51 test_marks.out \
|
6438
|
52 test_nested_function.out \
|
6140
|
53 test_options.out \
|
6847
|
54 test_perl.out \
|
6140
|
55 test_qf_title.out \
|
6847
|
56 test_ruby.out \
|
6903
|
57 test_search_mbyte.out \
|
6841
|
58 test_set.out \
|
6307
|
59 test_signs.out \
|
6675
|
60 test_textobjects.out \
|
6140
|
61 test_utf8.out
|
7
|
62
|
|
63 SCRIPTS_GUI = test16.out
|
|
64
|
6328
|
65 SCRIPTS_BENCH = bench_re_freeze.out
|
|
66
|
7
|
67 .SUFFIXES: .in .out
|
|
68
|
1717
|
69 nongui: nolog $(SCRIPTS) report
|
|
70
|
|
71 gui: nolog $(SCRIPTS) $(SCRIPTS_GUI) report
|
7
|
72
|
6328
|
73 benchmark: $(SCRIPTS_BENCH)
|
|
74
|
1717
|
75 report:
|
7
|
76 @echo
|
1717
|
77 @echo 'Test results:'
|
|
78 @/bin/sh -c "if test -f test.log; \
|
|
79 then cat test.log; echo TEST FAILURE; exit 1; \
|
|
80 else echo ALL DONE; \
|
|
81 fi"
|
7
|
82
|
|
83 $(SCRIPTS) $(SCRIPTS_GUI): $(VIMPROG)
|
|
84
|
3992
|
85 RM_ON_RUN = test.out X* viminfo
|
6328
|
86 RM_ON_START = tiny.vim small.vim mbyte.vim mzscheme.vim lua.vim test.ok benchmark.out
|
5909
|
87 RUN_VIM = VIMRUNTIME=$(SCRIPTSOURCE); export VIMRUNTIME; $(VALGRIND) $(VIMPROG) -u unix.vim -U NONE --noplugin -s dotest.in
|
3992
|
88
|
7
|
89 clean:
|
3992
|
90 -rm -rf *.out *.failed *.rej *.orig test.log $(RM_ON_RUN) $(RM_ON_START) valgrind.*
|
7
|
91
|
|
92 test1.out: test1.in
|
5363
|
93 -rm -rf $*.failed $(RM_ON_RUN) $(RM_ON_START) wrongtermsize
|
3992
|
94 $(RUN_VIM) $*.in
|
5702
|
95 @/bin/sh -c "if test -f wrongtermsize; \
|
5363
|
96 then echo; \
|
|
97 echo test1 FAILED - terminal size must be 80x24 or larger; \
|
|
98 echo; exit 1; \
|
|
99 elif diff test.out $*.ok; \
|
7
|
100 then mv -f test.out $*.out; \
|
|
101 else echo; \
|
|
102 echo test1 FAILED - Something basic is wrong; \
|
|
103 echo; exit 1; fi"
|
|
104 -rm -rf X* viminfo
|
|
105
|
|
106 .in.out:
|
3992
|
107 -rm -rf $*.failed test.ok $(RM_ON_RUN)
|
7
|
108 cp $*.ok test.ok
|
4313
|
109 # Sleep a moment to avoid that the xterm title is messed up.
|
|
110 # 200 msec is sufficient, but only modern sleep supports a fraction of
|
|
111 # a second, fall back to a second if it fails.
|
|
112 @-/bin/sh -c "sleep .2 > /dev/null 2>&1 || sleep 1"
|
3992
|
113 -$(RUN_VIM) $*.in
|
|
114
|
|
115 # For flaky tests retry one time.
|
|
116 @/bin/sh -c "if test -f test.out -a $* = test61; then \
|
|
117 if diff test.out $*.ok; \
|
|
118 then echo flaky test ok first time; \
|
|
119 else rm -rf $*.failed $(RM_ON_RUN); \
|
|
120 $(RUN_VIM) $*.in; \
|
|
121 fi \
|
|
122 fi"
|
|
123
|
|
124 # Check if the test.out file matches test.ok.
|
4444
|
125 @/bin/sh -c "if test -f test.out; then \
|
169
|
126 if diff test.out $*.ok; \
|
|
127 then mv -f test.out $*.out; \
|
|
128 else echo $* FAILED >>test.log; mv -f test.out $*.failed; \
|
|
129 fi \
|
|
130 else echo $* NO OUTPUT >>test.log; \
|
7
|
131 fi"
|
4444
|
132 @/bin/sh -c "if test -f valgrind; then\
|
|
133 mv -f valgrind valgrind.$*; \
|
|
134 fi"
|
3855
|
135 -rm -rf X* test.ok viminfo
|
7
|
136
|
1405
|
137 test49.out: test49.vim
|
|
138
|
|
139 test60.out: test60.vim
|
|
140
|
6328
|
141 bench_re_freeze.out: bench_re_freeze.vim
|
|
142 -rm -rf benchmark.out $(RM_ON_RUN)
|
|
143 # Sleep a moment to avoid that the xterm title is messed up.
|
|
144 # 200 msec is sufficient, but only modern sleep supports a fraction of
|
|
145 # a second, fall back to a second if it fails.
|
|
146 @-/bin/sh -c "sleep .2 > /dev/null 2>&1 || sleep 1"
|
|
147 -$(RUN_VIM) $*.in
|
|
148 @/bin/sh -c "if test -f benchmark.out; then cat benchmark.out; fi"
|
|
149
|
7
|
150 nolog:
|
1717
|
151 -rm -f test.log
|