2004-11-23 Marek Safar <marek.safar@seznam.cz>
[mono.git] / mcs / tests / Makefile
index bf69be471eb30431726b96f80b064e89689d4d9d..36994e87bd012424334cd9ec699a873d9d4ea9da 100644 (file)
@@ -1,39 +1,57 @@
 #
 # use `run-test-local'
 #
+# *** make sure you add multi-file tests to TEST_ORDERING if necessary
+
 thisdir = tests
 SUBDIRS = 
 include ../build/rules.make
 
-DISTFILES = README.tests $(wildcard *.cs)
+DISTFILES = README.tests harness.mk $(wildcard *.cs)
+
+ifeq (default, $(PROFILE))
+# force this, we don't case if CSC is broken. This also
+# means we can use --options, yay.
+
+MCS = MONO_PATH="$(topdir)/class/lib/$(PROFILE)$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH" $(INTERNAL_MCS)
+endif
 
 # We don't want debugging info :-)
 
 USE_MCS_FLAGS :=
 
+# All new tests for 'mcs' go in here
+# These tests are not run by GMCS since the corresponding code is not yet in there.-
+# Martin Baulig will manually move them into TEST_SOURCES_common after merging the code into GMCS.
+# He may also move some to TEST_EXCLUDE_net_2_0 if some of the merges are inappropriate for GMCS.
 #
-# If you add any tests here, please do also add them to README.Tests !
-#
+NEW_TEST_SOURCES_common = test-294 test-304 test-305 test-306 test-307 test-318 mtest-5-dll mtest-5-exe \\r
+                       test-319-dll test-319-exe
 
-TEST_SOURCES = \
-       test-1   test-2   test-3   test-4   test-5   test-6   test-7   test-8   test-9   test-10 \
-       test-11  test-12  test-13  test-14  test-15  test-16  test-17  test-18  test-19  test-20 \
-       test-21  test-22  test-23  test-24  test-25  test-26  test-27  test-28  test-29  test-30 \
-       test-31  test-32  test-33  test-34  test-35  test-36  test-37  test-38  test-39  test-40 \
-       test-41  test-42  test-43  test-44  test-45  test-46  test-47  test-48  test-49          \
-       test-51  test-52  test-53  test-54  test-55  test-56  test-57           test-59  test-60 \
-       test-61  test-62  test-63  test-64  test-65  test-66           test-68  test-69  test-70 \
-       test-71  test-72  test-73  test-74  test-75  test-76  test-77  test-78  test-79  test-80 \
-       test-81  test-82  test-83  test-84  test-85  test-86  test-87  test-88  test-89  test-90 \
-       test-91  test-92  test-93  test-94  test-95  test-96  test-97  test-98  test-99  test-100\
-       test-101 test-102 test-103 test-104          test-106 test-107 test-108 test-109 test-110\
+#
+# Please do _not_ add any tests here - all new tests should go into NEW_TEST_SOURCES_common
+# Martin Baulig is the only one who may add tests here - after merging the latest MCS patches
+# into GMCS
+#
+TEST_SOURCES_common = \
+       test-1   test-2   test-3   test-4   test-5   test-6   test-7   test-8   test-9   test-10  \
+       test-11  test-12  test-13  test-14  test-15  test-16  test-17  test-18  test-19  test-20  \
+       test-21  test-22  test-23  test-24  test-25  test-26  test-27  test-28  test-29  test-30  \
+       test-31  test-32  test-33  test-34  test-35  test-36  test-37  test-38  test-39  test-40  \
+       test-41  test-42  test-43  test-44  test-45  test-46  test-47  test-48  test-49           \
+       test-51  test-52  test-53  test-54  test-55  test-56  test-57  test-58  test-59  test-60  \
+       test-61  test-62  test-63  test-64  test-65  test-66           test-68  test-69  test-70  \
+       test-71  test-72  test-73  test-74  test-75  test-76  test-77  test-78  test-79  test-80  \
+       test-81  test-82  test-83  test-84  test-85  test-86  test-87  test-88  test-89  test-90  \
+       test-91  test-92  test-93  test-94  test-95  test-96  test-97  test-98  test-99  test-100 \
+       test-101 test-102 test-103 test-104          test-106 test-107 test-108 test-109 test-110 \
        test-111 test-112 test-113 test-114 test-115 test-116 test-117 test-118 test-119          \
        test-121 test-122 test-123          test-125 test-126 test-127 test-128 test-129 test-130 \
        test-131                   test-134 test-135 test-136 test-137 test-138 test-139 test-140 \
        test-141 test-142 test-143 test-144 test-145 test-146 test-147 test-148 test-149 test-150 \
        test-151 test-152 test-153 test-154 test-155 test-156 test-157 test-158 test-159 test-160 \
        test-161 test-162 test-163 test-164 test-165 test-166 test-167 test-168 test-169 test-170 \
-                test-172 test-173 test-174 test-175 test-176 test-177 test-178 test-179 test-180 \
+       test-171 test-172 test-173 test-174 test-175 test-176 test-177 test-178 test-179 test-180 \
        test-181 test-182 test-183 test-184 test-185 test-186 test-187 test-188 test-189 test-190 \
        test-191 test-192 test-193 test-194 test-195 test-196 test-197 test-198 test-199 test-200 \
        test-201 test-202 test-203 test-204 test-205 test-206 test-207 test-208 test-209 test-210 \
@@ -45,42 +63,67 @@ TEST_SOURCES = \
        test-261 test-262 test-263 test-264 test-265 test-266 test-267 test-268 test-269 test-270 \
        test-271 test-272 test-273 test-274 test-275 test-276 test-277 test-278 test-279 test-280 \
        test-281 test-282 test-283 test-284 test-285 test-286 test-287 test-288 test-289 test-290 \
-       test-291 \
+       test-291 test-292 test-293          test-295 test-296 test-297 test-298 test-299 test-300 \
+       test-301 test-302 test-303                                              test-309 test-310 \
+       test-311 test-312 test-313 test-314 test-315 test-316 test-317 \
        cls-test-0 cls-test-1 cls-test-2 cls-test-3 cls-test-5 cls-test-6 cls-test-7 cls-test-10  \
        cls-test-11 cls-test-14 cls-test-15 cls-test-16 \
-       mtest-1-dll mtest-1-exe
-
-GENERIC_SOURCES = \
-       gen-1   gen-2   gen-3   gen-4   gen-5   gen-6   gen-7   gen-8   gen-9   gen-10 \
-       gen-11  gen-12          gen-14  gen-15  gen-16          gen-18  gen-19  gen-20 \
-       gen-21  gen-22  gen-23  gen-24  gen-25  gen-26  gen-27  gen-28  gen-29  gen-30 \
-               gen-32  gen-33  gen-34  gen-35  gen-36  gen-37  gen-38  gen-39  gen-40 \
-       gen-41  gen-42  gen-43  gen-44  gen-45  gen-46          gen-48  gen-49  gen-50 \
-       gen-51  gen-52  gen-53  gen-54  gen-55  gen-56          gen-58  gen-59  gen-60 \
-               gen-62  gen-63  gen-64  gen-65  gen-66  gen-67  gen-68  gen-69  gen-70 \
-       gen-71  gen-72  gen-73  gen-74  gen-75  gen-76
-
-GENERIC_MULTI_SOURCES = \
-       gen-13  gen-17  gen-47
-
-#
-# C# 2.0 tests 
-#
-TEST2_SOURCES = \
-       2test-1 2test-2 2test-3 2test-4 2test-5 2test-6 2test-7 2test-8 2test-9 2test-10 \
-       2test-11 2test-12 2test-13 2test-14
-
-UNSAFE_SOURCES = \
-       unsafe-1 unsafe-2 unsafe-3 test-58 test-171 unsafe-5 unsafe-6 unsafe-7 unsafe-8 unsafe-9 unsafe-10
-
-WINDOWS_SOURCES = \
-       test-50 test-67
-
+       2test-1  2test-2  2test-3  2test-4  2test-5  2test-6  2test-7  2test-8  2test-9  2test-10 \
+       2test-11 2test-12 2test-13 2test-14 \
+       unsafe-1 unsafe-2 unsafe-3 unsafe-5 unsafe-6 unsafe-7 unsafe-8 unsafe-9 unsafe-10 \
+       mtest-1-dll mtest-1-exe \
+       mtest-2-dll mtest-2-exe \
+       mtest-3-dll mtest-3-exe \
+       mtest-4-dll mtest-4-exe \
+       conv-dll conv-exe \
+       vararg-dll vararg-exe \
+       module-1 module-2 module-3 \
+       a-call          a-capture5    a-instance        a-parameter2                    \
+       a-capture10     a-capture6    a-nested-anon2                                    \
+       a-capture1      a-capture7    a-nested-anon3                                    \
+       a-capture2      a-capture8    a-nested-anon4                                    \
+       a-capture3      a-capture9    a-nested-anon     a-simple2                       \
+       a-capture4      a-event       a-nested          a-simple
+
+TEST_EXCLUDES_common = 
+
+TEST_SOURCES_default = $(NEW_TEST_SOURCES_common)
+
+TEST_SOURCES_net_2_0 = \
+       gen-13-dll gen-13-exe gen-17-dll gen-17-exe gen-31-dll gen-31-exe               \
+       gen-47-dll gen-47-exe gen-98-dll gen-98-exe                                     \
+       gen-1   gen-2   gen-3   gen-4   gen-5   gen-6   gen-7   gen-8   gen-9   gen-10  \
+       gen-11  gen-12          gen-14  gen-15  gen-16          gen-18  gen-19  gen-20  \
+       gen-21  gen-22  gen-23  gen-24  gen-25  gen-26  gen-27  gen-28  gen-29  gen-30  \
+               gen-32  gen-33  gen-34  gen-35  gen-36  gen-37  gen-38  gen-39  gen-40  \
+       gen-41  gen-42  gen-43  gen-44  gen-45  gen-46          gen-48  gen-49  gen-50  \
+       gen-51  gen-52  gen-53  gen-54  gen-55  gen-56          gen-58  gen-59  gen-60  \
+       gen-61  gen-62  gen-63  gen-64          gen-66  gen-67  gen-68  gen-69  gen-70  \
+       gen-71  gen-72  gen-73  gen-74  gen-75  gen-76  gen-77  gen-78  gen-79  gen-80  \
+       gen-81  gen-82  gen-83  gen-84  gen-85  gen-86  gen-87  gen-88  gen-89  gen-90  \
+       gen-91  gen-92  gen-93  gen-94  gen-95  gen-96  gen-97                  gen-100 \
+       gen-101 gen-102 gen-103 gen-104
+
+TEST_EXCLUDES_net_2_0 =
+
+TEST_SOURCES = $(filter-out $(TEST_EXCLUDES_common) $(TEST_EXCLUDES_$(PROFILE)) $(TEST_EXCLUDES_$(PLATFORM)), \
+       $(TEST_SOURCES_common) $(TEST_SOURCES_$(PROFILE)) $(TEST_SOURCES_$(PLATFORM)))
+
+# These tests load User32.dll and/or Kernel32.dll
+TEST_SOURCES_win32 = test-50 test-67
+
+## FIXME: Need to audit.  Maybe move to 'TEST_EXCLUDES_linux' and 'TEST_EXCLUDES_win32' as approprate
 # A test is a 'no pass' if it fails on either windows or linux
 # Test 120 does not pass because the MS.NET runtime is buggy.
 
-TEST_NOPASS = \
-       test-28  test-45  test-53  test-91  test-102 test-106 test-107 test-120 test-122 test-132 test-133 test-66 test-177
+TEST_NOPASS = test-120 test-132 test-133 a-parameter4.cs 
+#      test-28 test-45 test-53 test-91 test-102 test-106 test-107 test-122 test-66 test-177
+
+# The test harness supports running the testcases in parallel.  However, we still need to
+# provide test-ordering rules to support multi-file testcases.  By default, any test named
+# 'foo-exe' requires that a test named 'foo-dll' be present, and they're run in the order: foo-dll, foo-exe
+# Additional test-orderings can be listed below.  Note that x:y says that 'x' should be run _after_ y
+TEST_ORDERING = module-2:module-1 module-3:module-1 module-3:module-2
 
 all-local install-local uninstall-local:
 
@@ -112,140 +155,57 @@ test-casts: boot-casts.out mcs-casts.out
 
 test-local: 
 
-run-test-local: test-compiler-jit test-unsafe-compiler-jit test-casts test-2
+run-test-local: multi test-harness test-casts
+
+test-everything:
+       $(MAKE) PROFILE=default run-test
+       $(MAKE) PROFILE=net_2_0 run-test
+
+test-generics:
+       $(MAKE) PROFILE=net_2_0 run-test
 
-test-everything: run-test-local test-generic test-generic-2 test-generic-3
+test-generics-2:
+       $(MAKE) PROFILE=net_2_0 TEST_SOURCES="$(TEST_SOURCES_net_2_0)" test-harness
 
 clean-local:
-       rm -f *.exe *.netmodule *.out *.pdb casts.cs
+       -rm -fr dir-*
+       -rm -f *.exe *.netmodule *.out *.pdb casts.cs
 
 dist-local: dist-default
        rm -f $(distdir)/casts.cs
 
-test-compiler-jit: multi test-compiler-jit-real
-
+ifeq (net_2_0, $(PROFILE))
+TEST_TAG = gmcs
+else
 TEST_TAG = mcs
-
-test-compiler-jit-real:
-       @rm -f *.exe *.dll $(TEST_TAG).log $(TEST_TAG)-*.log ; \
-       logfile="$(TEST_TAG).log" ; \
-       echo 'Running $(TEST_TAG) tests with flags "$(TEST_RUNTIME)" ... ' ; \
-       for i in $(TEST_SOURCES) ; do \
-           options=`sed -n 's,^// Compiler options:,,p' $$i.cs`; \
-           testlogfile="$(TEST_TAG)-$$i.log" ; \
-           echo -n "$$i: "; \
-           echo "*** $(MONO_PATH) $(INTERNAL_MCS) $$options $$i.cs" > $$testlogfile ; \
-           if $(INTERNAL_MCS) $$options $$i.cs >> $$testlogfile 2>&1 ; then \
-               : ; \
-           else \
-               echo "Exit code: $$?" >> $$testlogfile ; \
-               failed="$$failed $$i" ; \
-               echo "FAIL: $$i: compilation" >> $$logfile ; \
-               echo FAILED COMPILATION ; cat $$testlogfile ; \
-           fi ; \
-           if test -f $$i.exe; then \
-               echo "*** $(TEST_RUNTIME) ./$$i.exe" >> $$testlogfile ; \
-               if $(TEST_RUNTIME) ./$$i.exe >> $$testlogfile 2>&1 ; then \
-                   echo "PASS: $$i" >> $$logfile ; \
-                   echo OK ; rm -f $$testlogfile ; \
-               else \
-                   echo "Exit code: $$?" >> $$testlogfile ; \
-                   failed="$$failed $$i" ; \
-                   echo "FAIL: $$i" >> $$logfile ; \
-                   echo FAILED ; cat $$testlogfile ; \
-               fi ; \
-           else \
-               echo "PASS: $$i: compilation" >> $$logfile ; \
-               echo OK ; rm -f $$testlogfile ; \
-           fi ; \
-       done ; \
-       if test -z "$$failed"; then :; else echo "Failing tests: $$failed"; exit 1; fi
-
-test-compiler-jit-multi:
-       @rm -f *.exe *.dll $(TEST_TAG).log $(TEST_TAG)-*.log ; \
-       logfile="$(TEST_TAG).log" ; \
-       echo 'Running $(TEST_TAG) tests with flags "$(TEST_RUNTIME)" ... ' ; \
-       for i in $(TEST_SOURCES) ; do \
-           options=`sed -n 's,^// Compiler options:,,p' $$i-dll.cs`; \
-           testlogfile="$(TEST_TAG)-$$i-dll.log" ; \
-           echo -n "$$i: "; \
-           echo "*** $(MONO_PATH) $(INTERNAL_MCS) $$options /target:library $$i-dll.cs" > $$testlogfile ; \
-           if $(INTERNAL_MCS) $$options /target:library $$i-dll.cs >> $$testlogfile 2>&1 ; then \
-               : ; \
-           else \
-               echo "Exit code: $$?" >> $$testlogfile ; \
-               failed="$$failed $$i" ; \
-               echo "FAIL: $$i: compilation" >> $$logfile ; \
-               echo FAILED COMPILATION ; cat $$testlogfile ; \
-           fi ; \
-           if test -f $$i-dll.dll; then \
-               options=`sed -n 's,^// Compiler options:,,p' $$i-exe.cs`; \
-               testlogfile="$(TEST_TAG)-$$i-exe.log" ; \
-               echo "*** $(MONO_PATH) $(INTERNAL_MCS) $$options /r:$$i-dll.dll $$i-exe.cs" > $$testlogfile ; \
-               if $(INTERNAL_MCS) $$options /r:$$i-dll.dll $$i-exe.cs >> $$testlogfile 2>&1 ; then \
-                   : ; \
-               else \
-                   echo "Exit code: $$?" >> $$testlogfile ; \
-                   failed="$$failed $$i" ; \
-                   echo "FAIL: $$i: compilation" >> $$logfile ; \
-                   echo FAILED COMPILATION ; cat $$testlogfile ; \
-               fi ; \
-           fi ; \
-           if test -f $$i-exe.exe; then \
-               echo "*** $(TEST_RUNTIME) ./$$i-exe.exe" >> $$testlogfile ; \
-               if $(TEST_RUNTIME) ./$$i-exe.exe >> $$testlogfile 2>&1 ; then \
-                   echo "PASS: $$i" >> $$logfile ; \
-                   echo OK ; rm -f $$testlogfile ; \
-               else \
-                   echo "Exit code: $$?" >> $$testlogfile ; \
-                   failed="$$failed $$i" ; \
-                   echo "FAIL: $$i" >> $$logfile ; \
-                   echo FAILED ; cat $$testlogfile ; \
-               fi ; \
-           fi ; \
-       done ; \
+endif
+
+.PHONY: test-harness test-harness-run
+test-harness:
+       @$(MAKE) -s test-harness-run
+
+exe_tests := $(filter %-exe, $(TEST_SOURCES))
+
+test-harness-run:
+       @-rm -f $(TEST_TAG).log
+       @-rm -fr dir-$(TEST_TAG)
+       @mkdir dir-$(TEST_TAG)
+       @sed 's,@thisdir@,$(thisdir)/dir-$(TEST_TAG),' harness.mk > dir-$(TEST_TAG)/Makefile
+       @test -z "$(exe_tests)" || for i in ''$(exe_tests); do echo $$i | sed 's,\(.*\)-exe$$,\1-exe.res: \1-dll.res,' >> dir-$(TEST_TAG)/Makefile; done
+       @test -z "$(TEST_ORDERING)" || for i in ''$(TEST_ORDERING); do echo $$i.res | sed 's,:,.res: ,' >> dir-$(TEST_TAG)/Makefile; done
+       @echo 'Running $(TEST_TAG) tests with flags "$(TEST_RUNTIME)" ... '
+       @cd dir-$(TEST_TAG) ; \
+       $(MAKE) -s $(TEST_SOURCES:=.res) || failed="make " ; \
+       cat $(TEST_SOURCES:=.res) > ../$(TEST_TAG).log ; \
+       failed=$$failed`sed -n 's,^FAIL: ,,p' ../$(TEST_TAG).log` ; \
        if test -z "$$failed"; then :; else echo "Failing tests: $$failed"; exit 1; fi
 
-GENERIC_KNOWN_FAILURES = test-55 test-289
-
-# 
-# Tests the generics compiler, and excludes GENERIC_KNOWN_FAILURES from the build
-#
-test-generic: test-generic-1 test-generic-2 test-generic-3 test-generic-4
-
-test-generic-1:
-       sources=`echo $(TEST_SOURCES) | tr ' ' '\n' | grep -v $(GENERIC_KNOWN_FAILURES)| tr '\n' ' ' `;  \
-       make MONO_PATH="../class/lib/net_2_0$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH" TEST_RUNTIME="MONO_PATH=$$MONO_PATH $(RUNTIME) --debug" INTERNAL_MCS="mono ../gmcs/gmcs.exe" test-compiler-jit-real TEST_SOURCES="$$sources" TEST_TAG=gmcs
-
-test-generic-2:
-       make MONO_PATH="../class/lib/net_2_0$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH" TEST_RUNTIME="MONO_PATH=$$MONO_PATH $(RUNTIME) --debug" INTERNAL_MCS="mono ../gmcs/gmcs.exe" test-compiler-jit-real TEST_SOURCES="$(TEST2_SOURCES)" TEST_TAG=gmcs-v2
-
-test-generic-3:
-       make MONO_PATH="../class/lib/net_2_0$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH" TEST_RUNTIME="MONO_PATH=$$MONO_PATH $(RUNTIME) --debug" INTERNAL_MCS="mono ../gmcs/gmcs.exe" test-compiler-jit-real TEST_SOURCES="$(GENERIC_SOURCES)" TEST_TAG=gmcs-v3
-
-test-generic-4:
-       make MONO_PATH="../class/lib/net_2_0$(PLATFORM_PATH_SEPARATOR)$$MONO_PATH" TEST_RUNTIME="MONO_PATH=$$MONO_PATH $(RUNTIME) --debug" INTERNAL_MCS="mono ../gmcs/gmcs.exe" test-compiler-jit-multi TEST_SOURCES="$(GENERIC_MULTI_SOURCES)" TEST_TAG=gmcs-v4
-
-#
-# Tests the 2.0 features
-#
-test-2:
-       make INTERNAL_MCS="mono ../mcs/mcs.exe /langversion:default" test-compiler-jit-real TEST_SOURCES="$(TEST2_SOURCES)" TEST_TAG=mcs-v2
-
-test-unsafe-compiler-jit:
-       make INTERNAL_MCS="$(INTERNAL_MCS) /unsafe" test-compiler-jit-real TEST_SOURCES="$(UNSAFE_SOURCES)" TEST_TAG=mcs-unsafe
-
 #
 # Tests that require separate compilation
 #
