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

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

The newest version!
package com.tinkerpop.gremlin.process.graph.step.map;

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.HashSet;
import java.util.List;
import java.util.Set;

import static com.tinkerpop.gremlin.LoadGraphWith.GraphData.MODERN;
import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertFalse;

/**
 * @author Marko A. Rodriguez (http://markorodriguez.com)
 */
public abstract class FoldTest extends AbstractGremlinProcessTest {

    public abstract Traversal> get_g_V_fold();

    public abstract Traversal get_g_V_fold_unfold();

    public abstract Traversal get_g_V_age_foldX0_plusX();

    @Test
    @LoadGraphWith(MODERN)
    public void g_V_fold() {
        final Traversal> traversal = get_g_V_fold();
        printTraversalForm(traversal);
        List list = traversal.next();
        assertFalse(traversal.hasNext());
        Set vertices = new HashSet<>(list);
        assertEquals(6, vertices.size());
    }

    @Test
    @LoadGraphWith(MODERN)
    public void g_V_fold_unfold() {
        final Traversal traversal = get_g_V_fold_unfold();
        printTraversalForm(traversal);
        int count = 0;
        Set vertices = new HashSet<>();
        while (traversal.hasNext()) {
            vertices.add(traversal.next());
            count++;
        }
        assertFalse(traversal.hasNext());
        assertEquals(6, count);
        assertEquals(6, vertices.size());
    }

    @Test
    @LoadGraphWith(MODERN)
    public void g_V_age_foldX0_plusX() {
        final Traversal traversal = get_g_V_age_foldX0_plusX();
        printTraversalForm(traversal);
        final Integer ageSum = traversal.next();
        assertFalse(traversal.hasNext());
        assertEquals(Integer.valueOf(123), ageSum);
    }

    public static class StandardTest extends FoldTest {

        @Override
        public Traversal> get_g_V_fold() {
            return g.V().fold();
        }

        @Override
        public Traversal get_g_V_fold_unfold() {
            return g.V().fold().unfold();
        }

        @Override
        public Traversal get_g_V_age_foldX0_plusX() {
            return g.V().values("age").fold(0, (seed, age) -> seed + age);
        }
    }

    public static class ComputerTest extends FoldTest {

        public ComputerTest() {
            requiresGraphComputer = true;
        }

        @Override
        public Traversal> get_g_V_fold() {
            return g.V().fold().submit(g.compute());
        }

        @Override
        public Traversal get_g_V_fold_unfold() {
            return (Traversal) g.V().fold().unfold().submit(g.compute());
        }

        @Override
        public Traversal get_g_V_age_foldX0_plusX() {
            return g.V().values("age").fold(0, (seed, age) -> seed + age).submit(g.compute());
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy