org.umlg.sqlg.test.vertex.TestVertexEdges Maven / Gradle / Ivy
package org.umlg.sqlg.test.vertex;
import org.apache.tinkerpop.gremlin.structure.Direction;
import org.apache.tinkerpop.gremlin.structure.Edge;
import org.apache.tinkerpop.gremlin.structure.T;
import org.apache.tinkerpop.gremlin.structure.Vertex;
import org.junit.Assert;
import org.junit.Assume;
import org.junit.BeforeClass;
import org.junit.Test;
import org.umlg.sqlg.test.BaseTest;
import java.util.List;
import java.util.concurrent.atomic.AtomicInteger;
/**
* Date: 2016/12/13
* Time: 4:36 PM
*/
public class TestVertexEdges extends BaseTest {
@BeforeClass
public static void beforeClass() {
//This test only works on postgres.
//it makes assumptions about iteration and query excution order.
// HSQLDB behaves differently.
BaseTest.beforeClass();
Assume.assumeTrue(isPostgres());
}
@Test
public void testVertexEdgesEager() {
testVertexEdges(false);
}
@Test
public void testVertexEdgesLazy() {
testVertexEdges(true);
}
private void testVertexEdges(boolean lazy) {
final Vertex a1 = this.sqlgGraph.addVertex(T.label, "A");
final Vertex b1 = this.sqlgGraph.addVertex(T.label, "B");
final Vertex c1 = this.sqlgGraph.addVertex(T.label, "C");
a1.addEdge("ab", b1);
a1.addEdge("ac", c1);
this.sqlgGraph.tx().commit();
this.sqlgGraph.tx().setLazyQueries(lazy);
AtomicInteger count = new AtomicInteger(0);
a1.edges(Direction.BOTH).forEachRemaining(e -> count.incrementAndGet());
Assert.assertEquals(2, count.get());
count.set(0);
a1.edges(Direction.BOTH).forEachRemaining(edge -> {
a1.addEdge("ab", b1);
count.getAndIncrement();
});
Assert.assertEquals(lazy ? 3 : 2, count.get());
}
@Test
public void testVertexEdgesTraversalEager() {
testVertexEdgesTraversal(false);
}
@Test
public void testVertexEdgesTraversalLazy() {
testVertexEdgesTraversal(true);
}
private void testVertexEdgesTraversal(boolean lazy) {
final Vertex a1 = this.sqlgGraph.addVertex(T.label, "A");
final Vertex b1 = this.sqlgGraph.addVertex(T.label, "B");
final Vertex c1 = this.sqlgGraph.addVertex(T.label, "C");
a1.addEdge("ab", b1);
a1.addEdge("ac", c1);
this.sqlgGraph.tx().commit();
this.sqlgGraph.tx().setLazyQueries(lazy);
AtomicInteger count = new AtomicInteger(0);
a1.edges(Direction.BOTH).forEachRemaining(e -> count.incrementAndGet());
Assert.assertEquals(2, count.get());
count.set(0);
vertexTraversal(this.sqlgGraph, a1).bothE().forEachRemaining(edge -> {
a1.addEdge("ab", b1);
count.getAndIncrement();
});
Assert.assertEquals(lazy ? 3 : 2, count.get());
}
@Test
public void testBothEOnEdgeToSelf() {
final Vertex v1 = this.sqlgGraph.addVertex("name", "marko");
final Vertex v2 = this.sqlgGraph.addVertex("name", "puppy");
v1.addEdge("knows", v2, "since", 2010);
v1.addEdge("pets", v2);
v1.addEdge("walks", v2, "location", "arroyo");
v2.addEdge("knows", v1, "since", 2010);
Assert.assertEquals(4, vertexTraversal(this.sqlgGraph, v1).bothE().count().next().intValue());
Assert.assertEquals(4, vertexTraversal(this.sqlgGraph, v2).bothE().count().next().intValue());
this.sqlgGraph.tx().setLazyQueries(false);
v1.edges(Direction.BOTH).forEachRemaining(edge -> {
v1.addEdge("livesWith", v2);
v1.addEdge("walks", v2, "location", "river");
edge.remove();
});
this.sqlgGraph.tx().commit();
List edgeList = vertexTraversal(this.sqlgGraph, v1).outE().toList();
for (Edge edge : edgeList) {
System.out.println(edge);
}
Assert.assertEquals(8, vertexTraversal(this.sqlgGraph, v1).outE().count().next().intValue());
Assert.assertEquals(0, vertexTraversal(this.sqlgGraph, v2).outE().count().next().intValue());
v1.edges(Direction.BOTH).forEachRemaining(Edge::remove);
Assert.assertEquals(0, vertexTraversal(this.sqlgGraph, v1).bothE().count().next().intValue());
Assert.assertEquals(0, vertexTraversal(this.sqlgGraph, v2).bothE().count().next().intValue());
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy