You can not select more than 25 topics Topics must start with a chinese character,a letter or number, can include dashes ('-') and can be up to 35 characters long.

JavaTest.java 7.3 kB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217
  1. /*
  2. * The Apache Software License, Version 1.1
  3. *
  4. * Copyright (c) 2001-2002 The Apache Software Foundation. All rights
  5. * reserved.
  6. *
  7. * Redistribution and use in source and binary forms, with or without
  8. * modification, are permitted provided that the following conditions
  9. * are met:
  10. *
  11. * 1. Redistributions of source code must retain the above copyright
  12. * notice, this list of conditions and the following disclaimer.
  13. *
  14. * 2. Redistributions in binary form must reproduce the above copyright
  15. * notice, this list of conditions and the following disclaimer in
  16. * the documentation and/or other materials provided with the
  17. * distribution.
  18. *
  19. * 3. The end-user documentation included with the redistribution, if
  20. * any, must include the following acknowlegement:
  21. * "This product includes software developed by the
  22. * Apache Software Foundation (http://www.apache.org/)."
  23. * Alternately, this acknowlegement may appear in the software itself,
  24. * if and wherever such third-party acknowlegements normally appear.
  25. *
  26. * 4. The names "The Jakarta Project", "Ant", and "Apache Software
  27. * Foundation" must not be used to endorse or promote products derived
  28. * from this software without prior written permission. For written
  29. * permission, please contact apache@apache.org.
  30. *
  31. * 5. Products derived from this software may not be called "Apache"
  32. * nor may "Apache" appear in their names without prior written
  33. * permission of the Apache Group.
  34. *
  35. * THIS SOFTWARE IS PROVIDED ``AS IS'' AND ANY EXPRESSED OR IMPLIED
  36. * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
  37. * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
  38. * DISCLAIMED. IN NO EVENT SHALL THE APACHE SOFTWARE FOUNDATION OR
  39. * ITS CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
  40. * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT
  41. * LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF
  42. * USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
  43. * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY,
  44. * OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT
  45. * OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
  46. * SUCH DAMAGE.
  47. * ====================================================================
  48. *
  49. * This software consists of voluntary contributions made by many
  50. * individuals on behalf of the Apache Software Foundation. For more
  51. * information on the Apache Software Foundation, please see
  52. * <http://www.apache.org/>.
  53. */
  54. package org.apache.tools.ant.taskdefs;
  55. import junit.framework.*;
  56. import java.io.*;
  57. import org.apache.tools.ant.*;
  58. /**
  59. * stress out java task
  60. * @author steve loughran
  61. * @author <a href="mailto:sbailliez@apache.org>Stephane Bailliez</a>
  62. */
  63. public class JavaTest extends BuildFileTest {
  64. private boolean runFatalTests=false;
  65. public JavaTest(String name) {
  66. super(name);
  67. }
  68. /**
  69. * configure the project.
  70. * if the property junit.run.fatal.tests is set we run
  71. * the fatal tests
  72. */
  73. public void setUp() {
  74. configureProject("src/etc/testcases/taskdefs/java.xml");
  75. //final String propname="tests-classpath.value";
  76. //String testClasspath=System.getProperty(propname);
  77. //System.out.println("Test cp="+testClasspath);
  78. String propname="tests-classpath.value";
  79. String runFatal=System.getProperty("junit.run.fatal.tests");
  80. if(runFatal!=null)
  81. runFatalTests=true;
  82. }
  83. public void tearDown() {
  84. }
  85. public void testNoJarNoClassname(){
  86. expectBuildExceptionContaining("testNoJarNoClassname",
  87. "parameter validation",
  88. "Classname must not be null.");
  89. }
  90. public void testJarNoFork() {
  91. expectBuildExceptionContaining("testJarNoFork",
  92. "parameter validation",
  93. "Cannot execute a jar in non-forked mode. Please set fork='true'. ");
  94. }
  95. public void testJarAndClassName() {
  96. expectBuildException("testJarAndClassName",
  97. "Should not be able to set both classname AND jar");
  98. }
  99. public void testClassnameAndJar() {
  100. expectBuildException("testClassnameAndJar",
  101. "Should not be able to set both classname AND jar");
  102. }
  103. public void testRun() {
  104. executeTarget("testRun");
  105. }
  106. /** this test fails but we ignore the return value;
  107. * we verify that failure only matters when failonerror is set
  108. */
  109. public void testRunFail() {
  110. if(runFatalTests) {
  111. executeTarget("testRunFail");
  112. }
  113. }
  114. public void testRunFailFoe() {
  115. if(runFatalTests) {
  116. expectBuildExceptionContaining("testRunFailFoe",
  117. "java failures being propagated",
  118. "Java returned:");
  119. }
  120. }
  121. public void testRunFailFoeFork() {
  122. expectBuildExceptionContaining("testRunFailFoeFork",
  123. "java failures being propagated",
  124. "Java returned:");
  125. }
  126. public void testExcepting() {
  127. expectLogContaining("testExcepting",
  128. "Exception raised inside called program");
  129. }
  130. public void testExceptingFork() {
  131. expectLogContaining("testExceptingFork",
  132. "Java Result:");
  133. }
  134. public void testExceptingFoe() {
  135. expectBuildExceptionContaining("testExceptingFoe",
  136. "passes exception through",
  137. "Exception raised inside called program");
  138. }
  139. public void testExceptingFoeFork() {
  140. expectBuildExceptionContaining("testExceptingFoeFork",
  141. "exceptions turned into error codes",
  142. "Java returned:");
  143. }
  144. /**
  145. * entry point class with no dependencies other
  146. * than normal JRE runtime
  147. */
  148. public static class EntryPoint {
  149. /**
  150. * this entry point is used by the java.xml tests to
  151. * generate failure strings to handle
  152. * argv[0] = exit code (optional)
  153. * argv[1] = string to print to System.out (optional)
  154. * argv[1] = string to print to System.err (optional)
  155. */
  156. public static void main(String[] argv) {
  157. int exitCode=0;
  158. if(argv.length>0) {
  159. try {
  160. exitCode=Integer.parseInt(argv[0]);
  161. } catch(NumberFormatException nfe) {
  162. exitCode=-1;
  163. }
  164. }
  165. if(argv.length>1) {
  166. System.out.println(argv[1]);
  167. }
  168. if(argv.length>2) {
  169. System.err.println(argv[2]);
  170. }
  171. if(exitCode!=0) {
  172. System.exit(exitCode);
  173. }
  174. }
  175. }
  176. /**
  177. * entry point class with no dependencies other
  178. * than normal JRE runtime
  179. */
  180. public static class ExceptingEntryPoint {
  181. /**
  182. * throw a run time exception which does not need
  183. * to be in the signature of the entry point
  184. */
  185. public static void main(String[] argv) {
  186. throw new NullPointerException("Exception raised inside called program");
  187. }
  188. }
  189. }