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