2014-03-09 11:44:12 +01:00
|
|
|
|
package plugindevelopment;
|
|
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
|
import java.io.FileNotFoundException;
|
|
|
|
|
import java.io.FileReader;
|
|
|
|
|
import java.io.IOException;
|
|
|
|
|
import java.nio.ByteBuffer;
|
|
|
|
|
import java.nio.charset.StandardCharsets;
|
|
|
|
|
import java.nio.file.Files;
|
|
|
|
|
import java.nio.file.Paths;
|
|
|
|
|
import java.util.Vector;
|
|
|
|
|
|
2014-03-09 14:12:48 +01:00
|
|
|
|
import org.apache.log4j.ConsoleAppender;
|
|
|
|
|
import org.apache.log4j.FileAppender;
|
|
|
|
|
import org.apache.log4j.Level;
|
|
|
|
|
import org.apache.log4j.Logger;
|
|
|
|
|
import org.apache.log4j.PatternLayout;
|
|
|
|
|
import org.apache.log4j.SimpleLayout;
|
|
|
|
|
|
2014-06-19 19:40:13 +02:00
|
|
|
|
import typinferenz.typedeployment.TypeInsertPoint;
|
|
|
|
|
import typinferenz.typedeployment.TypeInsertSet;
|
2014-03-09 11:44:12 +01:00
|
|
|
|
import junit.framework.TestCase;
|
|
|
|
|
import mycompiler.MyCompiler;
|
|
|
|
|
import mycompiler.MyCompilerAPI;
|
|
|
|
|
import mycompiler.myparser.JavaParser.yyException;
|
2014-03-09 14:12:48 +01:00
|
|
|
|
import mycompiler.mytest.LambdaTest;
|
2014-03-09 11:44:12 +01:00
|
|
|
|
import mycompiler.mytypereconstruction.TypeinferenceResultSet;
|
|
|
|
|
|
|
|
|
|
|
2014-03-09 13:03:30 +01:00
|
|
|
|
public class TypeInsertTester{
|
2014-03-09 11:44:12 +01:00
|
|
|
|
|
2014-03-09 14:12:48 +01:00
|
|
|
|
private static Logger inferencelog = Logger.getLogger("Typeinference");
|
|
|
|
|
static{
|
|
|
|
|
{
|
|
|
|
|
// Ausgabeoptionen fuer die Logger
|
|
|
|
|
ConsoleAppender logAppender = new ConsoleAppender(new SimpleLayout());
|
|
|
|
|
logAppender.setTarget("System.out");
|
|
|
|
|
logAppender.activateOptions();
|
|
|
|
|
inferencelog.addAppender(logAppender); //Bei den Tests wird der Log auch in System.out geschrieben.
|
|
|
|
|
}
|
|
|
|
|
}
|
2014-03-18 20:18:57 +01:00
|
|
|
|
static final String rootDirectory = System.getProperty("user.dir")+"/test/plugindevelopment/";
|
2014-03-09 11:44:12 +01:00
|
|
|
|
|
|
|
|
|
public static void test(String sourceFileToInfere, String solutionFile){
|
|
|
|
|
String inferedSource = "";
|
|
|
|
|
MyCompilerAPI compiler = MyCompiler.getAPI();
|
|
|
|
|
try {
|
|
|
|
|
compiler.parse(new File(rootDirectory + sourceFileToInfere));
|
|
|
|
|
Vector<TypeinferenceResultSet> results = compiler.typeReconstruction();
|
2014-03-18 20:18:57 +01:00
|
|
|
|
TestCase.assertTrue("Es darf nicht mehr als eine L<>sungsm<73>glichkeit geben und nicht "+results.size(), results.size()==1);
|
2014-03-09 11:44:12 +01:00
|
|
|
|
for(TypeinferenceResultSet result : results){
|
2014-05-07 08:10:55 +02:00
|
|
|
|
TypeInsertSet point = result.getTypeInsertionPoints();
|
|
|
|
|
//TestCase.assertTrue("Es muss mindestens ein TypeInsertSet vorhanden sein", points.size()>0);
|
|
|
|
|
if(point.points.size()>0){
|
2014-03-09 11:44:12 +01:00
|
|
|
|
inferedSource = point.insertAllTypes(getFileContent(rootDirectory + sourceFileToInfere));
|
|
|
|
|
String solutionSource = getFileContent(rootDirectory + solutionFile);
|
|
|
|
|
System.out.println("\nInferierter Source:\n"+inferedSource);
|
2014-03-09 13:03:30 +01:00
|
|
|
|
TestCase.assertTrue("Nicht das erwartete Ergebnis", inferedSource.equals(solutionSource));
|
2014-03-09 11:44:12 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
} catch (IOException | yyException e) {
|
|
|
|
|
e.printStackTrace();
|
2014-03-09 13:03:30 +01:00
|
|
|
|
TestCase.fail();
|
2014-03-09 11:44:12 +01:00
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//Source: https://stackoverflow.com/questions/326390/how-to-create-a-java-string-from-the-contents-of-a-file
|
2014-04-09 14:12:55 +02:00
|
|
|
|
//PS: ben<65>tigt Java 7
|
2014-03-21 16:34:16 +01:00
|
|
|
|
public static String getFileContent(String path)throws IOException
|
2014-03-09 11:44:12 +01:00
|
|
|
|
{
|
|
|
|
|
byte[] encoded = Files.readAllBytes(Paths.get(path));
|
|
|
|
|
return StandardCharsets.UTF_8.decode(ByteBuffer.wrap(encoded)).toString();
|
|
|
|
|
}
|
2014-03-09 14:12:48 +01:00
|
|
|
|
|
2014-03-09 11:44:12 +01:00
|
|
|
|
}
|