package plugindevelopment; import static org.junit.Assert.*; import java.io.File; import java.io.FileNotFoundException; import java.io.IOException; import de.dhbwstuttgart.typeinference.Menge; import org.junit.Test; import de.dhbwstuttgart.core.MyCompiler; import de.dhbwstuttgart.core.MyCompilerAPI; import de.dhbwstuttgart.parser.JavaParser.yyException; import de.dhbwstuttgart.syntaxtree.SyntaxTreeNode; import de.dhbwstuttgart.syntaxtree.type.RefType; import de.dhbwstuttgart.syntaxtree.type.Type; import de.dhbwstuttgart.syntaxtree.type.TypePlaceholder; import de.dhbwstuttgart.typeinference.Pair; import de.dhbwstuttgart.typeinference.ResultSet; import de.dhbwstuttgart.typeinference.TypeInsertable; import de.dhbwstuttgart.typeinference.TypeinferenceResultSet; import de.dhbwstuttgart.typeinference.Pair.PairOperator; import de.dhbwstuttgart.typeinference.typedeployment.TypeInsertPoint; import de.dhbwstuttgart.typeinference.typedeployment.TypeInsertSet; import junit.framework.TestCase; import mycompiler.mytypereconstruction.replacementlistener.CReplaceTypeEvent; public class TRMEqualTest { Menge replaceSet = new Menge(); TestNode node; TypePlaceholder tph; public void initTRMEqualTest(){ node = new TestNode(); tph = TypePlaceholder.fresh(node); node.setType(tph); } @Test public void test(){ initTRMEqualTest(); assertTrue("Zu Beginn ist das Set leer",replaceSet.size()==0); addTestNode("Typ1"); assertTrue("Nach dem Anfügen eines Type muss das Set 1 Element enthalten",replaceSet.size()==1); addTestNode("Typ2"); assertTrue("Nach dem Anfügen eines weiteren Typs muss das Set 2 Elemente enthalten und nicht "+replaceSet.size(),replaceSet.size()==2); addTestNode("Typ1"); assertTrue("Nach dem Anfügen des selben Typs wie zuvor muss das Set immer noch 2 Element enthalten. Und nicht "+replaceSet.size(),replaceSet.size()==2); } private void addTestNode(String type){ Menge resultContent = new Menge(); Pair pair = new Pair(tph,new RefType(type,0)); pair.SetOperator(PairOperator.Equal); resultContent.add(pair); ResultSet resultSet = new ResultSet(resultContent); Menge tphs = tph.getTypeInsertPoints(resultSet); TypeInsertSet toAdd = new TypeInsertSet(resultSet); for(TypeInsertPoint tip : tphs){ toAdd.add(tip); } System.out.println("Füge hinzu: "+toAdd); if(!replaceSet.contains(toAdd))replaceSet.add(toAdd); } } class TestNode extends SyntaxTreeNode implements TypeInsertable{ @Override public void replaceType(CReplaceTypeEvent e) { // TODO Auto-generated method stub } @Override public int getTypeLineNumber() { // TODO Auto-generated method stub return 0; } @Override public void setType(Type typ) { // TODO Auto-generated method stub } @Override public Type getType() { // TODO Auto-generated method stub return null; } @Override public int getOffset() { // TODO Auto-generated method stub return 0; } @Override public void setOffset(int offset) { // TODO Auto-generated method stub } @Override public String getIdentifier() { // TODO Auto-generated method stub return null; } @Override public TypeInsertPoint createTypeInsertPoint(TypePlaceholder tph, ResultSet resultSet) { return new TypeInsertPoint( this, this, resultSet.getTypeEqualTo(tph), resultSet); } @Override public int getVariableLength() { // TODO Auto-generated method stub return 0; } @Override public Menge getChildren() { // TODO Auto-generated method stub return new Menge<>(); } }