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

org.umlg.sqlg.test.batch.TestBatchEdgeWithMultipleOutLabels Maven / Gradle / Ivy

package org.umlg.sqlg.test.batch;

import org.apache.tinkerpop.gremlin.structure.T;
import org.apache.tinkerpop.gremlin.structure.Vertex;
import org.junit.Assume;
import org.junit.Before;
import org.junit.BeforeClass;
import org.junit.Test;
import org.umlg.sqlg.structure.SqlgGraph;
import org.umlg.sqlg.test.BaseTest;

import java.util.UUID;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertTrue;

/**
 * Date: 2016/08/09
 * Time: 9:10 AM
 */
public class TestBatchEdgeWithMultipleOutLabels extends BaseTest {

    @BeforeClass
    public static void beforeClass() {
        BaseTest.beforeClass();
        if (isPostgres()) {
            configuration.addProperty("distributed", true);
        }
    }

    @Before
    public void beforeTest() {
        Assume.assumeTrue(this.sqlgGraph.getSqlDialect().supportsBatchMode());
    }

    @Test
    public void testBatchModeEdgeMultipleOutLabels() throws InterruptedException {
        sqlgGraph.tx().normalBatchModeOn();
        for (int i = 0; i < 5; i++) {
            Vertex a1 = this.sqlgGraph.addVertex(T.label, "A1");
            Vertex a2  = this.sqlgGraph.addVertex(T.label, "A2");
            Vertex b = this.sqlgGraph.addVertex(T.label, "B");
            a1.addEdge("address", b);
            a2.addEdge("address", b);
        }
        this.sqlgGraph.tx().commit();
        assertEquals(5, this.sqlgGraph.traversal().V().hasLabel("A1").count().next().intValue());
        assertEquals(5, this.sqlgGraph.traversal().V().hasLabel("A2").count().next().intValue());
        assertEquals(5, this.sqlgGraph.traversal().V().hasLabel("A1").out("address").count().next().intValue());
        assertEquals(5, this.sqlgGraph.traversal().V().hasLabel("A2").out("address").count().next().intValue());

        sqlgGraph.tx().normalBatchModeOn();
        for (int i = 0; i < 5; i++) {
            Vertex a1 = this.sqlgGraph.addVertex(T.label, "A1");
            Vertex a2  = this.sqlgGraph.addVertex(T.label, "A2");
            Vertex b = this.sqlgGraph.addVertex(T.label, "B");
            a1.addEdge("address", b);
            a2.addEdge("address", b);
        }
        this.sqlgGraph.tx().commit();
        testBatchModeEdgeMulitpleOutLabels_assert(this.sqlgGraph);
        if (this.sqlgGraph1 != null) {
            Thread.sleep(SLEEP_TIME);
            testBatchModeEdgeMulitpleOutLabels_assert(this.sqlgGraph1);
        }
    }

    private void testBatchModeEdgeMulitpleOutLabels_assert(SqlgGraph sqlgGraph) {
        assertEquals(10, sqlgGraph.traversal().V().hasLabel("A1").count().next().intValue());
        assertEquals(10, sqlgGraph.traversal().V().hasLabel("A2").count().next().intValue());
        assertEquals(10, sqlgGraph.traversal().V().hasLabel("A1").out("address").count().next().intValue());
        assertEquals(10, sqlgGraph.traversal().V().hasLabel("A2").out("address").count().next().intValue());
    }

    @Test
    public void issue57() throws InterruptedException {
        sqlgGraph.tx().normalBatchModeOn();
        String key = "AbstractTinkerPopFhirGraph.Prop.ID";
        int indexCount = 100;
        for (int index = 0; index < indexCount; index++) {
            Vertex v1 = sqlgGraph.addVertex(T.label, "Patient", key, index);
            Vertex v2 = sqlgGraph.addVertex(T.label, "HumanNameDt", key, UUID.randomUUID().toString());
            v1.addEdge("name", v2);

            Vertex v3 = sqlgGraph.addVertex(T.label, "Condition", key, index);
            Vertex v4 = sqlgGraph.addVertex(T.label, "CodeableConceptDt", key, UUID.randomUUID().toString());
            Vertex v5 = sqlgGraph.addVertex(T.label, "CodingDt", key, UUID.randomUUID().toString());
            v3.addEdge("code", v4);
            v4.addEdge("coding", v5);

            v3.addEdge("patient", v1);

            Vertex v6 = sqlgGraph.addVertex(T.label, "CodeableConcept", key, UUID.randomUUID().toString());
            v3.addEdge("category", v6);

            Vertex v7 = sqlgGraph.addVertex(T.label, "CodingDt", key, UUID.randomUUID().toString());
            v6.addEdge("coding", v7);
        }
        sqlgGraph.tx().commit();

        testIssue57_assert(this.sqlgGraph, indexCount);
        if (this.sqlgGraph1 != null) {
            Thread.sleep(SLEEP_TIME);
            testIssue57_assert(this.sqlgGraph1, indexCount);
        }

    }

    private void testIssue57_assert(SqlgGraph sqlgGraph, int indexCount) {
        assertEquals(indexCount, sqlgGraph.traversal().V().hasLabel("Patient").count().next().intValue());
        assertEquals(indexCount, sqlgGraph.traversal().V().hasLabel("HumanNameDt").count().next().intValue());
        assertEquals(indexCount, sqlgGraph.traversal().V().hasLabel("Patient").out("name").count().next().intValue());
        sqlgGraph.traversal().V().hasLabel("Patient").out("name").forEachRemaining(v -> assertTrue(v.label().equals("HumanNameDt")));

        assertEquals(indexCount, sqlgGraph.traversal().V().hasLabel("Condition").count().next().intValue());
        assertEquals(indexCount, sqlgGraph.traversal().V().hasLabel("CodeableConceptDt").count().next().intValue());
        assertEquals(indexCount * 2, sqlgGraph.traversal().V().hasLabel("CodingDt").count().next().intValue());
        assertEquals(indexCount, sqlgGraph.traversal().V().hasLabel("Condition").out("code").count().next().intValue());
        assertEquals(indexCount, sqlgGraph.traversal().V().hasLabel("CodeableConceptDt").out("coding").count().next().intValue());

        sqlgGraph.traversal().V().hasLabel("Condition").out("code").forEachRemaining(v -> assertTrue(v.label().equals("CodeableConceptDt")));
        sqlgGraph.traversal().V().hasLabel("Condition").out("coding").forEachRemaining(v -> assertTrue(v.label().equals("CodingDt")));
        sqlgGraph.traversal().V().hasLabel("Condition").out("patient").forEachRemaining(v -> assertTrue(v.label().equals("Patient")));

        assertEquals(indexCount, sqlgGraph.traversal().V().hasLabel("CodeableConcept").count().next().intValue());
        assertEquals(indexCount, sqlgGraph.traversal().V().hasLabel("Condition").out("category").count().next().intValue());
        sqlgGraph.traversal().V().hasLabel("Condition").out("category").forEachRemaining(v -> assertTrue(v.label().equals("CodeableConcept")));

        assertEquals(indexCount, sqlgGraph.traversal().V().hasLabel("CodeableConcept").out("coding").count().next().intValue());
        sqlgGraph.traversal().V().hasLabel("CodeableConcept").out("coding").forEachRemaining(v -> assertTrue(v.label().equals("CodingDt")));
    }


}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy