
com.tinkerpop.gremlin.process.graph.step.sideEffect.SackTest 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.Operator;
import com.tinkerpop.gremlin.structure.Vertex;
import org.junit.Test;
import java.util.Arrays;
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.*;
/**
* @author Marko A. Rodriguez (http://markorodriguez.com)
*/
public abstract class SackTest extends AbstractGremlinProcessTest {
public abstract Traversal get_g_V_withSackX0X_outE_sackXsum_weightX_inV_sack_sum();
public abstract Traversal get_g_V_withSackX0X_repeatXoutE_sackXsum_weightX_inVX_timesX2X_sack();
public abstract Traversal get_g_V_withSackXmap__map_cloneX_out_out_sackXmap_a_nameX_sack();
@Test
@LoadGraphWith(MODERN)
public void g_V_withSackX0X_outE_sackXsum_weightX_inV_sack_sum() {
final Traversal traversal = get_g_V_withSackX0X_outE_sackXsum_weightX_inV_sack_sum();
assertEquals(3.5d, traversal.next(), 0.00001d);
assertFalse(traversal.hasNext());
}
@Test
@LoadGraphWith(MODERN)
public void g_V_withSackX0X_repeatXoutE_sackXsum_weightX_inVX_timesX2X_sack() {
final Traversal traversal = get_g_V_withSackX0X_repeatXoutE_sackXsum_weightX_inVX_timesX2X_sack();
super.checkResults(Arrays.asList(2.0f, 1.4f), traversal);
}
@Test
@LoadGraphWith(MODERN)
public void g_V_withSackXmap__map_cloneX_out_out_sackXmap_a_nameX_sack() {
final Traversal traversal = get_g_V_withSackXmap__map_cloneX_out_out_sackXmap_a_nameX_sack();
int counter = 0;
while (traversal.hasNext()) {
final Map map = traversal.next();
assertEquals(1, map.size());
assertTrue(map.containsKey("a"));
assertTrue(map.get("a").equals("ripple") || map.get("a").equals("lop"));
counter++;
}
assertEquals(2, counter);
}
public static class StandardTest extends SackTest {
public StandardTest() {
requiresGraphComputer = false;
}
@Override
public Traversal get_g_V_withSackX0X_outE_sackXsum_weightX_inV_sack_sum() {
return g.V().withSack(() -> 0.0f).outE().sack(Operator.sum, "weight").inV().sack().sum();
}
@Override
public Traversal get_g_V_withSackX0X_repeatXoutE_sackXsum_weightX_inVX_timesX2X_sack() {
return g.V().withSack(() -> 0.0f).repeat(__.outE().sack(Operator.sum, "weight").inV()).times(2).sack();
}
@Override
public Traversal get_g_V_withSackXmap__map_cloneX_out_out_sackXmap_a_nameX_sack() {
return g.V().withSack(HashMap::new, m -> (HashMap) m.clone()).out().out().
© 2015 - 2025 Weber Informatics LLC | Privacy Policy