
com.tinkerpop.gremlin.process.graph.step.sideEffect.GroupTest Maven / Gradle / Ivy
The newest version!
package com.tinkerpop.gremlin.process.graph.step.sideEffect;
import com.tinkerpop.gremlin.LoadGraphWith;
import com.tinkerpop.gremlin.process.AbstractGremlinProcessTest;
import com.tinkerpop.gremlin.process.Traversal;
import com.tinkerpop.gremlin.structure.Vertex;
import org.junit.Test;
import java.util.ArrayList;
import java.util.Collection;
import java.util.List;
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.*;
/**
* @author Marko A. Rodriguez (http://markorodriguez.com)
* @author Stephen Mallette (http://stephen.genoprime.com)
*/
public abstract class GroupTest extends AbstractGremlinProcessTest {
public abstract Traversal>> get_g_V_group_byXnameX();
public abstract Traversal>> get_g_V_hasXlangX_groupXaX_byXlangX_byXnameX_out_capXaX();
public abstract Traversal> get_g_V_hasXlangX_group_byXlangX_byX1X_byXsizeX();
public abstract Traversal> get_g_V_repeatXout_groupXaX_byXnameX_by_byXsizeXX_timesX2X_capXaX();
@Test
@LoadGraphWith(MODERN)
public void g_V_group_byXnameX() {
final Traversal>> traversal = get_g_V_group_byXnameX();
printTraversalForm(traversal);
final Map> map = traversal.next();
assertEquals(6, map.size());
map.forEach((key, values) -> {
assertEquals(1, values.size());
assertEquals(convertToVertexId(key), values.iterator().next().id());
});
assertFalse(traversal.hasNext());
}
@Test
@LoadGraphWith(MODERN)
public void g_V_hasXlangX_groupXaX_byXlangX_byXnameX_out_capXaX() {
final Traversal>> traversal = get_g_V_hasXlangX_groupXaX_byXlangX_byXnameX_out_capXaX();
printTraversalForm(traversal);
final Map> map = traversal.next();
assertFalse(traversal.hasNext());
assertEquals(1, map.size());
assertTrue(map.containsKey("java"));
assertEquals(2, map.get("java").size());
assertTrue(map.get("java").contains("ripple"));
assertTrue(map.get("java").contains("lop"));
}
@Test
@LoadGraphWith(MODERN)
public void g_V_hasXlangX_group_byXlangX_byX1X_byXsizeX() {
final Traversal> traversal = get_g_V_hasXlangX_group_byXlangX_byX1X_byXsizeX();
printTraversalForm(traversal);
final Map map = traversal.next();
assertEquals(1, map.size());
assertTrue(map.containsKey("java"));
assertEquals(Integer.valueOf(2), map.get("java"));
assertFalse(traversal.hasNext());
}
@Test
@LoadGraphWith(MODERN)
public void g_V_repeatXout_groupXaX_byXnameX_byXitX_byXsizeXX_timesX2X_capXaX() {
List>> traversals = new ArrayList<>();
traversals.add(get_g_V_repeatXout_groupXaX_byXnameX_by_byXsizeXX_timesX2X_capXaX());
traversals.forEach(traversal -> {
printTraversalForm(traversal);
final Map map = traversal.next();
assertFalse(traversal.hasNext());
assertEquals(4, map.size());
assertTrue(map.containsKey("vadas"));
assertEquals(Integer.valueOf(1), map.get("vadas"));
assertTrue(map.containsKey("josh"));
assertEquals(Integer.valueOf(1), map.get("josh"));
assertTrue(map.containsKey("lop"));
assertEquals(Integer.valueOf(4), map.get("lop"));
assertTrue(map.containsKey("ripple"));
assertEquals(Integer.valueOf(2), map.get("ripple"));
});
}
public static class StandardTest extends GroupTest {
@Override
public Traversal>> get_g_V_group_byXnameX() {
return (Traversal) g.V().group().by("name");
}
@Override
public Traversal>> get_g_V_hasXlangX_groupXaX_byXlangX_byXnameX_out_capXaX() {
return (Traversal) g.V().has("lang")
.group("a").by("lang").by("name").out().cap("a");
}
@Override
public Traversal> get_g_V_hasXlangX_group_byXlangX_byX1X_byXsizeX() {
return (Traversal) g.V().has("lang")
.group().by("lang").by(v -> 1).by(Collection::size);
}
@Override
public Traversal> get_g_V_repeatXout_groupXaX_byXnameX_by_byXsizeXX_timesX2X_capXaX() {
return g.V().repeat(__.out().group("a").by("name").by().by(Collection::size)).times(2).cap("a");
}
}
public static class ComputerTest extends GroupTest {
public ComputerTest() {
requiresGraphComputer = true;
}
@Override
public Traversal>> get_g_V_group_byXnameX() {
return (Traversal) g.V().group().by("name").submit(g.compute());
}
@Override
public Traversal>> get_g_V_hasXlangX_groupXaX_byXlangX_byXnameX_out_capXaX() {
return (Traversal) g.V().has("lang")
.group("a").by("lang").by("name").out().cap("a").submit(g.compute());
}
@Override
public Traversal> get_g_V_hasXlangX_group_byXlangX_byX1X_byXsizeX() {
return (Traversal) g.V().has("lang")
.group().by("lang").by(v -> 1).by(Collection::size).submit(g.compute());
}
@Override
public Traversal> get_g_V_repeatXout_groupXaX_byXnameX_by_byXsizeXX_timesX2X_capXaX() {
return g.V().repeat(__.out().group("a").by("name").by().by(Collection::size)).times(2).
© 2015 - 2025 Weber Informatics LLC | Privacy Policy