2014-06-18 07:06:08 +00:00
|
|
|
|
package plugindevelopment;
|
|
|
|
|
|
|
|
|
|
import java.io.File;
|
|
|
|
|
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;
|
|
|
|
|
|
|
|
|
|
import org.junit.Test;
|
|
|
|
|
|
2014-09-02 08:33:54 +00:00
|
|
|
|
import de.dhbwstuttgart.core.MyCompiler;
|
|
|
|
|
import de.dhbwstuttgart.core.MyCompilerAPI;
|
2014-09-05 09:49:31 +00:00
|
|
|
|
import de.dhbwstuttgart.parser.JavaParser.yyException;
|
2014-09-02 08:33:54 +00:00
|
|
|
|
import de.dhbwstuttgart.typeinference.TypeinferenceResultSet;
|
|
|
|
|
import de.dhbwstuttgart.typeinference.typedeployment.TypeInsertPoint;
|
|
|
|
|
import de.dhbwstuttgart.typeinference.typedeployment.TypeInsertSet;
|
2014-06-18 07:06:08 +00:00
|
|
|
|
import junit.framework.TestCase;
|
|
|
|
|
|
|
|
|
|
public class InsertSingleTypeTest {
|
|
|
|
|
private static final String testFile = "SingleTypeInsertTest.jav";
|
|
|
|
|
|
|
|
|
|
@Test
|
|
|
|
|
public void test1(){
|
|
|
|
|
TypeinferenceResultSet res = test(testFile);
|
|
|
|
|
TypeInsertPoint p = res.getTypeInsertionPoints().points.firstElement();
|
|
|
|
|
try {
|
|
|
|
|
System.out.println(res.getTypeInsertionPoints().insertType(p, this.getFileContent(rootDirectory + testFile)));
|
|
|
|
|
} catch (IOException e) {
|
|
|
|
|
TestCase.fail();
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
static final String rootDirectory = System.getProperty("user.dir")+"/test/plugindevelopment/";
|
|
|
|
|
|
|
|
|
|
public static TypeinferenceResultSet test(String sourceFileToInfere){
|
|
|
|
|
String inferedSource = "";
|
|
|
|
|
MyCompilerAPI compiler = MyCompiler.getAPI();
|
|
|
|
|
try {
|
|
|
|
|
compiler.parse(new File(rootDirectory + sourceFileToInfere));
|
|
|
|
|
Vector<TypeinferenceResultSet> results = compiler.typeReconstruction();
|
|
|
|
|
TestCase.assertTrue("Es darf nicht mehr als eine L<>sungsm<73>glichkeit geben und nicht "+results.size(), results.size()==1);
|
|
|
|
|
return results.firstElement();
|
|
|
|
|
} catch (IOException | yyException e) {
|
|
|
|
|
e.printStackTrace();
|
|
|
|
|
TestCase.fail();
|
|
|
|
|
return null;
|
|
|
|
|
}
|
|
|
|
|
}
|
|
|
|
|
|
|
|
|
|
//Source: https://stackoverflow.com/questions/326390/how-to-create-a-java-string-from-the-contents-of-a-file
|
|
|
|
|
//PS: ben<65>tigt Java 7
|
|
|
|
|
public static String getFileContent(String path)throws IOException
|
|
|
|
|
{
|
|
|
|
|
byte[] encoded = Files.readAllBytes(Paths.get(path));
|
|
|
|
|
return StandardCharsets.UTF_8.decode(ByteBuffer.wrap(encoded)).toString();
|
|
|
|
|
}
|
|
|
|
|
}
|