
com.tinkerpop.gremlin.process.graph.step.map.BackTest Maven / Gradle / Ivy
The newest version!
package com.tinkerpop.gremlin.process.graph.step.map;
import com.tinkerpop.gremlin.LoadGraphWith;
import com.tinkerpop.gremlin.process.AbstractGremlinProcessTest;
import com.tinkerpop.gremlin.process.Traversal;
import com.tinkerpop.gremlin.structure.Edge;
import com.tinkerpop.gremlin.structure.Vertex;
import org.junit.Test;
import java.util.Arrays;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import static com.tinkerpop.gremlin.LoadGraphWith.GraphData.MODERN;
import static com.tinkerpop.gremlin.process.graph.AnonymousGraphTraversal.Tokens.__;
import static org.junit.Assert.*;
/**
* @author Marko A. Rodriguez (http://markorodriguez.com)
* @author Stephen Mallette (http://stephen.genoprime.com)
*/
public abstract class BackTest extends AbstractGremlinProcessTest {
public abstract Traversal get_g_VX1X_asXhereX_out_backXhereX(final Object v1Id);
public abstract Traversal get_g_VX4X_out_asXhereX_hasXlang_javaX_backXhereX(final Object v4Id);
public abstract Traversal get_g_VX4X_out_asXhereX_hasXlang_javaX_backXhereX_name(final Object v4Id);
public abstract Traversal get_g_VX1X_outE_asXhereX_inV_hasXname_vadasX_backXhereX(final Object v1Id);
public abstract Traversal get_g_VX1X_outEXknowsX_hasXweight_1X_asXhereX_inV_hasXname_joshX_backXhereX(final Object v1Id);
public abstract Traversal get_g_VX1X_outEXknowsX_asXhereX_hasXweight_1X_inV_hasXname_joshX_backXhereX(final Object v1Id);
public abstract Traversal get_g_VX1X_outEXknowsX_asXhereX_hasXweight_1X_asXfakeX_inV_hasXname_joshX_backXhereX(final Object v1Id);
public abstract Traversal get_g_V_asXhereXout_name_backXhereX();
public abstract Traversal> get_g_V_outXcreatedX_unionXasXprojectX_inXcreatedX_hasXname_markoX_backXprojectX__asXprojectX_inXcreatedX_inXknowsX_hasXname_markoX_backXprojectXX_groupCount_byXnameX();
@Test
@LoadGraphWith(MODERN)
public void g_VX1X_asXhereX_out_backXhereX() {
final Traversal traversal = get_g_VX1X_asXhereX_out_backXhereX(convertToVertexId("marko"));
printTraversalForm(traversal);
int counter = 0;
while (traversal.hasNext()) {
counter++;
assertEquals("marko", traversal.next().value("name"));
}
assertEquals(3, counter);
}
@Test
@LoadGraphWith(MODERN)
public void g_VX4X_out_asXhereX_hasXlang_javaX_backXhereX() {
final Traversal traversal = get_g_VX4X_out_asXhereX_hasXlang_javaX_backXhereX(convertToVertexId("josh"));
printTraversalForm(traversal);
int counter = 0;
while (traversal.hasNext()) {
counter++;
final Vertex vertex = traversal.next();
assertEquals("java", vertex.value("lang"));
assertTrue(vertex.value("name").equals("ripple") || vertex.value("name").equals("lop"));
}
assertEquals(2, counter);
}
@Test
@LoadGraphWith(MODERN)
public void g_VX1X_outE_asXhereX_inV_hasXname_vadasX_backXhereX() {
final Traversal traversal = get_g_VX1X_outE_asXhereX_inV_hasXname_vadasX_backXhereX(convertToVertexId("marko"));
printTraversalForm(traversal);
final Edge edge = traversal.next();
assertEquals("knows", edge.label());
assertEquals(convertToVertexId("vadas"), edge.inV().id().next());
assertEquals(convertToVertexId("marko"), edge.outV().id().next());
assertEquals(0.5d, edge.value("weight"), 0.0001d);
assertFalse(traversal.hasNext());
}
@Test
@LoadGraphWith(MODERN)
public void g_VX4X_out_asXhereX_hasXlang_javaX_backXhereX_name() {
final Traversal traversal = get_g_VX4X_out_asXhereX_hasXlang_javaX_backXhereX_name(convertToVertexId("josh"));
printTraversalForm(traversal);
int counter = 0;
final Set names = new HashSet<>();
while (traversal.hasNext()) {
counter++;
names.add(traversal.next());
}
assertEquals(2, counter);
assertEquals(2, names.size());
assertTrue(names.contains("ripple"));
assertTrue(names.contains("lop"));
}
@Test
@LoadGraphWith(MODERN)
public void g_VX1X_outEXknowsX_hasXweight_1X_asXhereX_inV_hasXname_joshX_backXhereX() {
final List> traversals = Arrays.asList(
get_g_VX1X_outEXknowsX_hasXweight_1X_asXhereX_inV_hasXname_joshX_backXhereX(convertToVertexId("marko")),
get_g_VX1X_outEXknowsX_asXhereX_hasXweight_1X_inV_hasXname_joshX_backXhereX(convertToVertexId("marko")),
get_g_VX1X_outEXknowsX_asXhereX_hasXweight_1X_asXfakeX_inV_hasXname_joshX_backXhereX(convertToVertexId("marko")));
traversals.forEach(traversal -> {
printTraversalForm(traversal);
assertTrue(traversal.hasNext());
assertTrue(traversal.hasNext());
final Edge edge = traversal.next();
assertEquals("knows", edge.label());
assertEquals(1.0d, edge.value("weight"), 0.00001d);
assertFalse(traversal.hasNext());
assertFalse(traversal.hasNext());
});
}
@Test
@LoadGraphWith(MODERN)
public void g_V_asXhereXout_name_backXhereX() {
Traversal traversal = get_g_V_asXhereXout_name_backXhereX();
printTraversalForm(traversal);
super.checkResults(new HashMap() {{
put(convertToVertex(g, "marko"), 3l);
put(convertToVertex(g, "josh"), 2l);
put(convertToVertex(g, "peter"), 1l);
}}, traversal);
}
@Test
@LoadGraphWith(MODERN)
public void g_V_outXcreatedX_unionXasXprojectX_inXcreatedX_hasXname_markoX_backXprojectX__asXprojectX_inXcreatedX_inXknowsX_hasXname_markoX_backXprojectXX_groupCount_byXnameX() {
List>> traversals = Arrays.asList(get_g_V_outXcreatedX_unionXasXprojectX_inXcreatedX_hasXname_markoX_backXprojectX__asXprojectX_inXcreatedX_inXknowsX_hasXname_markoX_backXprojectXX_groupCount_byXnameX());
traversals.forEach(traversal -> {
printTraversalForm(traversal);
assertTrue(traversal.hasNext());
final Map map = traversal.next();
assertFalse(traversal.hasNext());
assertEquals(2, map.size());
assertEquals(1l, map.get("ripple").longValue());
assertEquals(6l, map.get("lop").longValue());
});
}
public static class StandardTest extends BackTest {
public StandardTest() {
requiresGraphComputer = false;
}
@Override
public Traversal get_g_VX1X_asXhereX_out_backXhereX(final Object v1Id) {
return g.V(v1Id).as("here").out().back("here");
}
@Override
public Traversal get_g_VX4X_out_asXhereX_hasXlang_javaX_backXhereX(final Object v4Id) {
return g.V(v4Id).out().as("here").has("lang", "java").back("here");
}
@Override
public Traversal get_g_VX4X_out_asXhereX_hasXlang_javaX_backXhereX_name(final Object v4Id) {
return g.V(v4Id).out().as("here").has("lang", "java").back("here").values("name");
}
@Override
public Traversal get_g_VX1X_outE_asXhereX_inV_hasXname_vadasX_backXhereX(final Object v1Id) {
return g.V(v1Id).outE().as("here").inV().has("name", "vadas").back("here");
}
@Override
public Traversal get_g_VX1X_outEXknowsX_hasXweight_1X_asXhereX_inV_hasXname_joshX_backXhereX(final Object v1Id) {
return g.V(v1Id).outE("knows").has("weight", 1.0d).as("here").inV().has("name", "josh").back("here");
}
@Override
public Traversal get_g_VX1X_outEXknowsX_asXhereX_hasXweight_1X_inV_hasXname_joshX_backXhereX(final Object v1Id) {
return g.V(v1Id).outE("knows").as("here").has("weight", 1.0d).inV().has("name", "josh").back("here");
}
@Override
public Traversal get_g_VX1X_outEXknowsX_asXhereX_hasXweight_1X_asXfakeX_inV_hasXname_joshX_backXhereX(final Object v1Id) {
return g.V(v1Id).outE("knows").as("here").has("weight", 1.0d).as("fake").inV().has("name", "josh").back("here");
}
@Override
public Traversal get_g_V_asXhereXout_name_backXhereX() {
return g.V().as("here").out().values("name").back("here");
}
@Override
public Traversal> get_g_V_outXcreatedX_unionXasXprojectX_inXcreatedX_hasXname_markoX_backXprojectX__asXprojectX_inXcreatedX_inXknowsX_hasXname_markoX_backXprojectXX_groupCount_byXnameX() {
return (Traversal) g.V().out("created")
.union(__.as("project").in("created").has("name", "marko").back("project"),
__.as("project").in("created").in("knows").has("name", "marko").back("project")).groupCount().by("name");
}
}
public static class ComputerTest extends BackTest {
public ComputerTest() {
requiresGraphComputer = true;
}
@Override
public Traversal get_g_VX1X_asXhereX_out_backXhereX(final Object v1Id) {
return g.V(v1Id).as("here").out().back("here").submit(g.compute());
}
@Override
public Traversal get_g_VX4X_out_asXhereX_hasXlang_javaX_backXhereX(final Object v4Id) {
return g.V(v4Id).out().as("here").has("lang", "java").back("here").submit(g.compute());
}
@Override
public Traversal get_g_VX4X_out_asXhereX_hasXlang_javaX_backXhereX_name(final Object v4Id) {
return g.V(v4Id).out().as("here").has("lang", "java").back("here").values("name").submit(g.compute());
}
@Override
public Traversal get_g_VX1X_outE_asXhereX_inV_hasXname_vadasX_backXhereX(final Object v1Id) {
return g.V(v1Id).outE().as("here").inV().has("name", "vadas").back("here").submit(g.compute());
}
@Override
public Traversal get_g_VX1X_outEXknowsX_hasXweight_1X_asXhereX_inV_hasXname_joshX_backXhereX(final Object v1Id) {
return g.V(v1Id).outE("knows").has("weight", 1.0d).as("here").inV().has("name", "josh").back("here").submit(g.compute());
}
@Override
public Traversal get_g_VX1X_outEXknowsX_asXhereX_hasXweight_1X_inV_hasXname_joshX_backXhereX(final Object v1Id) {
return g.V(v1Id).outE("knows").as("here").has("weight", 1.0d).inV().has("name", "josh").back("here").submit(g.compute());
}
@Override
public Traversal get_g_VX1X_outEXknowsX_asXhereX_hasXweight_1X_asXfakeX_inV_hasXname_joshX_backXhereX(final Object v1Id) {
return g.V(v1Id).outE("knows").as("here").has("weight", 1.0d).as("fake").inV().has("name", "josh").back("here").submit(g.compute());
}
@Override
public Traversal get_g_V_asXhereXout_name_backXhereX() {
return g.V().as("here").out().values("name").back("here").submit(g.compute());
}
@Override
public Traversal> get_g_V_outXcreatedX_unionXasXprojectX_inXcreatedX_hasXname_markoX_backXprojectX__asXprojectX_inXcreatedX_inXknowsX_hasXname_markoX_backXprojectXX_groupCount_byXnameX() {
return (Traversal) g.V().out("created")
.union(__.as("project").in("created").has("name", "marko").back("project"),
__.as("project").in("created").in("knows").has("name", "marko").back("project")).groupCount().by("name").submit(g.compute());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy