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

com.tinkerpop.gremlin.process.graph.step.map.JumpTest Maven / Gradle / Ivy

package com.tinkerpop.gremlin.process.graph.step.map;

import com.tinkerpop.gremlin.LoadGraphWith;
import com.tinkerpop.gremlin.process.AbstractGremlinProcessTest;
import com.tinkerpop.gremlin.process.Path;
import com.tinkerpop.gremlin.process.Traversal;
import com.tinkerpop.gremlin.process.util.MapHelper;
import com.tinkerpop.gremlin.structure.Vertex;
import com.tinkerpop.gremlin.util.StreamFactory;
import org.junit.Test;

import java.util.ArrayList;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.stream.Collectors;

import static com.tinkerpop.gremlin.LoadGraphWith.GraphData.CLASSIC;
import static org.junit.Assert.*;

/**
 * @author Marko A. Rodriguez (http://markorodriguez.com)
 * @author Stephen Mallette (http://stephen.genoprime.com)
 */
public abstract class JumpTest extends AbstractGremlinProcessTest {

    public abstract Traversal get_g_v1_asXxX_out_jumpXx_loops_lt_2X_valueXnameX(final Object v1Id);

    public abstract Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2X();

    public abstract Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2_trueX();

    public abstract Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2_trueX_path();

    public abstract Traversal get_g_V_asXxX_out_jumpXx_2_trueX_path();

    public abstract Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2X_asXyX_in_jumpXy_loops_lt_2X_name();

    public abstract Traversal get_g_V_asXxX_out_jumpXx_2X_asXyX_in_jumpXy_2X_name();

    public abstract Traversal get_g_V_asXxX_out_jumpXx_2X();

    public abstract Traversal get_g_V_asXxX_out_jumpXx_2_trueX();

    public abstract Traversal get_g_v1_out_jumpXx_t_out_hasNextX_in_jumpXyX_asXxX_out_asXyX_path(final Object v1Id);

    public abstract Traversal get_g_V_jumpXxX_out_out_asXxX();

    public abstract Traversal get_g_v1_asXaX_jumpXb_loops_gt_1X_out_jumpXaX_asXbX_name(final Object v1Id);

    @Test
    @LoadGraphWith(CLASSIC)
    public void g_v1_asXxX_out_jumpXx_loops_lt_2X_valueXnameX() {
        final List> traversals = new ArrayList<>();
        traversals.add(get_g_v1_asXxX_out_jumpXx_loops_lt_2X_valueXnameX(convertToVertexId("marko")));
        traversals.add(get_g_v1_asXaX_jumpXb_loops_gt_1X_out_jumpXaX_asXbX_name(convertToVertexId("marko")));
        traversals.forEach(traversal -> {
            printTraversalForm(traversal);
            List names = new ArrayList<>();
            while (traversal.hasNext()) {
                names.add(traversal.next());
            }
            assertEquals(2, names.size());
            assertTrue(names.contains("ripple"));
            assertTrue(names.contains("lop"));
        });
    }

    @Test
    @LoadGraphWith(CLASSIC)
    public void g_V_asXxX_out_jumpXx_loops_lt_2_trueX_path() {
        final List> traversals = new ArrayList<>();
        traversals.add(get_g_V_asXxX_out_jumpXx_loops_lt_2_trueX_path());
        traversals.add(get_g_V_asXxX_out_jumpXx_2_trueX_path());
        traversals.forEach(traversal -> {
            printTraversalForm(traversal);
            final Map pathLengths = new HashMap<>();
            int counter = 0;
            while (traversal.hasNext()) {
                counter++;
                MapHelper.incr(pathLengths, traversal.next().size(), 1l);
            }
            assertEquals(2, pathLengths.size());
            assertEquals(8, counter);
            assertEquals(new Long(6), pathLengths.get(2));
            assertEquals(new Long(2), pathLengths.get(3));
        });
    }

    @Test
    @LoadGraphWith(CLASSIC)
    public void g_V_asXxX_out_jumpXx_2X_asXyX_in_jumpXy_2X_name() {
        final List> traversals = new ArrayList<>();
        traversals.add(get_g_V_asXxX_out_jumpXx_loops_lt_2X_asXyX_in_jumpXy_loops_lt_2X_name());
        traversals.add(get_g_V_asXxX_out_jumpXx_2X_asXyX_in_jumpXy_2X_name());
        traversals.forEach(traversal -> {
            printTraversalForm(traversal);
            int count = 0;
            while (traversal.hasNext()) {
                assertEquals("marko", traversal.next());
                count++;
            }
            assertEquals(2, count);
            assertFalse(traversal.hasNext());
        });
    }

    @Test
    @LoadGraphWith(CLASSIC)
    public void g_V_asXxX_out_jumpXx_2() {
        final List> traversals = new ArrayList<>();
        traversals.add(get_g_V_asXxX_out_jumpXx_2X());
        traversals.add(get_g_V_asXxX_out_jumpXx_loops_lt_2X());
        traversals.forEach(traversal -> {
            printTraversalForm(traversal);
            int counter = 0;
            while (traversal.hasNext()) {
                counter++;
                Vertex vertex = traversal.next();
                assertTrue(vertex.value("name").equals("lop") || vertex.value("name").equals("ripple"));
            }
            assertEquals(2, counter);
            assertFalse(traversal.hasNext());
        });
    }

    @Test
    @LoadGraphWith(CLASSIC)
    public void g_V_asXxX_out_jumpXx_2_trueX() {
        final List> traversals = new ArrayList<>();
        traversals.add(get_g_V_asXxX_out_jumpXx_2_trueX());
        traversals.add(get_g_V_asXxX_out_jumpXx_loops_lt_2_trueX());
        traversals.forEach(traversal -> {
            printTraversalForm(traversal);
            Map map = new HashMap<>();
            while (traversal.hasNext()) {
                Vertex vertex = traversal.next();
                MapHelper.incr(map, vertex.value("name"), 1l);
            }
            assertEquals(4, map.size());
            assertTrue(map.containsKey("vadas"));
            assertTrue(map.containsKey("josh"));
            assertTrue(map.containsKey("ripple"));
            assertTrue(map.containsKey("lop"));
            assertEquals(new Long(1), map.get("vadas"));
            assertEquals(new Long(1), map.get("josh"));
            assertEquals(new Long(2), map.get("ripple"));
            assertEquals(new Long(4), map.get("lop"));
        });
    }

    @Test
    @LoadGraphWith(CLASSIC)
    public void g_v1_out_jumpXx_t_out_hasNextX_in_jumpXyX_asXxX_out_asXyX_path() {
        Traversal traversal = get_g_v1_out_jumpXx_t_out_hasNextX_in_jumpXyX_asXxX_out_asXyX_path(convertToVertexId("marko"));
        printTraversalForm(traversal);
        final List paths = StreamFactory.stream(traversal).collect(Collectors.toList());
        assertEquals(6, paths.size());
        assertFalse(traversal.hasNext());
    }

    @Test
    @LoadGraphWith(CLASSIC)
    public void g_V_jumpXxX_out_out_asXxX() {
        Traversal traversal = get_g_V_jumpXxX_out_out_asXxX();
        printTraversalForm(traversal);
        assertTrue(traversal.hasNext());
        int counter = 0;
        Set vertices = new HashSet<>();
        while (traversal.hasNext()) {
            vertices.add(traversal.next());
            counter++;
        }
        assertEquals(6, counter);
        assertEquals(6, vertices.size());
    }


    public static class JavaJumpTest extends JumpTest {
        public JavaJumpTest() {
            requiresGraphComputer = false;
        }

        public Traversal get_g_v1_asXxX_out_jumpXx_loops_lt_2X_valueXnameX(final Object v1Id) {
            return g.v(v1Id).as("x").out().jump("x", h -> h.getLoops() < 2).value("name");
        }

        public Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2X() {
            return g.V().as("x").out().jump("x", t -> t.getLoops() < 2);
        }

        public Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2_trueX() {
            return g.V().as("x").out().jump("x", t -> t.getLoops() < 2, t -> true);
        }

        public Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2_trueX_path() {
            return g.V().as("x").out().jump("x", t -> t.getLoops() < 2, t -> true).path();
        }

        public Traversal get_g_V_asXxX_out_jumpXx_2_trueX_path() {
            return g.V().as("x").out().jump("x", 2, t -> true).path();
        }

        public Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2X_asXyX_in_jumpXy_loops_lt_2X_name() {
            return g.V().as("x").out().jump("x", t -> t.getLoops() < 2).as("y").in().jump("y", t -> t.getLoops() < 2).value("name");
        }

        public Traversal get_g_V_asXxX_out_jumpXx_2X_asXyX_in_jumpXy_2X_name() {
            return g.V().as("x").out().jump("x", 2).as("y").in().jump("y", 2).value("name");
        }

        public Traversal get_g_V_asXxX_out_jumpXx_2X() {
            return g.V().as("x").out().jump("x", 2);
        }

        public Traversal get_g_V_asXxX_out_jumpXx_2_trueX() {
            return g.V().as("x").out().jump("x", 2, t -> true);
        }

        public Traversal get_g_v1_out_jumpXx_t_out_hasNextX_in_jumpXyX_asXxX_out_asXyX_path(final Object v1Id) {
            return g.v(v1Id).out().jump("x", t -> t.get().out().hasNext()).in().jump("y").as("x").out().as("y").path();
        }

        public Traversal get_g_V_jumpXxX_out_out_asXxX() {
            return g.V().jump("x").out().out().as("x");
        }

        public Traversal get_g_v1_asXaX_jumpXb_loops_gt_1X_out_jumpXaX_asXbX_name(final Object v1Id) {
            return g.v(v1Id).as("a").jump("b", t -> t.getLoops() > 1).out().jump("a").as("b").value("name");
        }
    }

    public static class JavaComputerJumpTest extends JumpTest {
        public JavaComputerJumpTest() {
            requiresGraphComputer = true;
        }

        public Traversal get_g_v1_asXxX_out_jumpXx_loops_lt_2X_valueXnameX(final Object v1Id) {
            return g.v(v1Id).as("x").out().jump("x", t -> t.getLoops() < 2).value("name").submit(g.compute());
        }

        public Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2X() {
            return g.V().as("x").out().jump("x", t -> t.getLoops() < 2).submit(g.compute());
        }

        public Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2_trueX() {
            return g.V().as("x").out().jump("x", t -> t.getLoops() < 2, t -> true).submit(g.compute());
        }

        public Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2_trueX_path() {
            return g.V().as("x").out().jump("x", t -> t.getLoops() < 2, t -> true).path().submit(g.compute());
        }

        public Traversal get_g_V_asXxX_out_jumpXx_2_trueX_path() {
            return g.V().as("x").out().jump("x", 2, t -> true).path().submit(g.compute());
        }

        public Traversal get_g_V_asXxX_out_jumpXx_loops_lt_2X_asXyX_in_jumpXy_loops_lt_2X_name() {
            return g.V().as("x").out().jump("x", t -> t.getLoops() < 2).as("y").in().jump("y", t -> t.getLoops() < 2).value("name").submit(g.compute());
        }

        public Traversal get_g_V_asXxX_out_jumpXx_2X_asXyX_in_jumpXy_2X_name() {
            return g.V().as("x").out().jump("x", 2).as("y").in().jump("y", 2).value("name").submit(g.compute());
        }

        public Traversal get_g_V_asXxX_out_jumpXx_2X() {
            return g.V().as("x").out().jump("x", 2).submit(g.compute());
        }

        public Traversal get_g_V_asXxX_out_jumpXx_2_trueX() {
            return g.V().as("x").out().jump("x", 2, t -> true).submit(g.compute());
        }

        public Traversal get_g_v1_out_jumpXx_t_out_hasNextX_in_jumpXyX_asXxX_out_asXyX_path(final Object v1Id) {
            return g.v(v1Id).out().jump("x", t -> t.get().out().hasNext()).in().jump("y").as("x").out().as("y").path().submit(g.compute());
        }

        public Traversal get_g_V_jumpXxX_out_out_asXxX() {
            return g.V().jump("x").out().out().as("x").submit(g.compute());
        }

        public Traversal get_g_v1_asXaX_jumpXb_loops_gt_1X_out_jumpXaX_asXbX_name(final Object v1Id) {
            return g.v(v1Id).as("a").jump("b", t -> t.getLoops() > 1).out().jump("a").as("b").value("name").submit(g.compute());
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy