use of ai.grakn.graql.internal.gremlin.fragment.Fragment in project grakn by graknlabs.
the class GraqlTraversal method applyFragments.
private GraphTraversal<Vertex, Map<String, Element>> applyFragments(EmbeddedGraknTx<?> tx, Set<Var> vars, ImmutableList<Fragment> fragmentList, GraphTraversal<Vertex, ? extends Element> traversal) {
Set<Var> foundVars = new HashSet<>();
// Apply fragments in order into one single traversal
Var currentName = null;
for (Fragment fragment : fragmentList) {
// Apply fragment to traversal
fragment.applyTraversal(traversal, tx, foundVars, currentName);
currentName = fragment.end() != null ? fragment.end() : fragment.start();
}
// Select all the variable names
return selectVars(traversal, Sets.intersection(vars, foundVars));
}
use of ai.grakn.graql.internal.gremlin.fragment.Fragment in project grakn by graknlabs.
the class QueryPlannerTest method inferRelationshipTypeWithARolePlayerWithNoType.
@Test
public void inferRelationshipTypeWithARolePlayerWithNoType() {
Pattern pattern;
ImmutableList<Fragment> plan;
pattern = and(x.isa(thingy1), y.isa(thingy2), var().rel(x).rel(y).rel(z));
plan = getPlan(pattern);
assertEquals(2L, plan.stream().filter(LabelFragment.class::isInstance).count());
pattern = and(y.isa(thingy2), z.isa(thingy4), var().rel(x).rel(y).rel(z));
plan = getPlan(pattern);
// Relationship type can now be inferred, so one more relationship type label
assertEquals(3L, plan.stream().filter(LabelFragment.class::isInstance).count());
assertEquals(3L, plan.stream().filter(fragment -> fragment instanceof OutIsaFragment || fragment instanceof InIsaFragment).count());
}
use of ai.grakn.graql.internal.gremlin.fragment.Fragment in project grakn by graknlabs.
the class QueryPlannerTest method inferUniqueRelationshipType.
@Test
public void inferUniqueRelationshipType() {
Pattern pattern;
ImmutableList<Fragment> plan;
pattern = and(x.isa(thingy1), y.isa(thingy2), var().rel(x).rel(y));
plan = getPlan(pattern);
assertEquals(2L, plan.stream().filter(LabelFragment.class::isInstance).count());
pattern = and(x.isa(thingy), y.isa(thingy2), var().rel(x).rel(y));
plan = getPlan(pattern);
assertEquals(2L, plan.stream().filter(LabelFragment.class::isInstance).count());
pattern = and(x.isa(thingy2), y.isa(thingy4), var().rel(x).rel(y));
plan = getPlan(pattern);
// Relationship type can now be inferred, so one more relationship type label
assertEquals(3L, plan.stream().filter(LabelFragment.class::isInstance).count());
// Should start from the inferred relationship type, instead of role players
String relationship = plan.get(3).start().getValue();
assertNotEquals(relationship, x.getValue());
assertNotEquals(relationship, y.getValue());
}
use of ai.grakn.graql.internal.gremlin.fragment.Fragment in project grakn by graknlabs.
the class QueryPlannerTest method inferRelationshipTypeWhereRolePlayedBySuperType.
@Test
public void inferRelationshipTypeWhereRolePlayedBySuperType() {
Pattern pattern;
ImmutableList<Fragment> plan;
pattern = and(x.isa(thingy), y.isa(thingy4), var().rel(x).rel(y));
plan = getPlan(pattern);
assertEquals(2L, plan.stream().filter(LabelFragment.class::isInstance).count());
pattern = and(x.isa(thingy), y.isa(thingy2), z.isa(thingy4), var().rel(x).rel(y).rel(z));
plan = getPlan(pattern);
// Relationship type can now be inferred, so one more relationship type label
assertEquals(4L, plan.stream().filter(LabelFragment.class::isInstance).count());
assertEquals(4L, plan.stream().filter(fragment -> fragment instanceof OutIsaFragment || fragment instanceof InIsaFragment).count());
}
use of ai.grakn.graql.internal.gremlin.fragment.Fragment in project grakn by graknlabs.
the class QueryPlannerTest method inferRelationshipTypeWhereAVarHasIncorrectTypes.
@Test
public void inferRelationshipTypeWhereAVarHasIncorrectTypes() {
Pattern pattern;
ImmutableList<Fragment> plan;
pattern = and(x.isa(veryRelated), x.isa(thingy2), y.isa(thingy4), var().rel(x).rel(y));
plan = getPlan(pattern);
assertEquals(3L, plan.stream().filter(LabelFragment.class::isInstance).count());
assertEquals(3L, plan.stream().filter(fragment -> fragment instanceof OutIsaFragment || fragment instanceof InIsaFragment).count());
pattern = and(x.isa(veryRelated), y.isa(thingy4), var().rel(x).rel(y));
plan = getPlan(pattern);
assertEquals(2L, plan.stream().filter(LabelFragment.class::isInstance).count());
assertEquals(2L, plan.stream().filter(fragment -> fragment instanceof OutIsaFragment || fragment instanceof InIsaFragment).count());
}
Aggregations