diff options
author | wisberg <wisberg> | 2003-07-26 04:13:54 +0000 |
---|---|---|
committer | wisberg <wisberg> | 2003-07-26 04:13:54 +0000 |
commit | 2502ee5106921a6947e3470d08e30a0734a4d805 (patch) | |
tree | bc205a7f6f73c3ed80baf519e897b711f7e23021 /taskdefs/testsrc/org | |
parent | e49c9eb667399bea490f88462b5e880fb2028539 (diff) | |
download | aspectj-2502ee5106921a6947e3470d08e30a0734a4d805.tar.gz aspectj-2502ee5106921a6947e3470d08e30a0734a4d805.zip |
Fixes and tests for bugs 39842 and 40807
Diffstat (limited to 'taskdefs/testsrc/org')
-rw-r--r-- | taskdefs/testsrc/org/aspectj/tools/ant/taskdefs/AjcTaskTest.java | 104 |
1 files changed, 102 insertions, 2 deletions
diff --git a/taskdefs/testsrc/org/aspectj/tools/ant/taskdefs/AjcTaskTest.java b/taskdefs/testsrc/org/aspectj/tools/ant/taskdefs/AjcTaskTest.java index 15ab567e1..f7936d1e9 100644 --- a/taskdefs/testsrc/org/aspectj/tools/ant/taskdefs/AjcTaskTest.java +++ b/taskdefs/testsrc/org/aspectj/tools/ant/taskdefs/AjcTaskTest.java @@ -133,6 +133,59 @@ public class AjcTaskTest extends TestCase { MESSAGES.setLength(0); } + public void testNullDestDir() { + AjcTask task = getTask(NOFILE, null); + String[] cmd = task.makeCommand(); + + for (int i = 0; i < cmd.length; i++) { + assertTrue(!"-d".equals(cmd[i])); + } + } + + public void testOutputRequirement() { + AjcTask task = getTask("default.lst"); + checkRun(task, null); + + task = getTask("default.lst", null); + task.setCopyInjars(true); + checkRun(task, "copyInjars"); + + task = getTask("default.lst", null); + task.setSourceRootCopyFilter("*.java"); + checkRun(task, "sourceRoot"); + } + + private void checkRun(AjcTask task, String exceptionString) { + try { + task.execute(); + assertTrue(null == exceptionString); + } catch (BuildException e) { + if(-1 == e.getMessage().indexOf(exceptionString)) { + assertEquals(exceptionString, e.getMessage()); + } + } + + } + + public void testCommandEditor() { + String className = VerboseCommandEditor.class.getName(); + System.setProperty(AjcTask.COMMAND_EDITOR_NAME, className); + assertEquals(className, + System.getProperty(AjcTask.COMMAND_EDITOR_NAME)); + AjcTask task = getTask(NOFILE); + task.setCommandEditor(new VerboseCommandEditor()); + String[] cmd = task.makeCommand(); + assertEquals(VerboseCommandEditor.VERBOSE, cmd[0]); + + task = getTask(NOFILE); + task.setCommandEditorClass(VerboseCommandEditor.class.getName()); + cmd = task.makeCommand(); + assertEquals(VerboseCommandEditor.VERBOSE, cmd[0]); + } +// public void testStaticCommandEditor() { +// // XXX need to test COMMAND_EDITOR, but can't require property when run +// } + public void testLimitTo() { int numArgs = 100; String arg = "123456789"; @@ -191,10 +244,16 @@ public class AjcTaskTest extends TestCase { } protected AjcTask getTask(String input) { + return getTask(input, getTempDir()); + } + + protected AjcTask getTask(String input, File destDir) { AjcTask task = new AjcTask(); Project p = new Project(); task.setProject(p); - task.setDestdir(getTempDir()); + if (null != destDir) { + task.setDestdir(destDir); + } if (NOFILE.equals(input)) { // add nothing } else if (input.endsWith(".lst")) { @@ -218,7 +277,7 @@ public class AjcTaskTest extends TestCase { } } task.setClasspath(new Path(p, "../lib/test/aspectjrt.jar")); - task.setVerbose(true); // XXX + //task.setVerbose(true); return task; } @@ -498,3 +557,44 @@ public class AjcTaskTest extends TestCase { } } } + +class VerboseCommandEditor implements ICommandEditor { + public static final String VERBOSE = "-verbose"; + public String[] editCommand(String[] command) { + for (int i = 0; i < command.length; i++) { + if (VERBOSE.equals(command[i])) { + return command; + } + } + + String[] result = new String[1+command.length]; + result[0] = VERBOSE; + System.arraycopy(result, 1, command, 0, command.length); + return result; + } +} + +class AppendingCommandEditor implements ICommandEditor { + private static String[] NONE = new String[0]; + public static ICommandEditor VERBOSE = + new AppendingCommandEditor(new String[] {"-verbose"}, NONE); + public static ICommandEditor INVALID = + new AppendingCommandEditor(NONE, new String[] {"-invalidOption"}); + + final String[] prefix; + final String[] suffix; + + public AppendingCommandEditor(String[] prefix, String[] suffix) { + this.prefix = prefix; + this.suffix = suffix; + } + + public String[] editCommand(String[] command) { + int len = command.length + prefix.length + suffix.length; + String[] result = new String[len]; + System.arraycopy(result, 0, prefix, 0, prefix.length); + System.arraycopy(result, prefix.length, command, 0, command.length); + System.arraycopy(result, prefix.length + command.length, suffix, 0, suffix.length); + return result; + } +} |