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

org.umlg.sqlg.test.batch.TestBatchNormalUpdateDateTimeArrays 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.*;
import org.umlg.sqlg.structure.SqlgGraph;
import org.umlg.sqlg.test.BaseTest;

import java.time.*;
import java.time.temporal.ChronoUnit;
import java.util.ArrayList;
import java.util.List;

/**
 * Date: 2017/01/26
 * Time: 12:22 PM
 */
public class TestBatchNormalUpdateDateTimeArrays 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 testUpdateLocalDateTimeArray() throws InterruptedException {
        Assume.assumeTrue(this.sqlgGraph.getSqlDialect().supportsLocalDateTimeArrayValues());
        this.sqlgGraph.tx().normalBatchModeOn();
        LocalDateTime[] localDateTimeArray = new LocalDateTime[]{LocalDateTime.now(), LocalDateTime.now()};
        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "localDateTimeArray1", localDateTimeArray);
        Vertex a2 = this.sqlgGraph.addVertex(T.label, "A", "localDateTimeArray2", localDateTimeArray);
        Vertex a3 = this.sqlgGraph.addVertex(T.label, "A", "localDateTimeArray3", localDateTimeArray);
        this.sqlgGraph.tx().commit();

        this.sqlgGraph.tx().normalBatchModeOn();
        LocalDateTime[] localDateTimeArrayAgain = new LocalDateTime[]{
                isHsqldb() ? LocalDateTime.now().plusDays(1).truncatedTo(ChronoUnit.MILLIS) : LocalDateTime.now().plusDays(1),
                isHsqldb() ? LocalDateTime.now().plusDays(2).truncatedTo(ChronoUnit.MILLIS) : LocalDateTime.now().plusDays(2)
        };
        a1.property("localDateTimeArray1", localDateTimeArrayAgain);
        a2.property("localDateTimeArray2", localDateTimeArrayAgain);
        a3.property("localDateTimeArray3", localDateTimeArrayAgain);
        this.sqlgGraph.tx().commit();

        testUpdateLocalDateTimeArray_assert(this.sqlgGraph, a1, a2, a3, localDateTimeArrayAgain);
        if (this.sqlgGraph1 != null) {
            Thread.sleep(SLEEP_TIME);
            testUpdateLocalDateTimeArray_assert(this.sqlgGraph1, a1, a2, a3, localDateTimeArrayAgain);
        }

    }

    private void testUpdateLocalDateTimeArray_assert(SqlgGraph sqlgGraph, Vertex a1, Vertex a2, Vertex a3, LocalDateTime[] localDateTimeArrayAgain) {
        a1 = sqlgGraph.traversal().V(a1.id()).next();
        a2 = sqlgGraph.traversal().V(a2.id()).next();
        a3 = sqlgGraph.traversal().V(a3.id()).next();
        Assert.assertArrayEquals(localDateTimeArrayAgain, a1.value("localDateTimeArray1"));
        Assert.assertFalse(a1.property("localDateTimeArray2").isPresent());
        Assert.assertFalse(a1.property("localDateTimeArray3").isPresent());

        Assert.assertFalse(a2.property("localDateTimeArray1").isPresent());
        Assert.assertArrayEquals(localDateTimeArrayAgain, a2.value("localDateTimeArray2"));
        Assert.assertFalse(a2.property("localDateTimeArray3").isPresent());

        Assert.assertFalse(a3.property("localDateTimeArray1").isPresent());
        Assert.assertFalse(a3.property("localDateTimeArray2").isPresent());
        Assert.assertArrayEquals(localDateTimeArrayAgain, a3.value("localDateTimeArray3"));
    }

    @Test
    public void testUpdateLocalDateArray() throws InterruptedException {
        Assume.assumeTrue(this.sqlgGraph.getSqlDialect().supportsLocalDateArrayValues());
        this.sqlgGraph.tx().normalBatchModeOn();
        LocalDate[] localDateArray = new LocalDate[]{LocalDate.now(), LocalDate.now()};
        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "localDateArray1", localDateArray);
        Vertex a2 = this.sqlgGraph.addVertex(T.label, "A", "localDateArray2", localDateArray);
        Vertex a3 = this.sqlgGraph.addVertex(T.label, "A", "localDateArray3", localDateArray);
        this.sqlgGraph.tx().commit();

        this.sqlgGraph.tx().normalBatchModeOn();
        LocalDate[] localDateArrayAgain = new LocalDate[]{LocalDate.now().plusDays(1), LocalDate.now().plusDays(2)};
        a1.property("localDateArray1", localDateArrayAgain);
        a2.property("localDateArray2", localDateArrayAgain);
        a3.property("localDateArray3", localDateArrayAgain);
        this.sqlgGraph.tx().commit();

        testUpdateLocalDateArray_assert(this.sqlgGraph, a1, a2, a3, localDateArrayAgain);
        if (this.sqlgGraph1 != null) {
            Thread.sleep(SLEEP_TIME);
            testUpdateLocalDateArray_assert(this.sqlgGraph1, a1, a2, a3, localDateArrayAgain);
        }

    }

    private void testUpdateLocalDateArray_assert(SqlgGraph sqlgGraph, Vertex a1, Vertex a2, Vertex a3, LocalDate[] localDateArrayAgain) {
        a1 = sqlgGraph.traversal().V(a1.id()).next();
        a2 = sqlgGraph.traversal().V(a2.id()).next();
        a3 = sqlgGraph.traversal().V(a3.id()).next();
        Assert.assertArrayEquals(localDateArrayAgain, a1.value("localDateArray1"));
        Assert.assertFalse(a1.property("localDateArray2").isPresent());
        Assert.assertFalse(a1.property("localDateArray3").isPresent());

        Assert.assertFalse(a2.property("localDateArray1").isPresent());
        Assert.assertArrayEquals(localDateArrayAgain, a2.value("localDateArray2"));
        Assert.assertFalse(a2.property("localDateArray3").isPresent());

        Assert.assertFalse(a3.property("localDateArray1").isPresent());
        Assert.assertFalse(a3.property("localDateArray2").isPresent());
        Assert.assertArrayEquals(localDateArrayAgain, a3.value("localDateArray3"));
    }

    @Test
    public void testUpdateLocalTimeArray() {
        Assume.assumeTrue(this.sqlgGraph.getSqlDialect().supportsLocalTimeArrayValues());
        this.sqlgGraph.tx().normalBatchModeOn();
        LocalTime[] localTimeArray = new LocalTime[]{LocalTime.now(), LocalTime.now()};
        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "localTimeArray1", localTimeArray);
        Vertex a2 = this.sqlgGraph.addVertex(T.label, "A", "localTimeArray2", localTimeArray);
        Vertex a3 = this.sqlgGraph.addVertex(T.label, "A", "localTimeArray3", localTimeArray);
        this.sqlgGraph.tx().commit();

        this.sqlgGraph.tx().normalBatchModeOn();
        LocalTime[] localTimeArrayAgain = new LocalTime[]{LocalTime.now().plusHours(1), LocalTime.now().plusHours(2)};
        a1.property("localTimeArray1", localTimeArrayAgain);
        a2.property("localTimeArray2", localTimeArrayAgain);
        a3.property("localTimeArray3", localTimeArrayAgain);
        this.sqlgGraph.tx().commit();

        testUpdateLocalTimeArray_assert(this.sqlgGraph, a1, a2, a3, localTimeArrayAgain);

    }

    private void testUpdateLocalTimeArray_assert(SqlgGraph sqlgGraph, Vertex a1, Vertex a2, Vertex a3, LocalTime[] localTimeArrayAgain) {
        a1 = sqlgGraph.traversal().V(a1.id()).next();
        a2 = sqlgGraph.traversal().V(a2.id()).next();
        a3 = sqlgGraph.traversal().V(a3.id()).next();

        List localTimes1 = new ArrayList<>();
        for (LocalTime localTime : localTimeArrayAgain) {
            localTimes1.add(localTime.minusNanos(localTime.getNano()));
        }
        Assert.assertArrayEquals(localTimes1.toArray(), a1.value("localTimeArray1"));
        Assert.assertFalse(a1.property("localTimeArray2").isPresent());
        Assert.assertFalse(a1.property("localTimeArray3").isPresent());

        Assert.assertFalse(a2.property("localTimeArray1").isPresent());
        Assert.assertArrayEquals(localTimes1.toArray(), a2.value("localTimeArray2"));
        Assert.assertFalse(a2.property("localTimeArray3").isPresent());

        Assert.assertFalse(a3.property("localTimeArray1").isPresent());
        Assert.assertFalse(a3.property("localTimeArray2").isPresent());
        Assert.assertArrayEquals(localTimes1.toArray(), a3.value("localTimeArray3"));
    }

    @Test
    public void testUpdateZonedDateTimeArray() throws InterruptedException {
        Assume.assumeTrue(this.sqlgGraph.getSqlDialect().supportsZonedDateTimeArrayValues());
        this.sqlgGraph.tx().normalBatchModeOn();
        ZonedDateTime[] zonedDateTimeArray = new ZonedDateTime[]{ZonedDateTime.now(), ZonedDateTime.now()};
        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "zonedDateTimeArray1", zonedDateTimeArray);
        Vertex a2 = this.sqlgGraph.addVertex(T.label, "A", "zonedDateTimeArray2", zonedDateTimeArray);
        Vertex a3 = this.sqlgGraph.addVertex(T.label, "A", "zonedDateTimeArray3", zonedDateTimeArray);
        this.sqlgGraph.tx().commit();

        this.sqlgGraph.tx().normalBatchModeOn();
        ZonedDateTime[] zonedDateTimeArrayAgain = new ZonedDateTime[]{
                isHsqldb() ? ZonedDateTime.now().plusHours(1).truncatedTo(ChronoUnit.MILLIS) : ZonedDateTime.now().plusHours(1),
                isHsqldb() ? ZonedDateTime.now().plusHours(2).truncatedTo(ChronoUnit.MILLIS) : ZonedDateTime.now().plusHours(2)
        };
        a1.property("zonedDateTimeArray1", zonedDateTimeArrayAgain);
        a2.property("zonedDateTimeArray2", zonedDateTimeArrayAgain);
        a3.property("zonedDateTimeArray3", zonedDateTimeArrayAgain);
        this.sqlgGraph.tx().commit();

        testUpdateZonedDateTimeArray_assert(this.sqlgGraph, a1, a2, a3, zonedDateTimeArrayAgain);
        if (this.sqlgGraph1 != null) {
            Thread.sleep(SLEEP_TIME);
            testUpdateZonedDateTimeArray_assert(this.sqlgGraph1, a1, a2, a3, zonedDateTimeArrayAgain);
        }
    }

    private void testUpdateZonedDateTimeArray_assert(SqlgGraph sqlgGraph, Vertex a1, Vertex a2, Vertex a3, ZonedDateTime[] zonedDateTimeArrayAgain) {
        a1 = sqlgGraph.traversal().V(a1.id()).next();
        a2 = sqlgGraph.traversal().V(a2.id()).next();
        a3 = sqlgGraph.traversal().V(a3.id()).next();

        Assert.assertArrayEquals(zonedDateTimeArrayAgain, a1.value("zonedDateTimeArray1"));
        Assert.assertFalse(a1.property("zonedDateTimeArray2").isPresent());
        Assert.assertFalse(a1.property("zonedDateTimeArray3").isPresent());

        Assert.assertFalse(a2.property("zonedDateTimeArray1").isPresent());
        Assert.assertArrayEquals(zonedDateTimeArrayAgain, a2.value("zonedDateTimeArray2"));
        Assert.assertFalse(a2.property("zonedDateTimeArray3").isPresent());

        Assert.assertFalse(a3.property("zonedDateTimeArray1").isPresent());
        Assert.assertFalse(a3.property("zonedDateTimeArray2").isPresent());
        Assert.assertArrayEquals(zonedDateTimeArrayAgain, a3.value("zonedDateTimeArray3"));
    }

    @Test
    public void testUpdateDurationArray() throws InterruptedException {
        Assume.assumeTrue(this.sqlgGraph.getSqlDialect().supportsDurationArrayValues());
        this.sqlgGraph.tx().normalBatchModeOn();
        Duration[] durationArray = new Duration[]{Duration.ofDays(1), Duration.ofDays(1)};
        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "durationArray1", durationArray);
        Vertex a2 = this.sqlgGraph.addVertex(T.label, "A", "durationArray2", durationArray);
        Vertex a3 = this.sqlgGraph.addVertex(T.label, "A", "durationArray3", durationArray);
        this.sqlgGraph.tx().commit();

        this.sqlgGraph.tx().normalBatchModeOn();
        Duration[] durationArrayAgain = new Duration[]{Duration.ofDays(3), Duration.ofDays(4)};
        a1.property("durationArray1", durationArrayAgain);
        a2.property("durationArray2", durationArrayAgain);
        a3.property("durationArray3", durationArrayAgain);
        this.sqlgGraph.tx().commit();

        testUpdateDurationArray_assert(this.sqlgGraph, a1, a2, a3, durationArrayAgain);
        if (this.sqlgGraph1 != null) {
            Thread.sleep(SLEEP_TIME);
            testUpdateDurationArray_assert(this.sqlgGraph1, a1, a2, a3, durationArrayAgain);
        }
    }

    private void testUpdateDurationArray_assert(SqlgGraph sqlgGraph, Vertex a1, Vertex a2, Vertex a3, Duration[] durationArrayAgain) {
        a1 = sqlgGraph.traversal().V(a1.id()).next();
        a2 = sqlgGraph.traversal().V(a2.id()).next();
        a3 = sqlgGraph.traversal().V(a3.id()).next();

        Assert.assertArrayEquals(durationArrayAgain, a1.value("durationArray1"));
        Assert.assertFalse(a1.property("durationArray2").isPresent());
        Assert.assertFalse(a1.property("durationArray3").isPresent());

        Assert.assertFalse(a2.property("durationArray1").isPresent());
        Assert.assertArrayEquals(durationArrayAgain, a2.value("durationArray2"));
        Assert.assertFalse(a2.property("durationArray3").isPresent());

        Assert.assertFalse(a3.property("durationArray1").isPresent());
        Assert.assertFalse(a3.property("durationArray2").isPresent());
        Assert.assertArrayEquals(durationArrayAgain, a3.value("durationArray3"));
    }

    @Test
    public void testUpdatePeriodArray() throws InterruptedException {
        Assume.assumeTrue(this.sqlgGraph.getSqlDialect().supportsPeriodArrayValues());
        this.sqlgGraph.tx().normalBatchModeOn();
        Period[] periodArray = new Period[]{Period.of(1, 1, 1), Period.of(1, 1, 1)};
        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "periodArray1", periodArray);
        Vertex a2 = this.sqlgGraph.addVertex(T.label, "A", "periodArray2", periodArray);
        Vertex a3 = this.sqlgGraph.addVertex(T.label, "A", "periodArray3", periodArray);
        this.sqlgGraph.tx().commit();

        this.sqlgGraph.tx().normalBatchModeOn();
        Period[] periodArrayAgain = new Period[]{Period.of(2, 2, 2), Period.of(4, 4, 4)};
        a1.property("periodArray1", periodArrayAgain);
        a2.property("periodArray2", periodArrayAgain);
        a3.property("periodArray3", periodArrayAgain);
        this.sqlgGraph.tx().commit();

        testUpdatePeriodArray_assert(this.sqlgGraph, a1, a2, a3, periodArrayAgain);
        if (this.sqlgGraph1 != null) {
            Thread.sleep(SLEEP_TIME);
            testUpdatePeriodArray_assert(this.sqlgGraph1, a1, a2, a3, periodArrayAgain);
        }
    }

    private void testUpdatePeriodArray_assert(SqlgGraph sqlgGraph, Vertex a1, Vertex a2, Vertex a3, Period[] periodArrayAgain) {
        a1 = sqlgGraph.traversal().V(a1.id()).next();
        a2 = sqlgGraph.traversal().V(a2.id()).next();
        a3 = sqlgGraph.traversal().V(a3.id()).next();

        Assert.assertArrayEquals(periodArrayAgain, a1.value("periodArray1"));
        Assert.assertFalse(a1.property("periodArray2").isPresent());
        Assert.assertFalse(a1.property("periodArray3").isPresent());

        Assert.assertFalse(a2.property("periodArray1").isPresent());
        Assert.assertArrayEquals(periodArrayAgain, a2.value("periodArray2"));
        Assert.assertFalse(a2.property("periodArray3").isPresent());

        Assert.assertFalse(a3.property("periodArray1").isPresent());
        Assert.assertFalse(a3.property("periodArray2").isPresent());
        Assert.assertArrayEquals(periodArrayAgain, a3.value("periodArray3"));
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy