All Downloads are FREE. Search and download functionalities are using the official Maven repository.

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