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