-multi: multi-1 multi-2 multi-3 multi-5 multi-6 ilasm
+multi: multi-2 ilasm
        echo Multi-assembly test passes
 
-multi-1:
-       $(INTERNAL_MCS) -target:library dll-1.cs
-       $(INTERNAL_MCS) -r:dll-1.dll prog-1.cs /out:prog-1.exe
-       $(TEST_RUNTIME) prog-1.exe
-
 #
 # Tests that the order for internal/public in external 
 # assemblies does not affect the outcome of a build.
@@ -253,37 +213,12 @@ multi-1:
 # in a library. (eg, that it is not confused by two Main methods)
 #
 multi-2:
-       $(INTERNAL_MCS) -target:library pi.cs
-       $(INTERNAL_MCS) -target:library pp.cs
-       $(INTERNAL_MCS) pu.cs -r:pi.dll -r:pp.dll
-       $(INTERNAL_MCS) pu.cs -r:pp.dll -r:pi.dll
-
-multi-3:
-       $(INTERNAL_MCS) -target:library conv-lib.cs
-       $(INTERNAL_MCS) -r:conv-lib.dll conv-main.cs
-       $(TEST_RUNTIME) conv-main.exe
-
-multi-4:
-       $(INTERNAL_MCS) -target:module module-1.cs
-       $(INTERNAL_MCS) -target:module module-2.cs
-       $(INTERNAL_MCS) /addmodule:module-1.netmodule /addmodule:module-2.netmodule module-3.cs
-       $(TEST_RUNTIME) module-3.exe
-
-multi-5:
-       $(INTERNAL_MCS) -target:library dll-2.cs
-       $(INTERNAL_MCS) -r:dll-2.dll prog-2.cs /out:prog-2.exe
-       $(TEST_RUNTIME) prog-2.exe
-
-multi-6:
-       $(INTERNAL_MCS) -target:library ns0.cs
-       $(INTERNAL_MCS) ns.cs -r:ns0.dll
-
-multi-7:
-       $(INTERNAL_MCS) -target:library vararg-lib.cs
-       $(INTERNAL_MCS) vararg-exe.cs -r:vararg-lib.dll
-       $(TEST_RUNTIME) vararg-exe.exe
+       $(CSCOMPILE) -target:library pi.cs
+       $(CSCOMPILE) -target:library pp.cs
+       $(CSCOMPILE) pu.cs -r:pi.dll -r:pp.dll
+       $(CSCOMPILE) pu.cs -r:pp.dll -r:pi.dll
 
 ilasm:
        $(INTERNAL_ILASM) /dll property-il.il
-       $(INTERNAL_MCS) /r:property-il.dll property-main.cs /out:property-main.exe
+       $(CSCOMPILE) /r:property-il.dll property-main.cs /out:property-main.exe
        $(TEST_RUNTIME) property-main.exe