From a24d5d6bf5bb3dd9e6f0963f378f0c64fbd87a22 Mon Sep 17 00:00:00 2001 From: Florian Hockmann Date: Wed, 28 Feb 2024 14:23:00 +0100 Subject: [PATCH] Support new text predicates via JanusGraph Server The predicates added in #2559 were not supported by `JanusGraphPSerializer` and could thus not be used when connecting via remote to JanusGraph Server. Fixes #4275 Signed-off-by: Florian Hockmann --- .../tinkerpop/JanusGraphPSerializer.java | 27 +++++++++++++++++++ .../JanusGraphPGraphBinarySerializerTest.java | 11 +++++++- .../io/graphson/JanusGraphSONModuleTest.java | 1 + 3 files changed, 38 insertions(+), 1 deletion(-) diff --git a/janusgraph-driver/src/main/java/org/janusgraph/graphdb/tinkerpop/JanusGraphPSerializer.java b/janusgraph-driver/src/main/java/org/janusgraph/graphdb/tinkerpop/JanusGraphPSerializer.java index 0ec61b11f9..312bde90e1 100644 --- a/janusgraph-driver/src/main/java/org/janusgraph/graphdb/tinkerpop/JanusGraphPSerializer.java +++ b/janusgraph-driver/src/main/java/org/janusgraph/graphdb/tinkerpop/JanusGraphPSerializer.java @@ -52,12 +52,21 @@ public static boolean checkForJanusGraphPredicate(String predicateName) { case "geoWithin": case "geoContains": case "textContains": + case "textNotContains": case "textContainsFuzzy": + case "textNotContainsFuzzy": case "textContainsPrefix": + case "textNotContainsPrefix": case "textContainsRegex": + case "textNotContainsRegex": + case "textContainsPhrase": + case "textNotContainsPhrase": case "textFuzzy": + case "textNotFuzzy": case "textPrefix": + case "textNotPrefix": case "textRegex": + case "textNotRegex": return true; default: return false; @@ -76,18 +85,36 @@ public static JanusGraphP createPredicateWithValue(String predicateName, Object return Geo.geoContains(value); case "textContains": return Text.textContains(value); + case "textNotContains": + return Text.textNotContains(value); case "textContainsFuzzy": return Text.textContainsFuzzy(value); + case "textNotContainsFuzzy": + return Text.textNotContainsFuzzy(value); case "textContainsPrefix": return Text.textContainsPrefix(value); + case "textNotContainsPrefix": + return Text.textNotContainsPrefix(value); case "textContainsRegex": return Text.textContainsRegex(value); + case "textNotContainsRegex": + return Text.textNotContainsRegex(value); + case "textContainsPhrase": + return Text.textContainsPhrase(value); + case "textNotContainsPhrase": + return Text.textNotContainsPhrase(value); case "textFuzzy": return Text.textFuzzy(value); + case "textNotFuzzy": + return Text.textNotFuzzy(value); case "textPrefix": return Text.textPrefix(value); + case "textNotPrefix": + return Text.textNotPrefix(value); case "textRegex": return Text.textRegex(value); + case "textNotRegex": + return Text.textNotRegex(value); default: throw new UnsupportedOperationException("Matched predicate {" + predicateName + "} is not support by JanusGraphPSerializer"); } diff --git a/janusgraph-driver/src/test/java/org/janusgraph/graphdb/tinkerpop/io/binary/JanusGraphPGraphBinarySerializerTest.java b/janusgraph-driver/src/test/java/org/janusgraph/graphdb/tinkerpop/io/binary/JanusGraphPGraphBinarySerializerTest.java index 4b017cbf12..efafa5ff4b 100644 --- a/janusgraph-driver/src/test/java/org/janusgraph/graphdb/tinkerpop/io/binary/JanusGraphPGraphBinarySerializerTest.java +++ b/janusgraph-driver/src/test/java/org/janusgraph/graphdb/tinkerpop/io/binary/JanusGraphPGraphBinarySerializerTest.java @@ -53,12 +53,21 @@ private static Stream janusGraphPProvider() { Geo.geoDisjoint(Geoshape.circle(37.97, 23.72, 50)), Geo.geoContains(Geoshape.point(37.97, 23.72)), Text.textContains("neptune"), + Text.textNotContains("neptune"), Text.textContainsPrefix("nep"), + Text.textNotContainsPrefix("nep"), Text.textContainsRegex("nep.*"), + Text.textNotContainsRegex("nep.*"), + Text.textContainsPhrase("neptune,pluto"), + Text.textNotContainsPhrase("neptune,pluto"), Text.textPrefix("n"), + Text.textNotPrefix("n"), Text.textRegex(".*n.*"), + Text.textNotRegex(".*n.*"), Text.textContainsFuzzy("neptun"), - Text.textFuzzy("nepitne") + Text.textNotContainsFuzzy("neptun"), + Text.textFuzzy("nepitne"), + Text.textNotFuzzy("nepitne") ); } diff --git a/janusgraph-driver/src/test/java/org/janusgraph/graphdb/tinkerpop/io/graphson/JanusGraphSONModuleTest.java b/janusgraph-driver/src/test/java/org/janusgraph/graphdb/tinkerpop/io/graphson/JanusGraphSONModuleTest.java index 31cffb1c77..4893b2cdcb 100644 --- a/janusgraph-driver/src/test/java/org/janusgraph/graphdb/tinkerpop/io/graphson/JanusGraphSONModuleTest.java +++ b/janusgraph-driver/src/test/java/org/janusgraph/graphdb/tinkerpop/io/graphson/JanusGraphSONModuleTest.java @@ -67,6 +67,7 @@ public void testJanusGraphPredicatesAsGraphSON(GraphSONVersion graphSONVersion) g.E().has("place", Geo.geoDisjoint(Geoshape.circle(37.97, 23.72, 50))), g.V().has("place", Geo.geoContains(Geoshape.point(37.97, 23.72))), g.V().has("name", Text.textContains("neptune")), g.V().has("name", Text.textContainsPrefix("nep")), + g.V().has("name", Text.textNotContains("neptune")), g.V().has("name", Text.textNotContainsPrefix("nep")), g.V().has("name", Text.textContainsRegex("nep.*")), g.V().has("name", Text.textPrefix("n")), g.V().has("name", Text.textRegex(".*n.*")), g.V().has("name", Text.textContainsFuzzy("neptun")), g.V().has("name", Text.textFuzzy("nepitne")) };