SUBDIRS = cas assemblyresolve
-# avoid including eglib twice since GLIB_LIBS == GMODULE_LIBS for eglib builds
-if EGLIB_BUILD
-glib_libs = $(GLIB_LIBS)
-else
-glib_libs = $(GLIB_LIBS) $(GMODULE_LIBS)
-endif
-
check-local: test
aotcheck: testaot gshared-aot
TEST_PROG = ../interpreter/mint
-JITTEST_PROG = ../mini/mono
+
+JITTEST_PROG = $(if $(VALGRIND), valgrind $(VALGRIND_ARGS),) $(if $(SGEN),$(top_builddir)/mono/mini/mono-sgen,$(top_builddir)/mono/mini/mono)
TEST_PROG_RUN = MONO_SHARED_DIR=$(mono_build_root)/runtime MONO_CFG_DIR=$(mono_build_root)/runtime/etc $(LIBTOOL) --mode=execute $(TEST_PROG)
JITTEST_PROG_RUN = MONO_SHARED_DIR=$(mono_build_root)/runtime MONO_CFG_DIR=$(mono_build_root)/runtime/etc $(LIBTOOL) --mode=execute $(JITTEST_PROG)
RUNTIME_ARGS=--config tests-config --optimize=all --debug
-with_mono_path = MONO_PATH=$(mcs_topdir)/class/lib/net_2_0
+with_mono_path = MONO_PATH=$(mcs_topdir)/class/lib/net_4_0
with_mono_path_moonlight = MONO_PATH=$(mcs_topdir)/class/lib/moonlight_raw
RUNTIME = $(with_mono_path) $(top_builddir)/runtime/mono-wrapper
MKBUNDLE = \
PKG_CONFIG_PATH=$(top_builddir):$(PKG_CONFIG_PATH) \
- $(RUNTIME) $(mcs_topdir)/class/lib/net_2_0/mkbundle.exe
+ $(RUNTIME) $(mcs_topdir)/class/lib/net_4_0/mkbundle.exe
-MCS = $(RUNTIME) $(mcs_topdir)/class/lib/net_2_0/gmcs.exe -unsafe -nowarn:0162 -nowarn:0168 -nowarn:0219 -debug
-SMCS = $(RUNTIME_MOONLIGHT) --runtime=moonlight --security=temporary-smcs-hack $(mcs_topdir)/class/lib/moonlight_raw/smcs.exe -unsafe -nowarn:0162 -nowarn:0168 -nowarn:0219
-ILASM = $(RUNTIME) $(mcs_topdir)/class/lib/net_2_0/ilasm.exe
+MCS = $(RUNTIME) $(mcs_topdir)/class/lib/build/mcs.exe -unsafe -nowarn:0162 -nowarn:0168 -nowarn:0219 -debug
+ILASM = $(RUNTIME) $(mcs_topdir)/class/lib/net_4_0/ilasm.exe
BENCHSRC=fib.cs random.cs nested-loops.cs ackermann.cs tight-loop.cs sieve.cs
process-stress.cs \
assembly-load-stress.cs
+# Disabled until ?mcs is fixed
+# bug-331958.cs
BASE_TEST_CS_SRC= \
array-init.cs \
arraylist.cs \
async_read.cs \
threadpool.cs \
threadpool1.cs \
+ threadpool-exceptions1.cs \
+ threadpool-exceptions2.cs \
+ threadpool-exceptions3.cs \
+ threadpool-exceptions4.cs \
+ threadpool-exceptions5.cs \
+ threadpool-exceptions6.cs \
+ threadpool-exceptions7.cs \
base-definition.cs \
bug-27420.cs \
bug-47295.cs \
bug-78656.cs \
bug-77127.cs \
bug-323114.cs \
- bug-331958.cs \
interlocked.cs \
cross-domain.cs \
appdomain-exit.cs \
bug-473482.2.cs \
bug-473999.2.cs \
bug-479763.2.cs \
+ bug-616463.cs \
bug-80392.2.cs \
dynamic-method-access.2.cs \
dynamic-method-finalize.2.cs \
bug-561239.cs \
bug-562150.cs \
bug-575941.cs \
- bug-599469.cs
+ bug-599469.cs \
+ bug-389886-3.cs \
+ monitor.cs \
+ dynamic-method-resurrection.cs \
+ bug-666008.cs
TEST_CS_SRC_DIST= \
$(BASE_TEST_CS_SRC) \
async-exc-compilation.cs \
- filter-stack.cs
+ filter-stack.cs \
+ finally_guard.cs
+
+TEST_CS_SRC_GEN = \
+ runtime-invoke.gen.cs \
+ imt_big_iface_test.cs
if AMD64
-TEST_CS_SRC = $(BASE_TEST_CS_SRC) async-exc-compilation.cs
+TEST_CS_SRC = $(BASE_TEST_CS_SRC) $(TEST_CS_SRC_GEN) async-exc-compilation.cs finally_guard.cs
+# #651684
+PLATFORM_DISABLED_TESTS = finally_guard.exe
else
if X86
-TEST_CS_SRC = $(BASE_TEST_CS_SRC) async-exc-compilation.cs
+TEST_CS_SRC = $(BASE_TEST_CS_SRC) $(TEST_CS_SRC_GEN) async-exc-compilation.cs finally_guard.cs
else
-TEST_CS_SRC = $(BASE_TEST_CS_SRC)
+TEST_CS_SRC = $(BASE_TEST_CS_SRC) $(TEST_CS_SRC_GEN)
endif
endif
if X86
if HOST_WIN32
-PLATFORM_DISABLED_TESTS=async-exc-compilation.exe
+PLATFORM_DISABLED_TESTS=async-exc-compilation.exe finally_guard.exe
endif
endif
PLATFORM_DISABLED_TESTS=filter-stack.exe
endif
+if S390x
+PLATFORM_DISABLED_TESTS=dynamic-method-resurrection.exe
+#PLATFORM_DISABLED_TESTS=dynamic-method-resurrection.exe exception17.exe
+endif
+
# The two finalizer tests only work under sgen
# gc-altstack.exe fails under boehm because it has no support for altstack
+# bug-459094.exe creates an extremely deep directory tree
DISABLED_TESTS= \
delegate-async-exception.exe \
bug-348522.2.exe \
finalizer-wait.exe \
critical-finalizers.exe \
gc-altstack.exe \
+ bug-459094.exe \
$(PLATFORM_DISABLED_TESTS)
AOT_DISABLED_TESTS=constraints-load.exe
array_load_exception.il \
bug-481403.il \
interface-with-static-method.il \
- bug-515884.il
-
-# bug-318677.il
+ bug-515884.il \
+ bug-633291.il \
+ delegate-with-null-target.il \
+ bug-318677.il
# pre-requisite test sources: files that are not test themselves
# but that need to be compiled
# mkbundle works on ppc, but the pkg-config POC doesn't when run with make test
if POWERPC
-test_platform: testbundle
+test_platform:
else
# Can't use mkbundle on win32 since there is no static build there
# Can't run test-unhandled-exception on Windows because of all the debug popups...
endif
endif
+if X86
+if HOST_WIN32
+else
+test_platform: test-eglib-remap
+endif
+endif
+
+#
+# Test that no symbols are missed in eglib-remap.h
+#
+OK_G_SYMBOLS='g_list\|g_slist\|g_concat_dir_and_file'
+test-eglib-remap:
+ @echo "Testing eglib remap..."
+ @if which nm > /dev/null; then if nm $(top_builddir)/mono/mini/mono | grep -v $(OK_G_SYMBOLS) | grep 't g_'; then exit 1; else exit 0; fi; fi
+
#
# Tests that the internals in mono/io-layer/messages.c are ok by triggering the
# code that checks that the table is properly sorted
# test_messages fails on the buildbots
#test: assemblyresolve/test/asm.dll testjit test-type-load test-generic-sharing test_platform test_2_1 test_messages
-test: assemblyresolve/test/asm.dll testjit test-type-load test-generic-sharing test_platform test-runtime-invoke test-imt-big-iface test_2_1
+test: assemblyresolve/test/asm.dll testjit test-generic-sharing test-type-load test_platform test_2_1 test-process-exit
assemblyresolve/test/asm.dll:
$(MAKE) -C assemblyresolve prereq
# Generated tests for runtime invoke
EXTRA_DIST += gen-runtime-invoke.cs
-test-runtime-invoke: TestDriver.dll gen-runtime-invoke.exe
- @$(RUNTIME) gen-runtime-invoke.exe > runtime-invoke.gen.cs
- @$(MCS) -out:runtime-invoke.gen.exe -r:TestDriver.dll runtime-invoke.gen.cs
- @echo "Testing runtime-invoke.gen.exe..."
- @$(RUNTIME) runtime-invoke.gen.exe > runtime-invoke.gen.exe.stdout 2> runtime-invoke.gen.exe.stderr
+runtime-invoke.gen.exe: TestDriver.dll gen-runtime-invoke.exe
+ $(RUNTIME) gen-runtime-invoke.exe > runtime-invoke.gen.cs
+ $(MCS) -out:runtime-invoke.gen.exe -r:TestDriver.dll runtime-invoke.gen.cs
EXTRA_DIST += make-imt-test.cs
-test-imt-big-iface: TestDriver.dll make-imt-test.exe
- @$(RUNTIME) make-imt-test.exe > imt_big_iface_test.cs
- @$(MCS) -out:imt_big_iface_test.exe -r:TestDriver.dll imt_big_iface_test.cs
- @echo "Testing imt_big_iface_test.exe..."
- @$(RUNTIME) imt_big_iface_test.exe > imt_big_iface_test.exe.stdout 2> imt_big_iface_test.exe.stderr
+imt_big_iface_test.exe: TestDriver.dll make-imt-test.exe
+ $(RUNTIME) make-imt-test.exe > imt_big_iface_test.cs
+ $(MCS) -out:imt_big_iface_test.exe -r:TestDriver.dll imt_big_iface_test.cs
EXTRA_DIST += test-inline-call-stack-library.cs test-inline-call-stack.cs
test-inline-call-stack-library.dll: TestDriver.dll $(srcdir)/test-inline-call-stack-library.cs
EXTRA_DIST += unhandled-exception-base-configuration.config
EXTRA_DIST += unhandled-exception-legacy-configuration.config
+EXTRA_DIST += appdomain-unload.exe.config
EXTRA_DIST += unhandled-exception-test-case.2.cs
EXTRA_DIST += unhandled-exception-test-runner.2.cs
unhandled-exception-test-case.1.cs: unhandled-exception-test-case.2.cs
$(MCS) -target:library -out:bug-81691-b.dll -r:bug-81691-a.dll $(srcdir)/bug-81691-b.cs
$(MCS) -r:bug-81691-b.dll -out:bug-81691.exe $(srcdir)/bug-81691.cs
rm -f bug-81691-a.dll
+bug-81691.exe: bug-81691-b.dll
EXTRA_DIST += bug-81466-lib.il
bug-81466-lib.dll: bug-81466-lib.il
generic-stack-traces.2.exe generic-stack-traces2.2.exe \
bug-472600.2.exe bug-473482.2.exe bug-473999.2.exe \
bug-479763.2.exe generic-xdomain.2.exe \
- generic-type-load-exception.2.exe
+ generic-type-load-exception.2.exe bug-616463.exe
test-generic-sharing-normal: $(GSHARED_TESTS)
@for fn in $+ ; do \
modules.exe: modules.cs modules-m1.netmodule TestDriver.dll
$(MCS) -out:$@ /addmodule:modules-m1.netmodule -r:TestDriver.dll $(srcdir)/modules.cs
-EXTRA_DIST += dtest.cs dtest-app.cs
-
-dcheck: dtest.dll dtest-app.exe
- @echo "Testing soft-debugger..."
- @nunit-console2 -labels dtest.dll > dcheck.stdout 2> dcheck.stderr
-
-dtest.dll:
- $(MCS) -r:Mono.Debugger.Soft.dll -pkg:mono-nunit /target:library -r:`pkg-config --variable Libraries cecil` /debug $(srcdir)/dtest.cs
-
-dtest-app.exe:
- $(MCS) /debug /unsafe $(srcdir)/dtest-app.cs
-
# Useful if mono is compiled with --enable-shared=no
patch-libtool:
cp "../../libtool" .
sed -e 's,LIBTOOL =,LIBTOOL2 =,g' Makefile > 2 && echo "LIBTOOL = bash ./libtool" > 1 && cat 1 2 > Makefile
touch libtest.c
+EXTRA_DIST += bug-438454.cs bug-438454.exe.stdout.expected
+test-process-exit:
+ @$(MCS) $(srcdir)/bug-438454.cs -out:bug-438454.exe
+ @echo "Testing bug-438454.exe..."
+ @$(RUNTIME) bug-438454.exe > bug-438454.exe.stdout
+ @diff -w bug-438454.exe.stdout $(srcdir)/bug-438454.exe.stdout.expected
+
+OOM_TESTS = \
+ gc-oom-handling.exe \
+ gc-oom-handling2.exe
+
+
+test-oom: $(OOM_TESTS)
+ @for fn in $+ ; do \
+ echo "Testing $$fn ..."; \
+ MONO_GC_PARAMS=max-heap-size=16m,major=marksweep-par MONO_ENV_OPTIONS="--gc=sgen" $(RUNTIME) $$fn > $$fn.stdout || exit 1; \
+ MONO_GC_PARAMS=max-heap-size=16m MONO_ENV_OPTIONS="--gc=sgen" $(RUNTIME) $$fn > $$fn.stdout || exit 1; \
+ MONO_GC_PARAMS=max-heap-size=16m $(RUNTIME) $$fn > $$fn.stdout || exit 1; \
+ done
+
+
noinst_LTLIBRARIES = libtest.la
INCLUDES = $(GLIB_CFLAGS) $(GMODULE_CFLAGS)
libtest_la_LDFLAGS = -rpath `pwd`
endif
libtest_la_SOURCES = libtest.c
-libtest_la_LIBADD = $(glib_libs)
+libtest_la_LIBADD = $(GLIB_LIBS)
CLEANFILES = $(TESTSI_CS) $(TESTSI_IL) $(STRESS_TESTS) *.dll *.stdout *.aotlog *.exe stest.dat