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 13KB

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