xref: /vim-8.2.3635/src/testdir/Makefile (revision 9c0cec65)
1#
2# Makefile to run all tests for Vim
3#
4
5# Use console or GUI.
6VIMPROG = ../vim
7XXDPROG = ../xxd/xxd
8# VIMPROG = ../gvim
9
10SCRIPTSOURCE = ../../runtime
11
12# Comment out this line to see the verbose output of tests.
13#
14# Catches SwapExists to avoid hanging at the ATTENTION prompt.
15# REDIR_TEST_TO_NULL = --cmd 'au SwapExists * let v:swapchoice = "e"' > /dev/null
16
17# Uncomment this line to use valgrind for memory leaks and extra warnings.
18#   The output goes into a file "valgrind.testN"
19#   Vim should be compiled with EXITFREE to avoid false warnings.
20#   This will make testing about 10 times as slow.
21# VALGRIND = valgrind --tool=memcheck --leak-check=yes --num-callers=25 --log-file=valgrind.$*
22
23default: nongui
24
25# The list of tests is common to all systems.
26# This defines NEW_TESTS, NEW_TESTS_RES, SCRIPTS_ALL, SCRIPTS_MORE* and
27# SCRIPTS_GUI.
28include Make_all.mak
29
30
31SCRIPTS = $(SCRIPTS_ALL) \
32	  $(SCRIPTS_MORE1) \
33	  $(SCRIPTS_MORE2) \
34	  $(SCRIPTS_MORE4)
35
36# Explicit dependencies.
37test49.out: test49.vim
38
39test_options.res test_alot.res: opt_test.vim
40
41SCRIPTS_BENCH = bench_re_freeze.out
42
43.SUFFIXES: .in .out .res .vim
44
45nongui:	nolog $(SCRIPTS_FIRST) $(SCRIPTS) newtests report
46
47gui:	nolog $(SCRIPTS_FIRST) $(SCRIPTS) $(SCRIPTS_GUI) newtests report
48
49benchmark: $(SCRIPTS_BENCH)
50
51report:
52	$(RUN_VIMTEST) $(NO_INITS) -S summarize.vim messages $(REDIR_TEST_TO_NULL)
53	@echo
54	@echo 'Test results:'
55	@cat test_result.log
56	@/bin/sh -c "if test -f test.log; \
57		then echo TEST FAILURE; exit 1; \
58		else echo ALL DONE; \
59		fi"
60
61$(SCRIPTS_FIRST) $(SCRIPTS) $(SCRIPTS_GUI) $(NEW_TESTS_RES): $(VIMPROG)
62
63# Must run test1 first to create small.vim.
64$(SCRIPTS) $(SCRIPTS_GUI) $(NEW_TESTS_RES): $(SCRIPTS_FIRST)
65
66
67# Execute an individual new style test, e.g.:
68# 	make test_largefile
69$(NEW_TESTS):
70	rm -f $@.res test.log messages
71	$(MAKE) -f Makefile $@.res
72	@if test -f test.log; then \
73		cat test.log; \
74	fi
75	cat messages
76
77RM_ON_RUN = test.out X* viminfo
78RM_ON_START = tiny.vim small.vim mbyte.vim mzscheme.vim test.ok benchmark.out
79RUN_VIM = VIMRUNTIME=$(SCRIPTSOURCE); export VIMRUNTIME; $(VALGRIND) $(VIMPROG) -f $(GUI_FLAG) -u unix.vim $(NO_INITS) -s dotest.in
80
81clean:
82	-rm -rf *.out *.failed *.res *.rej *.orig
83	-rm opt_test.vim test.log test_result.log messages
84	-rm $(RM_ON_RUN) $(RM_ON_START)
85	-rm valgrind.*
86
87test1.out: test1.in
88	-rm -rf $*.failed $(RM_ON_RUN) $(RM_ON_START) wrongtermsize
89	$(RUN_VIM) $*.in $(REDIR_TEST_TO_NULL)
90	@/bin/sh -c "if test -f wrongtermsize; \
91		then echo; \
92		echo test1 FAILED - terminal size must be 80x24 or larger; \
93		echo; exit 1; \
94		elif diff test.out $*.ok; \
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:
102	-rm -rf $*.failed test.ok $(RM_ON_RUN)
103	cp $*.ok test.ok
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"
108	$(RUN_VIM) $*.in $(REDIR_TEST_TO_NULL)
109
110	# For flaky tests retry one time.  No tests at the moment.
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.
120	@/bin/sh -c "if test -f test.out; then \
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; \
126		fi"
127	@/bin/sh -c "if test -f valgrind; then\
128		  mv -f valgrind valgrind.$*; \
129		fi"
130	-rm -rf X* test.ok viminfo
131
132bench_re_freeze.out: bench_re_freeze.vim
133	-rm -rf benchmark.out $(RM_ON_RUN)
134	# Sleep a moment to avoid that the xterm title is messed up.
135	# 200 msec is sufficient, but only modern sleep supports a fraction of
136	# a second, fall back to a second if it fails.
137	@-/bin/sh -c "sleep .2 > /dev/null 2>&1 || sleep 1"
138	$(RUN_VIM) $*.in $(REDIR_TEST_TO_NULL)
139	@/bin/sh -c "if test -f benchmark.out; then cat benchmark.out; fi"
140
141nolog:
142	-rm -f test.log messages
143
144
145# New style of tests uses Vim script with assert calls.  These are easier
146# to write and a lot easier to read and debug.
147# Limitation: Only works with the +eval feature.
148RUN_VIMTEST = VIMRUNTIME=$(SCRIPTSOURCE); export VIMRUNTIME; $(VALGRIND) $(VIMPROG) -f $(GUI_FLAG) -u unix.vim
149
150newtests: newtestssilent
151	@/bin/sh -c "if test -f messages && grep -q 'SKIPPED\|FAILED' messages; then cat messages; fi"
152
153newtestssilent: $(NEW_TESTS_RES)
154
155
156.vim.res:
157	@echo "$(VIMPROG)" > vimcmd
158	@echo "$(RUN_VIMTEST)" >> vimcmd
159	$(RUN_VIMTEST) $(NO_INITS) -S runtest.vim $*.vim $(REDIR_TEST_TO_NULL)
160	@rm vimcmd
161
162test_gui.res: test_gui.vim
163	@echo "$(VIMPROG)" > vimcmd
164	@echo "$(RUN_GVIMTEST)" >> vimcmd
165	$(RUN_VIMTEST) -u NONE $(NO_INITS) -S runtest.vim $<
166	@rm vimcmd
167
168test_gui_init.res: test_gui_init.vim
169	@echo "$(VIMPROG)" > vimcmd
170	@echo "$(RUN_GVIMTEST_WITH_GVIMRC)" >> vimcmd
171	$(RUN_VIMTEST) -u gui_preinit.vim -U gui_init.vim $(NO_PLUGINS) -S runtest.vim $<
172	@rm vimcmd
173
174opt_test.vim: ../option.c gen_opt_test.vim
175	$(VIMPROG) -u NONE -S gen_opt_test.vim --noplugin --not-a-term ../option.c
176
177test_xxd.res:
178	XXD=$(XXDPROG); export XXD; $(RUN_VIMTEST) $(NO_INITS) -S runtest.vim test_xxd.vim
179