/* * Licensed to the Apache Software Foundation (ASF) under one * or more contributor license agreements. See the NOTICE file * distributed with this work for additional information * regarding copyright ownership. The ASF licenses this file * to you under the Apache License, Version 2.0 (the * "License"); you may not use this file except in compliance * with the License. You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, * software distributed under the License is distributed on an * "AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY * KIND, either express or implied. See the License for the * specific language governing permissions and limitations * under the License. */ package org.apache.tinkerpop.gremlin.process.traversal.step.branch; import org.apache.tinkerpop.gremlin.LoadGraphWith; import org.apache.tinkerpop.gremlin.process.AbstractGremlinProcessTest; import org.apache.tinkerpop.gremlin.process.GremlinProcessRunner; import org.apache.tinkerpop.gremlin.process.traversal.Order; import org.apache.tinkerpop.gremlin.process.traversal.Traversal; import org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.__; import org.apache.tinkerpop.gremlin.structure.Edge; import org.apache.tinkerpop.gremlin.structure.T; import org.apache.tinkerpop.gremlin.structure.Vertex; import org.junit.Test; import org.junit.runner.RunWith; import java.util.Arrays; import java.util.Map; import static org.apache.tinkerpop.gremlin.LoadGraphWith.GraphData.CREW; import static org.apache.tinkerpop.gremlin.LoadGraphWith.GraphData.MODERN; import static org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.__.as; import static org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.__.bothE; import static org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.__.inE; import static org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.__.out; import static org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.__.outE; import static org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.__.properties; import static org.junit.Assert.assertEquals; import static org.junit.Assert.assertFalse; import static org.junit.Assert.assertTrue; import static org.junit.Assert.fail; /** * @author Marko A. Rodriguez (http://markorodriguez.com) */ @RunWith(GremlinProcessRunner.class) public abstract class LocalTest extends AbstractGremlinProcessTest { public abstract Traversal<Vertex, String> get_g_V_localXpropertiesXlocationX_order_byXvalueX_limitX2XX_value(); public abstract Traversal<Vertex, Map<String, Object>> get_g_V_hasXlabel_personX_asXaX_localXoutXcreatedX_asXbXX_selectXa_bX_byXnameX_byXidX(); public abstract Traversal<Vertex, Long> get_g_V_localXoutE_countX(); public abstract Traversal<Vertex, String> get_g_VX1X_localXoutEXknowsX_limitX1XX_inV_name(final Object v1Id); public abstract Traversal<Vertex, String> get_g_V_localXbothEXcreatedX_limitX1XX_otherV_name(); public abstract Traversal<Vertex, Edge> get_g_VX4X_localXbothEX1_createdX_limitX1XX(final Object v4Id); public abstract Traversal<Vertex, Edge> get_g_VX4X_localXbothEXknows_createdX_limitX1XX(final Object v4Id); public abstract Traversal<Vertex, String> get_g_VX4X_localXbothE_limitX1XX_otherV_name(final Object v4Id); public abstract Traversal<Vertex, String> get_g_VX4X_localXbothE_limitX2XX_otherV_name(final Object v4Id); public abstract Traversal<Vertex, String> get_g_V_localXinEXknowsX_limitX2XX_outV_name(); public abstract Traversal<Vertex, Map<String, String>> get_g_V_localXmatchXproject__created_person__person_name_nameX_selectXname_projectX_by_byXnameX(); @Test @LoadGraphWith(CREW) public void g_V_localXpropertiesXlocationX_order_byXvalueX_limitX2XX_value() { final Traversal<Vertex, String> traversal = get_g_V_localXpropertiesXlocationX_order_byXvalueX_limitX2XX_value(); printTraversalForm(traversal); checkResults(Arrays.asList("brussels", "san diego", "centreville", "dulles", "baltimore", "bremen", "aachen", "kaiserslautern"), traversal); } @Test @LoadGraphWith(MODERN) public void g_V_hasXlabel_personX_asXaX_localXoutXcreatedX_asXbXX_selectXa_bX_byXnameX_by() { final Traversal<Vertex, Map<String, Object>> traversal = get_g_V_hasXlabel_personX_asXaX_localXoutXcreatedX_asXbXX_selectXa_bX_byXnameX_byXidX(); printTraversalForm(traversal); int counter = 0; while (traversal.hasNext()) { final Map<String, Object> map = traversal.next(); counter++; assertEquals(2, map.size()); if (map.get("a").equals("marko")) { assertEquals(convertToVertexId("lop"), map.get("b")); } else if (map.get("a").equals("josh")) { assertTrue(convertToVertexId("lop").equals(map.get("b")) || convertToVertexId("ripple").equals(map.get("b"))); } else if (map.get("a").equals("peter")) { assertEquals(convertToVertexId("lop"), map.get("b")); } else { fail("The following map should not have been returned: " + map); } } assertEquals(4, counter); } @Test @LoadGraphWith(MODERN) public void g_V_localXoutE_countX() { final Traversal<Vertex, Long> traversal = get_g_V_localXoutE_countX(); printTraversalForm(traversal); checkResults(Arrays.asList(3l, 0l, 0l, 0l, 1l, 2l), traversal); } @Test @LoadGraphWith(MODERN) public void g_VX4X_localXbothEXknows_createdX_limitX1XX() { final Traversal<Vertex, Edge> traversal = get_g_VX4X_localXbothEXknows_createdX_limitX1XX(convertToVertexId("josh")); printTraversalForm(traversal); final Edge edge = traversal.next(); assertTrue(edge.label().equals("created") || edge.label().equals("knows")); assertTrue(edge.value("weight").equals(1.0d) || edge.value("weight").equals(0.4d)); assertFalse(traversal.hasNext()); } @Test @LoadGraphWith(MODERN) public void g_VX4X_localXbothE_limitX1XX_otherV_name() { final Traversal<Vertex, String> traversal = get_g_VX4X_localXbothE_limitX1XX_otherV_name(convertToVertexId("josh")); printTraversalForm(traversal); int counter = 0; while (traversal.hasNext()) { counter++; final String name = traversal.next(); assertTrue(name.equals("marko") || name.equals("ripple") || name.equals("lop")); } assertEquals(1, counter); assertFalse(traversal.hasNext()); } @Test @LoadGraphWith(MODERN) public void g_VX4X_localXbothE_limitX2XX_otherV_name() { final Traversal<Vertex, String> traversal = get_g_VX4X_localXbothE_limitX2XX_otherV_name(convertToVertexId("josh")); printTraversalForm(traversal); int counter = 0; while (traversal.hasNext()) { counter++; final String name = traversal.next(); assertTrue(name.equals("marko") || name.equals("ripple") || name.equals("lop")); } assertEquals(2, counter); assertFalse(traversal.hasNext()); } @Test @LoadGraphWith(MODERN) public void g_V_localXinEXknowsX_limitX2XX_outV_name() { final Traversal<Vertex, String> traversal = get_g_V_localXinEXknowsX_limitX2XX_outV_name(); printTraversalForm(traversal); int counter = 0; while (traversal.hasNext()) { counter++; assertEquals(traversal.next(), "marko"); } assertFalse(traversal.hasNext()); assertEquals(2, counter); } @Test @LoadGraphWith(MODERN) public void g_VX4X_localXbothEX1_createdX_limitX1XX() { final Traversal<Vertex, Edge> traversal = get_g_VX4X_localXbothEX1_createdX_limitX1XX(convertToVertexId("josh")); printTraversalForm(traversal); final Edge edge = traversal.next(); assertEquals("created", edge.label()); assertTrue(edge.value("weight").equals(1.0d) || edge.value("weight").equals(0.4d)); assertFalse(traversal.hasNext()); } @Test @LoadGraphWith(MODERN) public void g_VX1X_localXoutEXknowsX_limitX1XX_inV_name() { final Traversal<Vertex, String> traversal = get_g_VX1X_localXoutEXknowsX_limitX1XX_inV_name(convertToVertexId("marko")); printTraversalForm(traversal); final String name = traversal.next(); assertTrue(name.equals("vadas") || name.equals("josh")); assertFalse(traversal.hasNext()); } @Test @LoadGraphWith(MODERN) public void g_V_localXbothEXcreatedX_limitX1XX_otherV_name() { final Traversal<Vertex, String> traversal = get_g_V_localXbothEXcreatedX_limitX1XX_otherV_name(); printTraversalForm(traversal); int counter = 0; while (traversal.hasNext()) { counter++; final String name = traversal.next(); assertTrue(name.equals("marko") || name.equals("lop") || name.equals("josh") || name.equals("ripple") || name.equals("peter")); } assertEquals(5, counter); } @Test @LoadGraphWith(MODERN) public void g_V_localXmatchXproject__created_person__person_name_nameX_selectXname_projectX_by_byXnameX() { final Traversal<Vertex, Map<String, String>> traversal = get_g_V_localXmatchXproject__created_person__person_name_nameX_selectXname_projectX_by_byXnameX(); printTraversalForm(traversal); checkResults(makeMapList(2, "name", "marko", "project", "lop", "name", "josh", "project", "lop", "name", "peter", "project", "lop", "name", "josh", "project", "ripple"), traversal); assertFalse(traversal.hasNext()); } public static class Traversals extends LocalTest { @Override public Traversal<Vertex, String> get_g_V_localXpropertiesXlocationX_order_byXvalueX_limitX2XX_value() { return g.V().local(properties("location").order().by(T.value, Order.incr).range(0, 2)).value(); } @Override public Traversal<Vertex, Map<String, Object>> get_g_V_hasXlabel_personX_asXaX_localXoutXcreatedX_asXbXX_selectXa_bX_byXnameX_byXidX() { return g.V().has(T.label, "person").as("a").local(out("created").as("b")).select("a", "b").by("name").by(T.id); } @Override public Traversal<Vertex, Long> get_g_V_localXoutE_countX() { return g.V().local(outE().count()); } @Override public Traversal<Vertex, String> get_g_VX1X_localXoutEXknowsX_limitX1XX_inV_name(final Object v1Id) { return g.V(v1Id).local(outE("knows").limit(1)).inV().values("name"); } @Override public Traversal<Vertex, String> get_g_V_localXbothEXcreatedX_limitX1XX_otherV_name() { return g.V().local(bothE("created").limit(1)).otherV().values("name"); } @Override public Traversal<Vertex, Edge> get_g_VX4X_localXbothEX1_createdX_limitX1XX(final Object v4Id) { return g.V(v4Id).local(bothE("created").limit(1)); } @Override public Traversal<Vertex, Edge> get_g_VX4X_localXbothEXknows_createdX_limitX1XX(final Object v4Id) { return g.V(v4Id).local(bothE("knows", "created").limit(1)); } @Override public Traversal<Vertex, String> get_g_VX4X_localXbothE_limitX1XX_otherV_name(final Object v4Id) { return g.V(v4Id).local(bothE().limit(1)).otherV().values("name"); } @Override public Traversal<Vertex, String> get_g_VX4X_localXbothE_limitX2XX_otherV_name(final Object v4Id) { return g.V(v4Id).local(bothE().limit(2)).otherV().values("name"); } @Override public Traversal<Vertex, String> get_g_V_localXinEXknowsX_limitX2XX_outV_name() { return g.V().local(inE("knows").limit(2)).outV().values("name"); } @Override public Traversal<Vertex, Map<String, String>> get_g_V_localXmatchXproject__created_person__person_name_nameX_selectXname_projectX_by_byXnameX() { return g.V().local(__.match( as("project").in("created").as("person"), as("person").values("name").as("name"))) .<String>select("name", "project").by().by("name"); } } }