reduceSup Test

This commit is contained in:
Florian Steurer 2015-11-08 22:21:28 +01:00
parent 7ada9cbd47
commit eeba9fb734
2 changed files with 80 additions and 38 deletions

View File

@ -78,16 +78,8 @@ public class RuleSet implements IRuleSet{
return Optional.empty(); return Optional.empty();
Type lhsType = pair.getLhsType(); Type lhsType = pair.getLhsType();
SimpleType lhsSType;
if(lhsType instanceof SimpleType) if(!(lhsType instanceof SimpleType) && !(lhsType instanceof ExtendsType))
lhsSType = (SimpleType) lhsType;
else if(lhsType instanceof ExtendsType)
lhsSType = (SimpleType) ((ExtendsType) lhsType).getExtendedType();
else
return Optional.empty();
if(lhsSType.getTypeParams().empty())
return Optional.empty(); return Optional.empty();
Type rhsType = pair.getRhsType(); Type rhsType = pair.getRhsType();
@ -95,18 +87,16 @@ public class RuleSet implements IRuleSet{
if(!(rhsType instanceof ExtendsType)) if(!(rhsType instanceof ExtendsType))
return Optional.empty(); return Optional.empty();
SimpleType rhsSType = (SimpleType) ((ExtendsType) rhsType).getExtendedType(); if(lhsType.getTypeParams().empty() || rhsType.getTypeParams().size() != lhsType.getTypeParams().size())
if(rhsSType.getTypeParams().size() != lhsSType.getTypeParams().size())
return Optional.empty(); return Optional.empty();
int[] pi = pi(lhsSType, rhsType); int[] pi = pi(lhsType, rhsType);
if(pi.length == 0) if(pi.length == 0)
return Optional.empty(); return Optional.empty();
Type[] rhsTypeParams = rhsSType.getTypeParams().asArray(); Type[] rhsTypeParams = rhsType.getTypeParams().asArray();
Type[] lhsTypeParams = lhsSType.getTypeParams().asArray(); Type[] lhsTypeParams = lhsType.getTypeParams().asArray();
Set<MPair> result = new HashSet<>(); Set<MPair> result = new HashSet<>();
for(int rhsIdx = 0; rhsIdx < rhsTypeParams.length; rhsIdx++) for(int rhsIdx = 0; rhsIdx < rhsTypeParams.length; rhsIdx++)
@ -121,16 +111,8 @@ public class RuleSet implements IRuleSet{
return Optional.empty(); return Optional.empty();
Type lhsType = pair.getLhsType(); Type lhsType = pair.getLhsType();
SimpleType lhsSType;
if(lhsType instanceof SimpleType) if(!(lhsType instanceof SimpleType) && !(lhsType instanceof SuperType))
lhsSType = (SimpleType) lhsType;
else if(lhsType instanceof SuperType)
lhsSType = (SimpleType) ((SuperType) lhsType).getSuperedType();
else
return Optional.empty();
if(lhsSType.getTypeParams().empty())
return Optional.empty(); return Optional.empty();
Type rhsType = pair.getRhsType(); Type rhsType = pair.getRhsType();
@ -138,22 +120,20 @@ public class RuleSet implements IRuleSet{
if(!(rhsType instanceof SuperType)) if(!(rhsType instanceof SuperType))
return Optional.empty(); return Optional.empty();
SimpleType rhsSType = (SimpleType) ((SuperType) rhsType).getSuperedType(); if(lhsType.getTypeParams().empty() || rhsType.getTypeParams().size() != lhsType.getTypeParams().size())
if(rhsSType.getTypeParams().size() != lhsSType.getTypeParams().size())
return Optional.empty(); return Optional.empty();
int[] pi = pi(lhsSType, rhsType); int[] pi = pi(lhsType, rhsType);
if(pi.length == 0) if(pi.length == 0)
return Optional.empty(); return Optional.empty();
Type[] rhsTypeParams = rhsSType.getTypeParams().asArray(); Type[] rhsTypeParams = rhsType.getTypeParams().asArray();
Type[] lhsTypeParams = lhsSType.getTypeParams().asArray(); Type[] lhsTypeParams = lhsType.getTypeParams().asArray();
Set<MPair> result = new HashSet<>(); Set<MPair> result = new HashSet<>();
for(int rhsIdx = 0; rhsIdx < rhsTypeParams.length; rhsIdx++) for(int rhsIdx = 0; rhsIdx < rhsTypeParams.length; rhsIdx++)
result.add(new MPair(lhsTypeParams[rhsIdx], rhsTypeParams[pi[rhsIdx]], PairOperator.SMALLERDOTWC)); result.add(new MPair(lhsTypeParams[pi[rhsIdx]], rhsTypeParams[rhsIdx], PairOperator.SMALLERDOTWC));
return Optional.of(result); return Optional.of(result);
} }
@ -205,7 +185,7 @@ public class RuleSet implements IRuleSet{
SimpleType lhsSType = (SimpleType) lhsType; SimpleType lhsSType = (SimpleType) lhsType;
SimpleType rhsSType = (SimpleType) rhsType; SimpleType rhsSType = (SimpleType) rhsType;
if(lhsSType.getTypeParams().empty() || rhsSType.getTypeParams().empty() || lhsSType.getTypeParams().size() != rhsSType.getTypeParams().size()) if(lhsSType.getTypeParams().empty() || lhsSType.getTypeParams().size() != rhsSType.getTypeParams().size())
return Optional.empty(); return Optional.empty();
int[] pi = pi(lhsSType, rhsSType); int[] pi = pi(lhsSType, rhsSType);
@ -267,7 +247,7 @@ public class RuleSet implements IRuleSet{
Type[] rhsTypeParams = rhsSType.getTypeParams().asArray(); Type[] rhsTypeParams = rhsSType.getTypeParams().asArray();
Type[] lhsTypeParams = lhsSType.getTypeParams().asArray(); Type[] lhsTypeParams = lhsSType.getTypeParams().asArray();
for(int i = 0; i < rhsTypeParams.length; i++) for(int i = 0; i < rhsTypeParams.length; i++)
result.add(new MPair(lhsTypeParams[i], rhsTypeParams[i], PairOperator.SMALLERDOT)); result.add(new MPair(lhsTypeParams[i], rhsTypeParams[i], PairOperator.EQUALSDOT));
return Optional.of(result); return Optional.of(result);
} }
@ -346,15 +326,20 @@ public class RuleSet implements IRuleSet{
* @return An array containing the values of pi for every type argument of C or an empty array if the search failed. * @return An array containing the values of pi for every type argument of C or an empty array if the search failed.
*/ */
private int[] pi(Type C, Type D) { private int[] pi(Type C, Type D) {
Type cFromFc = finiteClosure.getType(C.getName()); Type cFromFc = null;
if(C instanceof SimpleType)
cFromFc = finiteClosure.getType(C.getName());
else if(C instanceof ExtendsType)
cFromFc = new ExtendsType(finiteClosure.getType(((ExtendsType) C).getExtendedType().getName()));
else if(C instanceof SuperType)
cFromFc = new SuperType(finiteClosure.getType(((SuperType) C).getSuperedType().getName()));
if(cFromFc == null) if(cFromFc == null)
return new int[0]; return new int[0];
Optional<Type> opt = Optional.empty(); Optional<Type> opt = Optional.empty();
if(D instanceof ExtendsType) { if(D instanceof ExtendsType) {
SimpleType dSType = (SimpleType) ((ExtendsType) D).getExtendedType(); SimpleType dSType = (SimpleType) ((ExtendsType) D).getExtendedType();
Set<Type> t = finiteClosure.grArg(cFromFc);
opt = finiteClosure.grArg(cFromFc).stream() opt = finiteClosure.grArg(cFromFc).stream()
.filter(x -> x instanceof ExtendsType) .filter(x -> x instanceof ExtendsType)
.filter(x -> ((ExtendsType) x).getExtendedType().getName().equals(dSType.getName())).findAny(); .filter(x -> ((ExtendsType) x).getExtendedType().getName().equals(dSType.getName())).findAny();

View File

@ -265,7 +265,64 @@ public class RuleSetTest {
@Test @Test
public void testReduceSup() { public void testReduceSup() {
TypeFactory tf = new TypeFactory();
FiniteClosureBuilder fcb = new FiniteClosureBuilder();
/*
* Positive Tests
*/
// X<T1, T2, T3, T4>
SimpleType x1 = tf.getSimpleType("X", "T1", "T2", "T3", "T4");
// Y<T4, T1, T2, T3>
SimpleType y1 = tf.getSimpleType("Y", "T4", "T1", "T2", "T3");
SimpleType buffer = tf.getSimpleType("Buffer");
//X<Int, ? extends Double, M, N>
SimpleType x2 = tf.getSimpleType("X", tf.getSimpleType("Int"), tf.getExtendsType(tf.getSimpleType("Double")), tf.getPlaceholderType("M"), tf.getPlaceholderType("N"));
//? extends Y<? super HashSet<Int>, Number, Double, N>
SuperType supY1 = tf.getSuperType(tf.getSimpleType("Y", tf.getSuperType(tf.getSimpleType("HashSet", "Int")), tf.getSimpleType("Number"), tf.getSimpleType("Double"), tf.getPlaceholderType("N")));
// Y<...> < buffer < X<...>
fcb.add(y1, buffer);
fcb.add(buffer, x1);
IRuleSet rules = new RuleSet(fcb.getFiniteClosure());
MPair pair1 = new MPair(x2, supY1, PairOperator.SMALLERDOTWC);
MPair pair2 = new MPair(tf.getSuperType(x2), supY1, PairOperator.SMALLERDOTWC);
MPair pair3 = new MPair(supY1, supY1, PairOperator.SMALLERDOTWC);
System.out.println("------ ReduceSup ------");
Optional<Set<MPair>> opt1 = rules.reduceSup(pair1);
System.out.println(opt1);
Optional<Set<MPair>> opt2 = rules.reduceSup(pair2);
System.out.println(opt2);
Optional<Set<MPair>> opt3 = rules.reduceSup(pair3);
System.out.println(opt3);
/*
* Negative Tests
*/
// Case 1: X <.? Y
pair1 = new MPair(x2, supY1.getSuperedType(), PairOperator.SMALLERDOTWC);
Assert.assertFalse(rules.reduceSup(pair1).isPresent());
// Case 2: X =. ? super Y
pair2 = new MPair(x2, supY1, PairOperator.EQUALSDOT);
Assert.assertFalse(rules.reduceSup(pair2).isPresent());
// Case 3: ? super Y <.? ? super X
pair3 = new MPair(supY1, tf.getSuperType(x2), PairOperator.SMALLERDOTWC);
Assert.assertFalse(rules.reduceSup(pair3).isPresent());
// Case 4: X <. ? super Y and ? super Y not in grArg(X)
fcb.clear();
rules = new RuleSet(fcb.getFiniteClosure());
pair1 = new MPair(x2, supY1, PairOperator.SMALLERDOTWC);
Assert.assertFalse(rules.reduceSup(pair1).isPresent());
} }
@Test @Test