
com.tinkerpop.gremlin.process.graph.step.branch.ChooseTest Maven / Gradle / Ivy
The newest version!
package com.tinkerpop.gremlin.process.graph.step.branch;
import com.tinkerpop.gremlin.LoadGraphWith;
import com.tinkerpop.gremlin.process.AbstractGremlinProcessTest;
import com.tinkerpop.gremlin.process.Traversal;
import com.tinkerpop.gremlin.process.util.MapHelper;
import com.tinkerpop.gremlin.structure.Vertex;
import org.junit.Test;
import java.util.HashMap;
import java.util.Map;
import static com.tinkerpop.gremlin.LoadGraphWith.GraphData.MODERN;
import static com.tinkerpop.gremlin.process.graph.AnonymousGraphTraversal.Tokens.__;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;
/**
* @author Marko A. Rodriguez (http://markorodriguez.com)
* @author Joshua Shinavier (http://fortytwo.net)
*/
public abstract class ChooseTest extends AbstractGremlinProcessTest {
public abstract Traversal get_g_V_chooseXname_length_5XoutXinX_name();
public abstract Traversal get_g_v1_chooseX0XoutX_name(Object v1Id);
public abstract Traversal get_g_V_hasXageX_chooseXname_lengthX5_in_4_out_3_bothX_name();
public abstract Traversal get_g_V_chooseXout_count_nextX2L_name_3L_valueMapX();
@Test
@LoadGraphWith(MODERN)
public void g_V_chooseXname_length_5XoutXinX_name() {
final Traversal traversal = get_g_V_chooseXname_length_5XoutXinX_name();
printTraversalForm(traversal);
Map counts = new HashMap<>();
int counter = 0;
while (traversal.hasNext()) {
MapHelper.incr(counts, traversal.next(), 1l);
counter++;
}
assertFalse(traversal.hasNext());
assertEquals(9, counter);
assertEquals(5, counts.size());
assertEquals(Long.valueOf(1), counts.get("vadas"));
assertEquals(Long.valueOf(3), counts.get("josh"));
assertEquals(Long.valueOf(2), counts.get("lop"));
assertEquals(Long.valueOf(2), counts.get("marko"));
assertEquals(Long.valueOf(1), counts.get("peter"));
}
@Test
@LoadGraphWith(MODERN)
public void g_v1_chooseX0XoutX_name() {
final Traversal traversal = get_g_v1_chooseX0XoutX_name(convertToVertexId("marko"));
printTraversalForm(traversal);
Map counts = new HashMap<>();
int counter = 0;
while (traversal.hasNext()) {
MapHelper.incr(counts, traversal.next(), 1l);
counter++;
}
assertFalse(traversal.hasNext());
assertEquals(3, counter);
assertEquals(3, counts.size());
assertEquals(Long.valueOf(1), counts.get("vadas"));
assertEquals(Long.valueOf(1), counts.get("josh"));
assertEquals(Long.valueOf(1), counts.get("lop"));
}
@Test
@LoadGraphWith(MODERN)
public void g_V_hasXageX_chooseXname_lengthX5_in_4_out_3_bothX_name() {
final Traversal traversal = get_g_V_hasXageX_chooseXname_lengthX5_in_4_out_3_bothX_name();
printTraversalForm(traversal);
Map counts = new HashMap<>();
int counter = 0;
while (traversal.hasNext()) {
MapHelper.incr(counts, traversal.next(), 1l);
counter++;
}
assertFalse(traversal.hasNext());
assertEquals(3, counter);
assertEquals(3, counts.size());
assertEquals(Long.valueOf(1), counts.get("marko"));
assertEquals(Long.valueOf(1), counts.get("lop"));
assertEquals(Long.valueOf(1), counts.get("ripple"));
}
@Test
@LoadGraphWith(MODERN)
public void g_V_chooseXout_count_nextX2L_valueXnameX_3L_valueMapX() {
final Traversal traversal = get_g_V_chooseXout_count_nextX2L_name_3L_valueMapX();
printTraversalForm(traversal);
Map counts = new HashMap<>();
int counter = 0;
while (traversal.hasNext()) {
MapHelper.incr(counts, traversal.next().toString(), 1l);
counter++;
}
assertFalse(traversal.hasNext());
assertEquals(2, counter);
assertEquals(2, counts.size());
assertEquals(Long.valueOf(1), counts.get("{name=[marko], age=[29]}"));
assertEquals(Long.valueOf(1), counts.get("josh"));
}
public static class StandardTest extends ChooseTest {
@Override
public Traversal get_g_V_chooseXname_length_5XoutXinX_name() {
return g.V().choose(v -> v.value("name").length() == 5,
__.out(),
__.in()).values("name");
}
@Override
public Traversal get_g_v1_chooseX0XoutX_name(Object v1Id) {
return g.V(v1Id).choose(t -> 0, new HashMap>() {{
put(0, __.out().values("name"));
}});
}
@Override
public Traversal get_g_V_hasXageX_chooseXname_lengthX5_in_4_out_3_bothX_name() {
return g.V().has("age").choose(v -> v.value("name").length(), new HashMap() {{
put(5, __.in());
put(4, __.out());
put(3, __.both());
}}).values("name");
}
@Override
public Traversal get_g_V_chooseXout_count_nextX2L_name_3L_valueMapX() {
return g.V().choose(v -> v.out().count().next(), new HashMap() {{
put(2L, __.values("name"));
put(3L, __.valueMap());
}});
}
}
public static class ComputerTest extends ChooseTest {
public ComputerTest() {
requiresGraphComputer = true;
}
@Override
public Traversal get_g_V_chooseXname_length_5XoutXinX_name() {
return g.V().choose(v -> v.value("name").length() == 5,
__.out(),
__.in()).values("name").submit(g.compute());
}
@Override
public Traversal get_g_v1_chooseX0XoutX_name(Object v1Id) {
return g.V(v1Id).choose(t -> 0, new HashMap() {{
put(0, __.out().values("name"));
}}).submit(g.compute());
}
@Override
public Traversal get_g_V_hasXageX_chooseXname_lengthX5_in_4_out_3_bothX_name() {
return g.V().has("age").choose(v -> v.value("name").length(), new HashMap() {{
put(5, __.in());
put(4, __.out());
put(3, __.both());
}}).values("name").submit(g.compute());
}
@Override
public Traversal get_g_V_chooseXout_count_nextX2L_name_3L_valueMapX() {
return g.V().choose(v -> v.out().count().next(), new HashMap() {{
put(2L, __.values("name"));
put(3L, __.valueMap());
}}).submit(g.compute());
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy