2018-11-15 20:52:27 +01:00
|
|
|
package bytecode.simplifyalgo;
|
|
|
|
|
|
|
|
import static org.junit.Assert.*;
|
|
|
|
|
|
|
|
import java.util.HashMap;
|
|
|
|
import java.util.HashSet;
|
|
|
|
|
|
|
|
import org.junit.BeforeClass;
|
|
|
|
import org.junit.Test;
|
|
|
|
import org.objectweb.asm.Type;
|
|
|
|
|
|
|
|
import de.dhbwstuttgart.bytecode.TPHExtractor;
|
|
|
|
import de.dhbwstuttgart.bytecode.constraint.ExtendsConstraint;
|
|
|
|
import de.dhbwstuttgart.bytecode.constraint.TPHConstraint;
|
|
|
|
import de.dhbwstuttgart.bytecode.constraint.TPHConstraint.Relation;
|
|
|
|
import de.dhbwstuttgart.bytecode.utilities.Simplify;
|
|
|
|
/**
|
|
|
|
*
|
|
|
|
* @author Fayez Abu Alia
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
public class SimpleCycle {
|
|
|
|
private static TPHExtractor tphExtractor;
|
|
|
|
private static String methName;
|
|
|
|
@BeforeClass
|
|
|
|
public static void setUpBeforeClass() throws Exception {
|
|
|
|
tphExtractor = new TPHExtractor();
|
|
|
|
// A < B
|
|
|
|
TPHConstraint c1 = new ExtendsConstraint("A", "B", Relation.EXTENDS);
|
|
|
|
// B < A
|
|
|
|
TPHConstraint c2 = new ExtendsConstraint("B", "A", Relation.EXTENDS);
|
|
|
|
// name
|
|
|
|
methName = "m";
|
|
|
|
tphExtractor.allCons.add(c1);
|
|
|
|
tphExtractor.allCons.add(c2);
|
|
|
|
|
|
|
|
}
|
|
|
|
|
|
|
|
@Test
|
|
|
|
public void test() {
|
|
|
|
HashMap<TPHConstraint, HashSet<String>> result = new HashMap<>();
|
|
|
|
HashSet<String> equals = new HashSet<>();
|
|
|
|
equals.add("A");
|
|
|
|
equals.add("B");
|
|
|
|
TPHConstraint k = new ExtendsConstraint("B", Type.getInternalName(Object.class), Relation.EXTENDS);
|
|
|
|
result.put(k, equals);
|
|
|
|
|
|
|
|
HashMap<TPHConstraint, HashSet<String>> sim = Simplify.simplifyConstraints(methName, tphExtractor);
|
|
|
|
boolean areEquals = areMapsEqual(result, sim);
|
|
|
|
assertTrue(areEquals);
|
|
|
|
}
|
|
|
|
|
|
|
|
public static boolean areMapsEqual(HashMap<TPHConstraint, HashSet<String>> m1, HashMap<TPHConstraint, HashSet<String>> m2) {
|
|
|
|
|
|
|
|
for(TPHConstraint c : m1.keySet()) {
|
|
|
|
for(TPHConstraint c2 : m2.keySet()) {
|
|
|
|
if(c.getLeft().equals(c2.getLeft()) && c.getRight().equals(c2.getRight()) && c.getRel()==c2.getRel()) {
|
|
|
|
HashSet<String> eq1 = m1.get(c);
|
|
|
|
HashSet<String> eq2 = m2.get(c2);
|
|
|
|
|
2018-11-21 11:58:58 +01:00
|
|
|
if((eq1 == null && eq2 != null) || (eq1 != null && eq2 == null))
|
2018-11-15 20:52:27 +01:00
|
|
|
return false;
|
2018-11-21 11:58:58 +01:00
|
|
|
if(eq1 != null) {
|
|
|
|
if(eq1.size() != eq2.size())
|
2018-11-15 20:52:27 +01:00
|
|
|
return false;
|
2018-11-21 11:58:58 +01:00
|
|
|
|
|
|
|
for(String tph:eq1) {
|
|
|
|
if(!eq2.contains(tph))
|
|
|
|
return false;
|
|
|
|
}
|
2018-11-15 20:52:27 +01:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|
|
|
|
return true;
|
|
|
|
}
|
|
|
|
|
|
|
|
}
|