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

Last change on this file since 927 was 927, checked in by sherbold, 12 years ago
  • added copyright under the Apache License, Version 2.0
  • Property svn:executable set to *
  • Property svn:keywords set to Date Revision Author HeadURL Id
File size: 5.8 KB
Line 
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
15package de.ugoe.cs.autoquest.plugin.mfc;
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;
24import java.io.FileOutputStream;
25import java.io.InputStreamReader;
26import java.io.PrintStream;
27import java.util.ArrayList;
28import java.util.Collection;
29import java.util.List;
30
31import org.junit.After;
32import org.junit.Before;
33import org.junit.Test;
34
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;
40import de.ugoe.cs.util.console.Console;
41import de.ugoe.cs.util.console.GlobalDataContainer;
42import de.ugoe.cs.util.console.listener.IOutputListener;
43
44/**
45 * TODO comment
46 *
47 * @version $Revision$ $Date$
48 * @author 2011, last modified by $Author$
49 */
50public class MFCLogParserTest implements IOutputListener {
51
52    /** */
53    private File tmpFile;
54   
55    /** */
56    private PrintStream outputStream;
57
58    /**
59     *
60     */
61    @Before
62    public void setUp() throws Exception {
63        outputStream = new PrintStream(new FileOutputStream("blub.log"));
64        Console.getInstance().registerOutputListener(this);
65       
66        tmpFile = new File("tmp.xml");
67       
68        if (tmpFile.exists()) {
69            assertTrue(tmpFile.delete());
70        }
71    }
72   
73    /**
74     *
75     */
76    @After
77    public void tearDown() throws Exception {
78        if (!System.out.equals(outputStream) && !System.err.equals(outputStream)) {
79            outputStream.close();
80        }
81       
82        if (tmpFile.exists()) {
83            assertTrue(tmpFile.delete());
84        }
85    }
86   
87   
88    /**
89     *
90     */
91    @Test
92    public void testTrace() throws Exception {
93        File traceFile = new File(ClassLoader.getSystemResource("trace.txt").getFile());
94       
95        new LogPreprocessor().convertToXml(traceFile.getAbsolutePath(),
96                                           tmpFile.getAbsolutePath());
97       
98        MFCLogParser parser = new MFCLogParser();
99        parser.parseFile(tmpFile);
100        Collection<List<Event>> events = parser.getSequences();
101
102        assertNotNull(events);
103        assertTrue(events.size() > 0);
104
105        System.err.println("{");
106        for (List<Event> session : events) {
107            System.err.println("  {");
108            for (Event event : session) {
109                System.err.print("    ");
110                System.err.print(event);
111                System.err.println(",");
112            }
113            System.err.println("  }");
114        }
115        System.err.println("}");
116        System.err.println("\n\n");
117
118        GUIModel guiModel = parser.getGuiModel();
119        assertNotNull(guiModel);
120        assertNotSame(0, guiModel.getRootElements().size());
121
122        guiModel.dump(System.err, "UTF-8");
123    }
124
125    /**
126     *
127     */
128    @Test
129    public void testLogfile() throws Exception {
130        File logFile = new File(ClassLoader.getSystemResource("log.xml").getFile());
131
132        MFCLogParser parser = new MFCLogParser();
133        parser.parseFile(logFile);
134        Collection<List<Event>> events = parser.getSequences();
135
136        assertNotNull(events);
137        assertTrue(events.size() > 0);
138
139        System.err.println("{");
140        for (List<Event> session : events) {
141            System.err.println("  {");
142            for (Event event : session) {
143                System.err.print("    ");
144                System.err.print(event);
145                System.err.println(",");
146            }
147            System.err.println("  }");
148        }
149        System.err.println("}");
150        System.err.println("\n\n");
151
152        GUIModel guiModel = parser.getGuiModel();
153        assertNotNull(guiModel);
154
155        guiModel.dump(System.err, "UTF-8");
156
157       
158        GlobalDataContainer.getInstance().addData("seqs",  parser.getSequences());
159       
160        List<Object> parameters = new ArrayList<Object>();
161        parameters.add(tmpFile.getAbsolutePath());
162        parameters.add("seqs");
163       
164        CMDgenerateReplayfile cmd = new CMDgenerateReplayfile();
165        cmd.run(parameters);
166       
167        InputStreamReader reader1 =
168            new InputStreamReader(ClassLoader.getSystemResourceAsStream("replay.xml"), "UTF-8");
169
170        InputStreamReader reader2 = new InputStreamReader(new FileInputStream(tmpFile), "UTF-8");
171       
172        try {
173            int sign1;
174            do {
175                sign1 = reader1.read();
176                assertEquals(sign1, reader2.read());
177            }
178            while (sign1 > -1);
179        }
180        finally {
181            reader1.close();
182            reader2.close();
183        }
184    }
185
186    /* (non-Javadoc)
187     * @see de.ugoe.cs.util.console.listener.IOutputListener#outputMsg(java.lang.String)
188     */
189    @Override
190    public void outputMsg(String newMessage) {
191        outputStream.println(newMessage);
192    }
193
194}
Note: See TracBrowser for help on using the repository browser.