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 \
|
6935
|
38 test_autocmd_option.out \
|
5848
|
39 test_autoformat_join.out \
|
5995
|
40 test_breakindent.out \
|
6096
|
41 test_changelist.out \
|
6398
|
42 test_close_count.out \
|
6424
|
43 test_command_count.out \
|
6712
|
44 test_erasebackword.out \
|
5848
|
45 test_eval.out \
|
6933
|
46 test_fixeol.out \
|
6868
|
47 test_increment.out \
|
6098
|
48 test_insertcount.out \
|
6777
|
49 test_listchars.out \
|
6140
|
50 test_listlbr.out \
|
|
51 test_listlbr_utf8.out \
|
6299
|
52 test_mapping.out \
|
6616
|
53 test_marks.out \
|
6438
|
54 test_nested_function.out \
|
6140
|
55 test_options.out \
|
6847
|
56 test_perl.out \
|
6140
|
57 test_qf_title.out \
|
6847
|
58 test_ruby.out \
|
6903
|
59 test_search_mbyte.out \
|
6841
|
60 test_set.out \
|
6307
|
61 test_signs.out \
|
6675
|
62 test_textobjects.out \
|
6140
|
63 test_utf8.out
|
7
|
64
|
|
65 SCRIPTS_GUI = test16.out
|
|
66
|
6328
|
67 SCRIPTS_BENCH = bench_re_freeze.out
|
|
68
|
7
|
69 .SUFFIXES: .in .out
|
|
70
|
1717
|
71 nongui: nolog $(SCRIPTS) report
|
|
72
|
|
73 gui: nolog $(SCRIPTS) $(SCRIPTS_GUI) report
|
7
|
74
|
6328
|
75 benchmark: $(SCRIPTS_BENCH)
|
|
76
|
1717
|
77 report:
|
7
|
78 @echo
|
1717
|
79 @echo 'Test results:'
|
|
80 @/bin/sh -c "if test -f test.log; \
|
|
81 then cat test.log; echo TEST FAILURE; exit 1; \
|
|
82 else echo ALL DONE; \
|
|
83 fi"
|
7
|
84
|
|
85 $(SCRIPTS) $(SCRIPTS_GUI): $(VIMPROG)
|
|
86
|
3992
|
87 RM_ON_RUN = test.out X* viminfo
|
6328
|
88 RM_ON_START = tiny.vim small.vim mbyte.vim mzscheme.vim lua.vim test.ok benchmark.out
|
5909
|
89 RUN_VIM = VIMRUNTIME=$(SCRIPTSOURCE); export VIMRUNTIME; $(VALGRIND) $(VIMPROG) -u unix.vim -U NONE --noplugin -s dotest.in
|
3992
|
90
|
7
|
91 clean:
|
3992
|
92 -rm -rf *.out *.failed *.rej *.orig test.log $(RM_ON_RUN) $(RM_ON_START) valgrind.*
|
7
|
93
|
|
94 test1.out: test1.in
|
5363
|
95 -rm -rf $*.failed $(RM_ON_RUN) $(RM_ON_START) wrongtermsize
|
3992
|
96 $(RUN_VIM) $*.in
|
5702
|
97 @/bin/sh -c "if test -f wrongtermsize; \
|
5363
|
98 then echo; \
|
|
99 echo test1 FAILED - terminal size must be 80x24 or larger; \
|
|
100 echo; exit 1; \
|
|
101 elif diff test.out $*.ok; \
|
7
|
102 then mv -f test.out $*.out; \
|
|
103 else echo; \
|
|
104 echo test1 FAILED - Something basic is wrong; \
|
|
105 echo; exit 1; fi"
|
|
106 -rm -rf X* viminfo
|
|
107
|
|
108 .in.out:
|
3992
|
109 -rm -rf $*.failed test.ok $(RM_ON_RUN)
|
7
|
110 cp $*.ok test.ok
|
4313
|
111 # Sleep a moment to avoid that the xterm title is messed up.
|
|
112 # 200 msec is sufficient, but only modern sleep supports a fraction of
|
|
113 # a second, fall back to a second if it fails.
|
|
114 @-/bin/sh -c "sleep .2 > /dev/null 2>&1 || sleep 1"
|
3992
|
115 -$(RUN_VIM) $*.in
|
|
116
|
|
117 # For flaky tests retry one time.
|
|
118 @/bin/sh -c "if test -f test.out -a $* = test61; then \
|
|
119 if diff test.out $*.ok; \
|
|
120 then echo flaky test ok first time; \
|
|
121 else rm -rf $*.failed $(RM_ON_RUN); \
|
|
122 $(RUN_VIM) $*.in; \
|
|
123 fi \
|
|
124 fi"
|
|
125
|
|
126 # Check if the test.out file matches test.ok.
|
4444
|
127 @/bin/sh -c "if test -f test.out; then \
|
169
|
128 if diff test.out $*.ok; \
|
|
129 then mv -f test.out $*.out; \
|
|
130 else echo $* FAILED >>test.log; mv -f test.out $*.failed; \
|
|
131 fi \
|
|
132 else echo $* NO OUTPUT >>test.log; \
|
7
|
133 fi"
|
4444
|
134 @/bin/sh -c "if test -f valgrind; then\
|
|
135 mv -f valgrind valgrind.$*; \
|
|
136 fi"
|
3855
|
137 -rm -rf X* test.ok viminfo
|
7
|
138
|
1405
|
139 test49.out: test49.vim
|
|
140
|
|
141 test60.out: test60.vim
|
|
142
|
6328
|
143 bench_re_freeze.out: bench_re_freeze.vim
|
|
144 -rm -rf benchmark.out $(RM_ON_RUN)
|
|
145 # Sleep a moment to avoid that the xterm title is messed up.
|
|
146 # 200 msec is sufficient, but only modern sleep supports a fraction of
|
|
147 # a second, fall back to a second if it fails.
|
|
148 @-/bin/sh -c "sleep .2 > /dev/null 2>&1 || sleep 1"
|
|
149 -$(RUN_VIM) $*.in
|
|
150 @/bin/sh -c "if test -f benchmark.out; then cat benchmark.out; fi"
|
|
151
|
7
|
152 nolog:
|
1717
|
153 -rm -f test.log
|