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

AjBuildManagerTest.java 12KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351
  1. /* *******************************************************************
  2. * Copyright (c) 2002 Palo Alto Research Center, Incorporated (PARC).
  3. * All rights reserved.
  4. * This program and the accompanying materials are made available
  5. * under the terms of the Eclipse Public License v1.0
  6. * which accompanies this distribution and is available at
  7. * http://www.eclipse.org/legal/epl-v10.html
  8. *
  9. * Contributors:
  10. * PARC initial implementation
  11. * ******************************************************************/
  12. package org.aspectj.ajdt.internal.core.builder;
  13. import java.io.File;
  14. import java.io.IOException;
  15. import java.io.PrintWriter;
  16. import org.aspectj.ajdt.StreamPrintWriter;
  17. import org.aspectj.ajdt.ajc.BuildArgParser;
  18. import org.aspectj.ajdt.ajc.Constants;
  19. import org.aspectj.bridge.IMessage;
  20. import org.aspectj.bridge.MessageHandler;
  21. import org.aspectj.bridge.MessageWriter;
  22. import org.aspectj.testing.util.TestUtil;
  23. import junit.framework.TestCase;
  24. public class AjBuildManagerTest extends TestCase {
  25. private final StreamPrintWriter outputWriter = new StreamPrintWriter(new PrintWriter(System.out));
  26. private final MessageWriter messageWriter = new MessageWriter(outputWriter, false);
  27. public static File source1 = new File(Constants.TESTDATA_DIR, "src1/A.java");
  28. public static File source2 = new File(Constants.TESTDATA_DIR, "src1/Hello.java");
  29. public static File source3 = new File(Constants.TESTDATA_DIR, "src1/X.java");
  30. /**
  31. * @throws AssertionFailedError unless handler has 0 messages worse than warning, or the one message is a warning about
  32. * aspectjrt.jar
  33. */
  34. public static void assertCompileMessagesValid(MessageHandler handler) {
  35. assertTrue("null handler", null != handler);
  36. final int numMessages = handler.numMessages(IMessage.WARNING, true);
  37. if (1 == numMessages) { // permit aspectjrt.jar warning
  38. IMessage m = handler.getMessages(IMessage.WARNING, true)[0];
  39. if (!(m.isWarning() && (m.getMessage().contains("aspectjrt.jar")))) {
  40. assertTrue(handler.toString(), false);
  41. }
  42. } else if (0 != numMessages) {
  43. assertTrue(handler.toString(), false);
  44. }
  45. }
  46. public AjBuildManagerTest(String name) {
  47. super(name);
  48. }
  49. public void testSimpleStructure() throws IOException {
  50. AjBuildManager manager = new AjBuildManager(messageWriter);
  51. BuildArgParser parser = new BuildArgParser(messageWriter);
  52. String javaClassPath = System.getProperty("java.class.path");
  53. String sandboxName = TestUtil.createEmptySandbox().getAbsolutePath();
  54. AjBuildConfig buildConfig = parser.genBuildConfig(new String[] { "-d", sandboxName, "-1.4", "-classpath", javaClassPath,
  55. Constants.TESTDATA_PATH + "/src1/A.java",
  56. // EajcModuleTests.TESTDATA_PATH + "/src1/Hello.java",
  57. });
  58. String err = parser.getOtherMessages(true);
  59. assertTrue(err, null == err || err.startsWith("incorrect classpath"));
  60. // manager.setStructureModel(AsmManager.getDefault().getHierarchy());
  61. MessageHandler handler = new MessageHandler();
  62. manager.batchBuild(buildConfig, handler);
  63. assertCompileMessagesValid(handler);
  64. }
  65. // XXX add test for resource deltas
  66. //
  67. // public void testUpdateBuildConfig() {
  68. // final File FILE_1 = new File("testdata/testclasses/Temp1.java");
  69. // final File FILE_2 = new File("testdata/testclasses/Temp2.java");
  70. // final File FILE_3 = new File("testdata/testclasses/Temp3.java");
  71. // List files = new ArrayList();
  72. // files.add(FILE_1);
  73. // files.add(FILE_2);
  74. //
  75. // AjBuildManager manager = new AjBuildManager(messageWriter);
  76. // AjBuildConfig buildConfig = new AjBuildConfig();
  77. // manager.buildConfig = buildConfig;
  78. // buildConfig.setFiles(files);
  79. //
  80. // manager.updateBuildConfig(buildConfig);
  81. // assertTrue("no change", manager.deletedFiles.isEmpty());
  82. //
  83. // AjBuildConfig newConfig = new AjBuildConfig();
  84. // newConfig.getFiles().add(FILE_1);
  85. // newConfig.getFiles().add(FILE_2);
  86. // newConfig.getFiles().add(FILE_3);
  87. // manager.updateBuildConfig(newConfig);
  88. // assertTrue("added file", manager.deletedFiles.isEmpty());
  89. // assertTrue(manager.addedFiles.size() == 1);
  90. // assertTrue(manager.addedFiles.contains(FILE_3));
  91. //
  92. // newConfig = new AjBuildConfig();
  93. // newConfig.getFiles().add(FILE_3);
  94. // manager.updateBuildConfig(newConfig);
  95. // assertTrue("deleted 2 files", manager.addedFiles.isEmpty());
  96. // assertTrue(manager.deletedFiles.size() == 2);
  97. // assertTrue(manager.deletedFiles.contains(FILE_1));
  98. //
  99. // newConfig = new AjBuildConfig();
  100. // newConfig.getFiles().add(FILE_2);
  101. // manager.updateBuildConfig(newConfig);
  102. // assertTrue("added file", manager.addedFiles.size() == 1);
  103. // assertTrue("deleted file", manager.deletedFiles.size() == 1);
  104. // assertTrue(manager.deletedFiles.size() == 1);
  105. // assertTrue(manager.addedFiles.contains(FILE_2));
  106. // assertTrue(manager.deletedFiles.contains(FILE_3));
  107. // }
  108. //
  109. // /**
  110. // * Pretends that the files 'have been' modified in the future and waits.
  111. // * Tests:
  112. // * 1) no change,
  113. // * 2) added file,
  114. // * 3) removed file
  115. // *
  116. // * XXX should just test modified
  117. // */
  118. // public void testGetModifiedFiles() throws IOException, InterruptedException {
  119. // final File TEMP_1 = new File("testdata/testclasses/TempChanged.java");
  120. // final File EXISTS_2 = new File("testdata/testclasses/p1/Foo.java");
  121. // final File NEW = new File("testdata/testclasses/TempNew.java");
  122. // NEW.delete();
  123. // touch(TEMP_1, false);
  124. // List files = new ArrayList();
  125. // files.add(TEMP_1);
  126. // files.add(EXISTS_2);
  127. //
  128. // assertTrue("input files", TEMP_1.exists() && EXISTS_2.exists());
  129. // assertTrue("new file", !NEW.exists());
  130. //
  131. // Thread.sleep(100);
  132. // long lastBuildTime = System.currentTimeMillis();
  133. //
  134. // AjBuildManager manager = new AjBuildManager(messageWriter);
  135. // manager.buildConfig = new AjBuildConfig();
  136. // manager.buildConfig.setFiles(files);
  137. // Collection changedFiles = manager.getModifiedFiles(lastBuildTime);
  138. // assertTrue("nothing changed: " + changedFiles, changedFiles.isEmpty());
  139. //
  140. // lastBuildTime = System.currentTimeMillis();
  141. // Thread.sleep(100);
  142. //
  143. // touch(NEW, false);
  144. //
  145. // //NEW.createNewFile();
  146. // files.add(NEW);
  147. // changedFiles = manager.getModifiedFiles(lastBuildTime);
  148. // assertTrue("new file: " + changedFiles, changedFiles.contains(NEW));
  149. //
  150. // lastBuildTime = System.currentTimeMillis();
  151. // Thread.sleep(100);
  152. //
  153. // files.remove(NEW);
  154. // changedFiles = manager.getModifiedFiles(lastBuildTime);
  155. // assertTrue("nothing changed", changedFiles.isEmpty());
  156. //
  157. // lastBuildTime = System.currentTimeMillis();
  158. // Thread.sleep(100);
  159. //
  160. // touch(TEMP_1, true);
  161. // changedFiles = manager.getModifiedFiles(lastBuildTime);
  162. // assertTrue("touched file: " + changedFiles, changedFiles.contains(TEMP_1));
  163. //
  164. // lastBuildTime = System.currentTimeMillis();
  165. // Thread.sleep(100);
  166. //
  167. // files.remove(NEW);
  168. // changedFiles = manager.getModifiedFiles(lastBuildTime);
  169. // assertTrue("nothing changed", changedFiles.isEmpty());
  170. //
  171. // TEMP_1.delete();
  172. // NEW.delete();
  173. // }
  174. // don't do delta's anymore
  175. // public void testMakeDeltas() throws IOException, InterruptedException {
  176. // AjBuildManager manager = new AjBuildManager(messageWriter);
  177. // manager.buildConfig = new AjBuildConfig();
  178. // List sourceRoots = new ArrayList();
  179. // sourceRoots.add(new File("out"));
  180. // manager.buildConfig.setSourceRoots(sourceRoots);
  181. // assertTrue(manager.testInit(messageWriter));
  182. // List modified = Arrays.asList(new File[] { new File("A.java"), new File("B.java") });
  183. // List deleted = Arrays.asList(new File[] { new File("X.java") });
  184. // SimpleLookupTable deltas = new SimpleLookupTable();
  185. // manager.makeDeltas(
  186. // deltas,
  187. // modified,
  188. // deleted,
  189. // ((File)manager.buildConfig.getSourceRoots().get(0)).getPath());
  190. //
  191. // ResourceDelta d = (ResourceDelta)deltas.get(manager.getJavaBuilder().currentProject);
  192. // assertNotNull(d);
  193. //
  194. // assertEquals(d.getAffectedChildren().length, 3);
  195. // //XXX do more testing of children
  196. // }
  197. //
  198. // // XXX should this be working??
  199. // public void testDeleteRealFiles() throws CoreException, IOException {
  200. // AjBuildManager manager = new AjBuildManager(messageWriter);
  201. // manager.buildConfig = new AjBuildConfig();
  202. // List sourceRoots = new ArrayList();
  203. // sourceRoots.add(new File("testdata/src1"));
  204. // manager.buildConfig.setSourceRoots(sourceRoots);
  205. // manager.buildConfig.setOutputDir(new File("out"));
  206. // assertTrue(manager.testInit(messageWriter));
  207. //
  208. // File realClassFile = new File("out/X.class");
  209. // touch(realClassFile, false);
  210. //
  211. // assertTrue(realClassFile.exists());
  212. //
  213. // IFile classfile = manager.classFileCache.getFile(new Path("X.class"));
  214. // classfile.create(FileUtil.getStreamFromZip("testdata/testclasses.jar", "Hello.class"), true, null);
  215. // assertTrue(classfile.exists());
  216. //
  217. // manager.addAspectClassFilesToWeaver();
  218. //
  219. // classfile.delete(true, false, null);
  220. // assertTrue(realClassFile.exists());
  221. //
  222. // manager.addAspectClassFilesToWeaver();
  223. //
  224. // assertTrue(!realClassFile.exists());
  225. //
  226. // }
  227. // !!!
  228. // public void testIncrementalCompilerCall() throws IOException, InterruptedException, CoreException {
  229. // AjBuildManager manager = new AjBuildManager(messageWriter);
  230. //
  231. // manager.buildConfig = new AjBuildConfig();
  232. // List roots = new ArrayList();
  233. // roots.add(new File("testdata/src1"));
  234. // manager.testInit(messageWriter);
  235. // manager.buildConfig.setSourceRoots(roots);
  236. // assertTrue(manager.testInit(messageWriter));
  237. // List modified = Arrays.asList(new File[] { source1, source2 });
  238. // List deleted = Arrays.asList(new File[] { source3 });
  239. // SimpleLookupTable deltas = new SimpleLookupTable();
  240. // manager.makeDeltas(
  241. // deltas,
  242. // modified,
  243. // deleted,
  244. // ((File)manager.buildConfig.getSourceRoots().get(0)).getAbsolutePath());
  245. //
  246. // JavaBuilder jbuilder = manager.getJavaBuilder();
  247. // jbuilder.lastState = new State(jbuilder);
  248. // jbuilder.binaryLocationsPerProject = new SimpleLookupTable();
  249. //
  250. // AjBuildManager.IncrementalBuilder builder
  251. // = manager.getIncrementalBuilder(messageWriter); // XXX trap errors
  252. // TestNotifier testNotifier = new TestNotifier(builder, jbuilder.currentProject);
  253. // jbuilder.notifier = testNotifier;
  254. //
  255. // IContainer[] sourceFolders = new IContainer[] {
  256. // new FilesystemFolder(((File)manager.buildConfig.getSourceRoots().get(0)).getAbsolutePath())
  257. // };
  258. // builder.setSourceFolders(sourceFolders);
  259. // testNotifier.builder = builder;
  260. //
  261. // IFile classfile = manager.classFileCache.getFile(new Path("X.class"));
  262. // classfile.create(new ByteArrayInputStream(new byte[] {1,2,3}), true, null);
  263. //
  264. // assertTrue(classfile.exists());
  265. //
  266. //
  267. // try {
  268. // manager.testSetHandler(messageWriter);
  269. // boolean succeeded = builder.build(deltas);
  270. // } catch (NonLocalExit nle) {
  271. // assertEquals(nle.getExitCode(), 0);
  272. // } finally {
  273. // manager.testSetHandler(null);
  274. // }
  275. //
  276. // assertTrue(!classfile.exists());
  277. // }
  278. //
  279. // static class TestNotifier extends BuildNotifier {
  280. // int state = 0;
  281. // AjBuildManager.IncrementalBuilder builder;
  282. //
  283. // public TestNotifier(AjBuildManager.IncrementalBuilder builder, IProject project) {
  284. // super(null, project);
  285. // this.builder = builder;
  286. // }
  287. //
  288. //
  289. // public void updateProgressDelta(float percentWorked) {
  290. // switch(state) {
  291. // case 0:
  292. // checkInitialConfig();
  293. // break;
  294. // case 1:
  295. // checkBinaryResources();
  296. // break;
  297. // case 2:
  298. // checkAffectedFiles();
  299. // break;
  300. // }
  301. // state += 1;
  302. // }
  303. //
  304. // private void checkBinaryResources() {
  305. // }
  306. //
  307. //
  308. // private void checkInitialConfig() {
  309. // Collection files = builder.getLocations();
  310. // //System.out.println("initial: " + files);
  311. // }
  312. //
  313. // private void checkAffectedFiles() {
  314. // Collection files = builder.getLocations();
  315. // TestUtil.assertSetEquals(Arrays.asList(new String[] {
  316. // source1.getAbsolutePath().replace(File.separatorChar, '/'),
  317. // source2.getAbsolutePath().replace(File.separatorChar, '/') }), files);
  318. // throw new NonLocalExit(0);
  319. // }
  320. // }
  321. // private void touch(File file, boolean isAppend) throws IOException {
  322. // FileOutputStream s = new FileOutputStream(file.getAbsolutePath(), isAppend);
  323. // s.write(new byte[] {1,2,3});
  324. // s.close();
  325. // }
  326. /*
  327. * jar directory source directory container
  328. */
  329. // public void testMakeClasspathLocations() {
  330. // List classpath = new ArrayList();
  331. // classpath.add(
  332. //
  333. // AjBuildConfig config = new AjBuildConfig();
  334. // config.setClasspath()
  335. // }
  336. // private void testClasspathLocation(String loca
  337. }