source: trunk/autoquest-plugin-mfc-test/src/test/java/de/ugoe/cs/autoquest/plugin/mfc/MFCLogParserTest.java @ 1425

Last change on this file since 1425 was 1425, checked in by pharms, 10 years ago
  • removed some TODOs
  • Property svn:executable set to *
  • Property svn:keywords set to Date Revision Author HeadURL Id
File size: 5.7 KB
RevLine 
[927]1//   Copyright 2012 Georg-August-Universität Göttingen, Germany
2//
3//   Licensed under the Apache License, Version 2.0 (the "License");
4//   you may not use this file except in compliance with the License.
5//   You may obtain a copy of the License at
6//
7//       http://www.apache.org/licenses/LICENSE-2.0
8//
9//   Unless required by applicable law or agreed to in writing, software
10//   distributed under the License is distributed on an "AS IS" BASIS,
11//   WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
12//   See the License for the specific language governing permissions and
13//   limitations under the License.
14
[922]15package de.ugoe.cs.autoquest.plugin.mfc;
[622]16
17import static org.junit.Assert.assertEquals;
18import static org.junit.Assert.assertNotNull;
19import static org.junit.Assert.assertNotSame;
20import static org.junit.Assert.assertTrue;
21
22import java.io.File;
23import java.io.FileInputStream;
[649]24import java.io.FileOutputStream;
[622]25import java.io.InputStreamReader;
[649]26import java.io.PrintStream;
[707]27import java.util.ArrayList;
[622]28import java.util.Collection;
29import java.util.List;
30
31import org.junit.After;
32import org.junit.Before;
33import org.junit.Test;
34
[922]35import de.ugoe.cs.autoquest.commands.sequences.CMDgenerateReplayfile;
36import de.ugoe.cs.autoquest.eventcore.Event;
37import de.ugoe.cs.autoquest.eventcore.guimodel.GUIModel;
38import de.ugoe.cs.autoquest.plugin.mfc.LogPreprocessor;
39import de.ugoe.cs.autoquest.plugin.mfc.MFCLogParser;
[649]40import de.ugoe.cs.util.console.Console;
[706]41import de.ugoe.cs.util.console.GlobalDataContainer;
[649]42import de.ugoe.cs.util.console.listener.IOutputListener;
[622]43
44/**
[1425]45 * @author Steffen Herbold
[622]46 */
[649]47public class MFCLogParserTest implements IOutputListener {
[622]48
49    /** */
50    private File tmpFile;
51   
[649]52    /** */
53    private PrintStream outputStream;
54
[622]55    /**
56     *
57     */
58    @Before
59    public void setUp() throws Exception {
[649]60        outputStream = new PrintStream(new FileOutputStream("blub.log"));
61        Console.getInstance().registerOutputListener(this);
62       
[622]63        tmpFile = new File("tmp.xml");
64       
65        if (tmpFile.exists()) {
66            assertTrue(tmpFile.delete());
67        }
68    }
69   
70    /**
71     *
72     */
73    @After
74    public void tearDown() throws Exception {
[649]75        if (!System.out.equals(outputStream) && !System.err.equals(outputStream)) {
76            outputStream.close();
77        }
78       
[622]79        if (tmpFile.exists()) {
80            assertTrue(tmpFile.delete());
81        }
82    }
83   
84   
85    /**
86     *
87     */
88    @Test
89    public void testTrace() throws Exception {
90        File traceFile = new File(ClassLoader.getSystemResource("trace.txt").getFile());
91       
92        new LogPreprocessor().convertToXml(traceFile.getAbsolutePath(),
93                                           tmpFile.getAbsolutePath());
94       
95        MFCLogParser parser = new MFCLogParser();
96        parser.parseFile(tmpFile);
97        Collection<List<Event>> events = parser.getSequences();
98
99        assertNotNull(events);
100        assertTrue(events.size() > 0);
101
102        System.err.println("{");
103        for (List<Event> session : events) {
104            System.err.println("  {");
105            for (Event event : session) {
106                System.err.print("    ");
107                System.err.print(event);
108                System.err.println(",");
109            }
110            System.err.println("  }");
111        }
112        System.err.println("}");
113        System.err.println("\n\n");
114
115        GUIModel guiModel = parser.getGuiModel();
116        assertNotNull(guiModel);
117        assertNotSame(0, guiModel.getRootElements().size());
118
[745]119        guiModel.dump(System.err, "UTF-8");
[622]120    }
121
122    /**
123     *
124     */
125    @Test
126    public void testLogfile() throws Exception {
127        File logFile = new File(ClassLoader.getSystemResource("log.xml").getFile());
128
129        MFCLogParser parser = new MFCLogParser();
130        parser.parseFile(logFile);
131        Collection<List<Event>> events = parser.getSequences();
132
133        assertNotNull(events);
134        assertTrue(events.size() > 0);
135
136        System.err.println("{");
137        for (List<Event> session : events) {
138            System.err.println("  {");
139            for (Event event : session) {
140                System.err.print("    ");
141                System.err.print(event);
142                System.err.println(",");
143            }
144            System.err.println("  }");
145        }
146        System.err.println("}");
147        System.err.println("\n\n");
148
149        GUIModel guiModel = parser.getGuiModel();
150        assertNotNull(guiModel);
151
[745]152        guiModel.dump(System.err, "UTF-8");
[622]153
154       
[706]155        GlobalDataContainer.getInstance().addData("seqs",  parser.getSequences());
156       
[707]157        List<Object> parameters = new ArrayList<Object>();
158        parameters.add(tmpFile.getAbsolutePath());
159        parameters.add("seqs");
[706]160       
[707]161        CMDgenerateReplayfile cmd = new CMDgenerateReplayfile();
162        cmd.run(parameters);
163       
[622]164        InputStreamReader reader1 =
165            new InputStreamReader(ClassLoader.getSystemResourceAsStream("replay.xml"), "UTF-8");
166
167        InputStreamReader reader2 = new InputStreamReader(new FileInputStream(tmpFile), "UTF-8");
168       
169        try {
170            int sign1;
171            do {
172                sign1 = reader1.read();
173                assertEquals(sign1, reader2.read());
174            }
175            while (sign1 > -1);
176        }
177        finally {
178            reader1.close();
179            reader2.close();
180        }
181    }
182
[649]183    /* (non-Javadoc)
184     * @see de.ugoe.cs.util.console.listener.IOutputListener#outputMsg(java.lang.String)
[622]185     */
[649]186    @Override
187    public void outputMsg(String newMessage) {
188        outputStream.println(newMessage);
[622]189    }
190
191}
Note: See TracBrowser for help on using the repository browser.