From efe3c328ccc45579bdfab842de944f0cf5743f86 Mon Sep 17 00:00:00 2001 From: Boxuan Li Date: Wed, 28 Feb 2024 21:37:14 -0800 Subject: [PATCH] Fix io step read path for string-type vertex ID g.io(path).read() would fail if the vertex contains custom string-type vertex ID due to a bug in JanusGraphVertexFeatures. This fixes this bug and adds two unit tests for gryo and graphson format. Signed-off-by: Boxuan Li (cherry picked from commit ce1742880f37d9d1dd03a0c5b4d5d180e918a15f) --- .../graphdb/JanusGraphCustomIdTest.java | 44 +++++++++++++++++++ .../graphdb/tinkerpop/JanusGraphFeatures.java | 2 +- 2 files changed, 45 insertions(+), 1 deletion(-) diff --git a/janusgraph-backend-testutils/src/main/java/org/janusgraph/graphdb/JanusGraphCustomIdTest.java b/janusgraph-backend-testutils/src/main/java/org/janusgraph/graphdb/JanusGraphCustomIdTest.java index 503e026b27..7429a40bf4 100644 --- a/janusgraph-backend-testutils/src/main/java/org/janusgraph/graphdb/JanusGraphCustomIdTest.java +++ b/janusgraph-backend-testutils/src/main/java/org/janusgraph/graphdb/JanusGraphCustomIdTest.java @@ -15,6 +15,7 @@ package org.janusgraph.graphdb; import com.google.common.base.Preconditions; +import org.apache.tinkerpop.gremlin.process.traversal.dsl.graph.GraphTraversalSource; import org.apache.tinkerpop.gremlin.structure.Direction; import org.apache.tinkerpop.gremlin.structure.T; import org.apache.tinkerpop.gremlin.structure.Vertex; @@ -49,7 +50,10 @@ import org.junit.jupiter.api.BeforeEach; import org.junit.jupiter.api.Test; import org.junit.jupiter.api.TestInfo; +import org.junit.jupiter.api.io.TempDir; +import java.io.File; +import java.nio.file.Path; import java.time.Duration; import java.time.temporal.ChronoUnit; import java.util.ArrayList; @@ -561,4 +565,44 @@ public void removeGhostVertices() throws Exception { assertEquals(0, result.getCustom(GhostVertexRemover.REMOVED_RELATION_COUNT)); assertEquals(0, result.getCustom(GhostVertexRemover.SKIPPED_GHOST_LIMIT_COUNT)); } + + @Test + public void testWriteAndReadWithJanusGraphIoRegistryWithGryo(@TempDir Path tempDir) { + open(true, true); + final Path file = tempDir.resolve("testgraph_" + this.getClass().getCanonicalName() + ".kryo"); + testWritingAndReading(file.toFile()); + } + + @Test + public void testWriteAndReadWithJanusGraphIoRegistryWithGraphson(@TempDir Path tempDir) { + open(true, true); + final Path file = tempDir.resolve("testgraph_" + this.getClass().getCanonicalName() + ".json"); + testWritingAndReading(file.toFile()); + } + + private void testWritingAndReading(File f) { + GraphTraversalSource g = graph.traversal(); + Vertex fromV = g.addV().property("name", f.getName()).property(T.id, "custom_id").next(); + Vertex toV = g.addV().property(T.id, "another_vertex").next(); + g.addE("connect").from(fromV).to(toV).next(); + g.tx().commit(); + assertEquals(0, f.length()); + + g.io(f.getAbsolutePath()).write().iterate(); + + assertTrue(f.length() > 0, "File " + f.getAbsolutePath() + " was expected to be not empty, but is"); + + open(true, true); + g = graph.traversal(); + g.V().drop().iterate(); + g.tx().commit(); + + g.io(f.getAbsolutePath()).read().iterate(); + + assertEquals(1, g.V().has("name", f.getName()).count().next()); + assertEquals(1, g.V("custom_id").count().next()); + assertEquals(2, g.V().count().next()); + assertEquals("connect", g.E().label().next()); + } + } diff --git a/janusgraph-core/src/main/java/org/janusgraph/graphdb/tinkerpop/JanusGraphFeatures.java b/janusgraph-core/src/main/java/org/janusgraph/graphdb/tinkerpop/JanusGraphFeatures.java index 5f99627dc9..8a02a5a2d0 100644 --- a/janusgraph-core/src/main/java/org/janusgraph/graphdb/tinkerpop/JanusGraphFeatures.java +++ b/janusgraph-core/src/main/java/org/janusgraph/graphdb/tinkerpop/JanusGraphFeatures.java @@ -197,7 +197,7 @@ public boolean supportsUuidIds() { @Override public boolean supportsStringIds() { - return false; + return JanusGraphFeatures.this.graph.getConfiguration().allowCustomVertexIdType(); } @Override