// Module : $RCSfile: ReplayReaderTest.java,v $ // Version : $Revision: 0.0 $ $Author: Patrick $ $Date: 26.11.2011 15:10:08 $ // Project : TaskTreePerformanceTest // Creation : 2011 by Patrick // Copyright : Patrick Harms, 2011 package de.ugoe.cs.quest.plugin.mfc; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertNotNull; import static org.junit.Assert.assertNotSame; import static org.junit.Assert.assertTrue; import java.io.File; import java.io.FileInputStream; import java.io.FileOutputStream; import java.io.InputStreamReader; import java.io.PrintStream; import java.util.Collection; import java.util.List; import org.junit.After; import org.junit.Before; import org.junit.Test; import de.ugoe.cs.quest.ReplayGenerator; import de.ugoe.cs.quest.eventcore.Event; import de.ugoe.cs.quest.eventcore.guimodel.GUIModel; import de.ugoe.cs.util.console.Console; import de.ugoe.cs.util.console.listener.IOutputListener; /** * TODO comment * * @version $Revision: $ $Date: $ * @author 2011, last modified by $Author: $ */ public class MFCLogParserTest implements IOutputListener { /** */ private File tmpFile; /** */ private PrintStream outputStream; /** * */ @Before public void setUp() throws Exception { outputStream = new PrintStream(new FileOutputStream("blub.log")); Console.getInstance().registerOutputListener(this); tmpFile = new File("tmp.xml"); if (tmpFile.exists()) { assertTrue(tmpFile.delete()); } } /** * */ @After public void tearDown() throws Exception { if (!System.out.equals(outputStream) && !System.err.equals(outputStream)) { outputStream.close(); } if (tmpFile.exists()) { assertTrue(tmpFile.delete()); } } /** * */ @Test public void testTrace() throws Exception { File traceFile = new File(ClassLoader.getSystemResource("trace.txt").getFile()); new LogPreprocessor().convertToXml(traceFile.getAbsolutePath(), tmpFile.getAbsolutePath()); MFCLogParser parser = new MFCLogParser(); parser.parseFile(tmpFile); Collection> events = parser.getSequences(); assertNotNull(events); assertTrue(events.size() > 0); System.err.println("{"); for (List session : events) { System.err.println(" {"); for (Event event : session) { System.err.print(" "); System.err.print(event); System.err.println(","); } System.err.println(" }"); } System.err.println("}"); System.err.println("\n\n"); GUIModel guiModel = parser.getGuiModel(); assertNotNull(guiModel); assertNotSame(0, guiModel.getRootElements().size()); guiModel.dump(System.err); } /** * */ @Test public void testLogfile() throws Exception { File logFile = new File(ClassLoader.getSystemResource("log.xml").getFile()); MFCLogParser parser = new MFCLogParser(); parser.parseFile(logFile); Collection> events = parser.getSequences(); assertNotNull(events); assertTrue(events.size() > 0); System.err.println("{"); for (List session : events) { System.err.println(" {"); for (Event event : session) { System.err.print(" "); System.err.print(event); System.err.println(","); } System.err.println(" }"); } System.err.println("}"); System.err.println("\n\n"); GUIModel guiModel = parser.getGuiModel(); assertNotNull(guiModel); guiModel.dump(System.err); ReplayGenerator generator = new ReplayGenerator(); generator.createLogfileMultipleSessions(parser.getSequences(), tmpFile.getAbsolutePath()); InputStreamReader reader1 = new InputStreamReader(ClassLoader.getSystemResourceAsStream("replay.xml"), "UTF-8"); InputStreamReader reader2 = new InputStreamReader(new FileInputStream(tmpFile), "UTF-8"); try { int sign1; do { sign1 = reader1.read(); assertEquals(sign1, reader2.read()); } while (sign1 > -1); } finally { reader1.close(); reader2.close(); } } /* (non-Javadoc) * @see de.ugoe.cs.util.console.listener.IOutputListener#outputMsg(java.lang.String) */ @Override public void outputMsg(String newMessage) { outputStream.println(newMessage); } }