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

org.umlg.sqlg.test.schema.TestGlobalUniqueIndex Maven / Gradle / Ivy

package org.umlg.sqlg.test.schema;

import org.apache.tinkerpop.gremlin.structure.Edge;
import org.apache.tinkerpop.gremlin.structure.T;
import org.apache.tinkerpop.gremlin.structure.Vertex;
import org.junit.Assert;
import org.junit.Test;
import org.umlg.sqlg.structure.*;
import org.umlg.sqlg.structure.topology.*;
import org.umlg.sqlg.test.BaseTest;

import java.util.*;

import static org.junit.Assert.fail;

/**
 * Date: 2016/12/03
 * Time: 9:08 PM
 */
public class TestGlobalUniqueIndex extends BaseTest {

    @Test
    public void testGlobalUniqueIndexAccrossMultipleVerticesAndEdges() {
        Map properties = new HashMap<>();
        properties.put("name1", PropertyType.STRING);
        properties.put("name2", PropertyType.STRING);
        VertexLabel aVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("A", properties);
        Assert.assertTrue(aVertexLabel.isUncommitted());
        properties.clear();
        properties.put("name3", PropertyType.STRING);
        properties.put("name4", PropertyType.STRING);
        VertexLabel bVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("B", properties);
        Assert.assertTrue(bVertexLabel.isUncommitted());
        properties.clear();
        properties.put("name5", PropertyType.STRING);
        properties.put("name6", PropertyType.STRING);
        EdgeLabel edgeLabel = aVertexLabel.ensureEdgeLabelExist("ab", bVertexLabel, properties);
        Assert.assertTrue(edgeLabel.isUncommitted());
        Set globalUniqueIndexPRopertyColumns = new HashSet<>();
        globalUniqueIndexPRopertyColumns.addAll(new HashSet<>(aVertexLabel.getProperties().values()));
        globalUniqueIndexPRopertyColumns.addAll(new HashSet<>(bVertexLabel.getProperties().values()));
        globalUniqueIndexPRopertyColumns.addAll(new HashSet<>(edgeLabel.getProperties().values()));
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(globalUniqueIndexPRopertyColumns);
        this.sqlgGraph.tx().commit();
        Assert.assertFalse(aVertexLabel.isUncommitted());
        Assert.assertFalse(bVertexLabel.isUncommitted());
        Assert.assertFalse(edgeLabel.isUncommitted());
        Assert.assertEquals(1, this.sqlgGraph.getTopology().getGlobalUniqueIndexes().size());
        Assert.assertEquals("globalUniqueIndex_0", this.sqlgGraph.getTopology().getGlobalUniqueIndexes().iterator().next().getName());

        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "name1", "1", "name2", "2");
        Vertex b1 = this.sqlgGraph.addVertex(T.label, "B", "name3", "3", "name4", "4");
        a1.addEdge("ab", b1, "name5", "5", "name6", "6");
        this.sqlgGraph.tx().commit();
        try {
            a1.addEdge("ab", b1, "name5", "5", "name6", "6");
            fail("GlobalUniqueIndex should not allow this to happen");
        } catch (Exception e) {
            //swallow
            this.sqlgGraph.tx().rollback();
        }
        //This should pass
        a1.addEdge("ab", b1, "name5", "7", "name6", "8");
    }

    @Test
    public void testTopologyGlobalUniqueIndexCache() {
        Map properties = new HashMap<>();
        properties.put("namec", PropertyType.STRING);
        properties.put("namea", PropertyType.STRING);
        properties.put("nameb", PropertyType.STRING);
        this.sqlgGraph.getTopology().ensureVertexLabelExist("A", properties);
        @SuppressWarnings("OptionalGetWithoutIsPresent")
        Collection propertyColumns = this.sqlgGraph.getTopology().getPublicSchema().getVertexLabel("A").get().getProperties().values();
        Assert.assertTrue(propertyColumns.stream().allMatch(PropertyColumn::isUncommitted));
        GlobalUniqueIndex globalUniqueIndex = this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(new HashSet<>(propertyColumns));
        Assert.assertTrue(globalUniqueIndex.isUncommitted());
        Assert.assertEquals(1, this.sqlgGraph.getTopology().getGlobalUniqueIndexes().size());
        this.sqlgGraph.tx().commit();
        Assert.assertEquals(1, this.sqlgGraph.getTopology().getGlobalUniqueIndexes().size());
        Assert.assertFalse(propertyColumns.stream().allMatch(PropertyColumn::isUncommitted));
        Assert.assertFalse(globalUniqueIndex.isUncommitted());
    }

    @SuppressWarnings("OptionalGetWithoutIsPresent")
    @Test
    public void testGlobalUniqueIndexOnVertex() {
        Map properties = new HashMap<>();
        properties.put("namec", PropertyType.STRING);
        properties.put("namea", PropertyType.STRING);
        properties.put("nameb", PropertyType.STRING);
        this.sqlgGraph.getTopology().ensureVertexLabelExist("A", properties);
        @SuppressWarnings("OptionalGetWithoutIsPresent")
        Collection propertyColumns = this.sqlgGraph.getTopology().getPublicSchema().getVertexLabel("A").get().getProperties().values();
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(new HashSet<>(propertyColumns));
        this.sqlgGraph.tx().commit();

        Schema globalUniqueIndexSchema = this.sqlgGraph.getTopology().getGlobalUniqueIndexSchema();
        Optional globalUniqueIndexOptional = globalUniqueIndexSchema.getGlobalUniqueIndex("A_namea_A_nameb_A_namec");
        Assert.assertTrue(globalUniqueIndexOptional.isPresent());

        Optional nameaPropertyColumnOptional = this.sqlgGraph.getTopology().getPublicSchema().getVertexLabel("A").get().getProperty("namea");
        Assert.assertTrue(nameaPropertyColumnOptional.isPresent());
        @SuppressWarnings("OptionalGetWithoutIsPresent")
        Set globalUniqueIndices = nameaPropertyColumnOptional.get().getGlobalUniqueIndices();
        Assert.assertEquals(1, globalUniqueIndices.size());
        GlobalUniqueIndex globalUniqueIndex = globalUniqueIndices.iterator().next();
        Assert.assertEquals("A_namea_A_nameb_A_namec", globalUniqueIndex.getName());

        Vertex a = this.sqlgGraph.addVertex(T.label, "A", "namea", "a");
        this.sqlgGraph.tx().commit();
        try {
            this.sqlgGraph.addVertex(T.label, "A", "namea", "a");
            fail("GlobalUniqueIndex should prevent this from executing");
        } catch (Exception e) {
            //swallow
        }
        this.sqlgGraph.tx().rollback();
        Vertex aa = this.sqlgGraph.addVertex(T.label, "A", "namea", "aa");
        this.sqlgGraph.tx().commit();

        List globalUniqueIndexVertexes = this.sqlgGraph.globalUniqueIndexes().V().toList();
        //This is 6 because all PropertyColumns with a GlobalUniqueIndex gets a value. If no value is present then a null is inserted as the value.
        //null do not partake in the unique constraint so all is well
        Assert.assertEquals(6, globalUniqueIndexVertexes.size());
        Assert.assertTrue(globalUniqueIndexVertexes.stream().allMatch(g -> g.label().equals(Schema.GLOBAL_UNIQUE_INDEX_SCHEMA + "." + globalUniqueIndex.getName())));
        Assert.assertEquals(1, globalUniqueIndexVertexes.stream().filter(g -> g.property(GlobalUniqueIndex.GLOBAL_UNIQUE_INDEX_VALUE).isPresent() && g.value(GlobalUniqueIndex.GLOBAL_UNIQUE_INDEX_VALUE).equals("a")).count());
        Assert.assertEquals(3, globalUniqueIndexVertexes.stream().filter(g -> g.value(GlobalUniqueIndex.GLOBAL_UNIQUE_INDEX_RECORD_ID).equals(a.id().toString())).count());
        Assert.assertEquals(1, globalUniqueIndexVertexes.stream().filter(g -> g.property(GlobalUniqueIndex.GLOBAL_UNIQUE_INDEX_VALUE).isPresent() && g.value(GlobalUniqueIndex.GLOBAL_UNIQUE_INDEX_VALUE).equals("aa")).count());
        Assert.assertEquals(3, globalUniqueIndexVertexes.stream().filter(g -> g.value(GlobalUniqueIndex.GLOBAL_UNIQUE_INDEX_RECORD_ID).equals(aa.id().toString())).count());
    }

    @SuppressWarnings("OptionalGetWithoutIsPresent")
    @Test
    public void testGlobalIndexAcrossMultipleVertexLabels() {
        Map properties = new HashMap<>();
        properties.put("a", PropertyType.STRING);
        VertexLabel aVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("A", properties);
        VertexLabel bVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("B", properties);
        Set globalUniqueIndexProperties = new HashSet<>();
        globalUniqueIndexProperties.add(aVertexLabel.getProperty("a").get());
        globalUniqueIndexProperties.add(bVertexLabel.getProperty("a").get());
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(globalUniqueIndexProperties);
        this.sqlgGraph.tx().commit();
        try {
            this.sqlgGraph.addVertex(T.label, "A", "a", "123");
            this.sqlgGraph.tx().commit();
            this.sqlgGraph.addVertex(T.label, "B", "a", "123");
            fail("GlobalUniqueIndex should prevent this from happening");
        } catch (Exception e) {
            //swallow
        }
    }

    @SuppressWarnings("OptionalGetWithoutIsPresent")
    @Test
    public void testGlobalUniqueIndexOnEdge() {
        Map properties = new HashMap<>();
        properties.put("name", PropertyType.STRING);
        VertexLabel vertexLabelA = this.sqlgGraph.getTopology().ensureVertexLabelExist("A", properties);
        VertexLabel vertexLabelB = this.sqlgGraph.getTopology().ensureVertexLabelExist("B", properties);
        properties.clear();
        properties.put("namea", PropertyType.STRING);
        properties.put("nameb", PropertyType.STRING);
        properties.put("namec", PropertyType.STRING);
        vertexLabelA.ensureEdgeLabelExist("ab", vertexLabelB, properties);
        @SuppressWarnings("OptionalGetWithoutIsPresent")
        Collection propertyColumns = this.sqlgGraph.getTopology().getPublicSchema().getEdgeLabel("ab").get().getProperties().values();
        GlobalUniqueIndex globalUniqueIndex = this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(new HashSet<>(propertyColumns));
        Assert.assertNotNull(globalUniqueIndex);
        this.sqlgGraph.tx().commit();

        Schema globalUniqueIndexSchema = this.sqlgGraph.getTopology().getGlobalUniqueIndexSchema();
        Optional globalUniqueIndexOptional = globalUniqueIndexSchema.getGlobalUniqueIndex(globalUniqueIndex.getName());
        Assert.assertTrue(globalUniqueIndexOptional.isPresent());

        Optional nameaPropertyColumnOptional = this.sqlgGraph.getTopology().getPublicSchema().getEdgeLabel("ab").get().getProperty("namea");
        Assert.assertTrue(nameaPropertyColumnOptional.isPresent());
        @SuppressWarnings("OptionalGetWithoutIsPresent")
        Set globalUniqueIndices = nameaPropertyColumnOptional.get().getGlobalUniqueIndices();
        Assert.assertEquals(1, globalUniqueIndices.size());
        Assert.assertEquals(globalUniqueIndex, globalUniqueIndices.iterator().next());
        Assert.assertEquals("ab_namea_ab_nameb_ab_namec", globalUniqueIndex.getName());

        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "name", "a");
        Vertex b1 = this.sqlgGraph.addVertex(T.label, "B", "name", "b");
        Edge edge = a1.addEdge("ab", b1, "namea", "a", "nameb", "b", "namec", "c");
        this.sqlgGraph.tx().commit();
        try {
            a1 = this.sqlgGraph.addVertex(T.label, "A", "name", "a");
            b1 = this.sqlgGraph.addVertex(T.label, "B", "name", "b");
            a1.addEdge("ab", b1, "namea", "a", "nameb", "b", "namec", "c");
            fail("GlobalUniqueIndex should prevent this from executing");
        } catch (Exception e) {
            //swallow
        }
        this.sqlgGraph.tx().rollback();
        this.sqlgGraph.addVertex(T.label, "A", "namea", "aa");
        this.sqlgGraph.tx().commit();

        Assert.assertEquals(3, this.sqlgGraph.traversal().V().count().next(), 0);

        List globalUniqueIndexVertexes = this.sqlgGraph.globalUniqueIndexes().V().toList();
        Assert.assertEquals(3, globalUniqueIndexVertexes.size());
        Assert.assertTrue(globalUniqueIndexVertexes.stream().allMatch(g -> g.label().equals(Schema.GLOBAL_UNIQUE_INDEX_SCHEMA + "." + globalUniqueIndex.getName())));
        Assert.assertEquals(1, globalUniqueIndexVertexes.stream().filter(g -> g.value(GlobalUniqueIndex.GLOBAL_UNIQUE_INDEX_VALUE).equals("a")).count());
        Assert.assertEquals(1, globalUniqueIndexVertexes.stream().filter(g -> g.value(GlobalUniqueIndex.GLOBAL_UNIQUE_INDEX_VALUE).equals("b")).count());
        Assert.assertEquals(1, globalUniqueIndexVertexes.stream().filter(g -> g.value(GlobalUniqueIndex.GLOBAL_UNIQUE_INDEX_VALUE).equals("c")).count());
        Assert.assertTrue(globalUniqueIndexVertexes.stream().allMatch(g -> g.value(GlobalUniqueIndex.GLOBAL_UNIQUE_INDEX_RECORD_ID).equals(edge.id().toString())));
    }

    @SuppressWarnings("OptionalGetWithoutIsPresent")
    @Test
    public void testGlobalUniqueIndexAcrossDifferentEdges() {
        Map properties = new HashMap<>();
        properties.put("a", PropertyType.STRING);
        VertexLabel aVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("A", properties);
        VertexLabel bVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("B", properties);
        EdgeLabel abEdgeLabel = aVertexLabel.ensureEdgeLabelExist("ab", bVertexLabel, properties);
        VertexLabel cVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("C", properties);
        VertexLabel dVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("D", properties);
        EdgeLabel cdEdgeLabel = cVertexLabel.ensureEdgeLabelExist("cd", dVertexLabel, properties);

        PropertyColumn abEdgeProperty = abEdgeLabel.getProperty("a").get();
        PropertyColumn cdEdgeProperty = cdEdgeLabel.getProperty("a").get();
        Set globalUniqueIndexProperties = new HashSet<>();
        globalUniqueIndexProperties.add(abEdgeProperty);
        globalUniqueIndexProperties.add(cdEdgeProperty);
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(globalUniqueIndexProperties);
        this.sqlgGraph.tx().commit();

        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "a", "132");
        Vertex b1 = this.sqlgGraph.addVertex(T.label, "B", "a", "132");
        a1.addEdge("ab", b1, "a", "123");
        Vertex c1 = this.sqlgGraph.addVertex(T.label, "C", "a", "132");
        Vertex d1 = this.sqlgGraph.addVertex(T.label, "D", "a", "132");
        try {
            c1.addEdge("cd", d1, "a", "123");
            fail("GlobalUniqueIndex should prevent this from happening");
        } catch (Exception e) {
            //swallow
        }
    }

    @Test
    public void testVertexUniqueConstraintUpdate() {
        VertexLabel vertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("A", new HashMap() {{
            put("namea", PropertyType.STRING);
            put("nameb", PropertyType.STRING);
            put("namec", PropertyType.STRING);
        }});
        Set properties = new HashSet<>(vertexLabel.getProperties().values());
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(properties);
        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "namea", "a");
        this.sqlgGraph.tx().commit();

        a1.property("namea", "aa");
        this.sqlgGraph.tx().commit();
        try {
            //this should pass
            this.sqlgGraph.addVertex(T.label, "A", "namea", "a");
        } catch (Exception e) {
            fail("GlobalUniqueIndex should not fire");
        }
        try {
            this.sqlgGraph.addVertex(T.label, "A", "nameb", "aa");
            fail("GlobalUniqueIndex should prevent this from executing");
        } catch (Exception e) {
            //swallow
        }
    }

    @Test
    public void testEdgeUniqueConstraintUpdate() {
        Map properties = new HashMap<>();
        properties.put("name", PropertyType.STRING);
        VertexLabel vertexLabelA = this.sqlgGraph.getTopology().ensureVertexLabelExist("A", properties);
        VertexLabel vertexLabelB = this.sqlgGraph.getTopology().ensureVertexLabelExist("B", properties);
        properties.clear();
        properties.put("namea", PropertyType.STRING);
        properties.put("nameb", PropertyType.STRING);
        properties.put("namec", PropertyType.STRING);
        vertexLabelA.ensureEdgeLabelExist("ab", vertexLabelB, properties);
        @SuppressWarnings("OptionalGetWithoutIsPresent")
        Collection propertyColumns = this.sqlgGraph.getTopology().getPublicSchema().getEdgeLabel("ab").get().getProperties().values();
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(new HashSet<>(propertyColumns));
        this.sqlgGraph.tx().commit();

        Schema globalUniqueIndexSchema = this.sqlgGraph.getTopology().getGlobalUniqueIndexSchema();
        Optional globalUniqueIndexOptional = globalUniqueIndexSchema.getGlobalUniqueIndex("ab_namea_ab_nameb_ab_namec");
        Assert.assertTrue(globalUniqueIndexOptional.isPresent());

        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "name", "a");
        Vertex b1 = this.sqlgGraph.addVertex(T.label, "B", "name", "b");
        Edge e = a1.addEdge("ab", b1, "namea", "a", "nameb", "b", "namec", "c");
        this.sqlgGraph.tx().commit();

        e.property("namea", "aa");
        this.sqlgGraph.tx().commit();
        try {
            //this should pass
            a1.addEdge("ab", b1, "namea", "a", "nameb", "bb", "namec", "cc");
        } catch (Exception ex) {
            fail("GlobalUniqueIndex should not fire");
        }
        try {
            a1.addEdge("ab", b1, "namea", "aa", "nameb", "bb", "namec", "cc");
            fail("GlobalUniqueIndex should prevent this from executing");
        } catch (Exception ex) {
            //swallow
        }
    }

    @Test
    public void testVertexUniqueConstraintDelete() {
        VertexLabel vertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("A", new HashMap() {{
            put("namea", PropertyType.STRING);
            put("nameb", PropertyType.STRING);
            put("namec", PropertyType.STRING);
        }});
        Set properties = new HashSet<>(vertexLabel.getProperties().values());
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(properties);
        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "namea", "a1");
        this.sqlgGraph.addVertex(T.label, "A", "namea", "a2");
        this.sqlgGraph.tx().commit();

        Assert.assertEquals(6, this.sqlgGraph.globalUniqueIndexes().V().count().next().intValue());

        try {
            this.sqlgGraph.addVertex(T.label, "A", "namea", "a1");
            fail("GlobalUniqueIndex should prevent this form happening");
        } catch (Exception e) {
            //swallow
            this.sqlgGraph.tx().rollback();
        }
        a1.remove();
        this.sqlgGraph.tx().commit();
        Assert.assertEquals(3, this.sqlgGraph.globalUniqueIndexes().V().count().next().intValue());


        this.sqlgGraph.addVertex(T.label, "A", "namea", "a1");
        //this time it passes.
        this.sqlgGraph.tx().commit();
        Assert.assertEquals(6, this.sqlgGraph.globalUniqueIndexes().V().count().next().intValue());
    }

    @Test
    public void testEdgeUniqueConstraintDelete() {
        Map properties = new HashMap<>();
        properties.put("namea", PropertyType.STRING);
        VertexLabel aVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("A", properties);
        VertexLabel bVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("B", properties);
        EdgeLabel edgeLabel = aVertexLabel.ensureEdgeLabelExist("ab", bVertexLabel, properties);

        Set propertyColumns = new HashSet<>(edgeLabel.getProperties().values());
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(propertyColumns);
        Vertex a1 = this.sqlgGraph.addVertex(T.label, "A", "namea", "a1");
        Vertex a2 = this.sqlgGraph.addVertex(T.label, "A", "namea", "a2");
        Edge edge = a1.addEdge("ab", a2, "namea", "123");
        this.sqlgGraph.tx().commit();

        Assert.assertEquals(1, this.sqlgGraph.globalUniqueIndexes().V().count().next().intValue());

        try {
            a1.addEdge("ab", a2, "namea", "123");
            fail("GlobalUniqueIndex should prevent this form happening");
        } catch (Exception e) {
            //swallow
            this.sqlgGraph.tx().rollback();
        }
        edge.remove();
        this.sqlgGraph.tx().commit();

        Assert.assertEquals(0, this.sqlgGraph.globalUniqueIndexes().V().count().next().intValue());

        a1.addEdge("ab", a2, "namea", "123");
        //this time it passes.
        this.sqlgGraph.tx().commit();
        Assert.assertEquals(1, this.sqlgGraph.globalUniqueIndexes().V().count().next().intValue());
    }


    //Lukas's tests
    @Test
    public void testVertexSingleLabelUniqueConstraint() {
        Map properties = new HashMap() {{
            put("name", PropertyType.STRING);
        }};
        VertexLabel personVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("Person", properties);
        Assert.assertTrue(personVertexLabel.isUncommitted());
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(new HashSet<>(personVertexLabel.getProperties().values()));
        this.sqlgGraph.tx().commit();

        this.sqlgGraph.addVertex(T.label, "Person", "name", "Joe");
        this.sqlgGraph.tx().commit();

        try {
            this.sqlgGraph.addVertex(T.label, "Person", "name", "Joe");
            fail("Should not have been possible to add 2 people with the same name.");
        } catch (Exception e) {
            //good
            this.sqlgGraph.tx().rollback();
        }
    }

    @SuppressWarnings("OptionalGetWithoutIsPresent")
    @Test
    public void testVertexMultiLabelUniqueConstraint() {
        Map properties = new HashMap() {{
            put("name", PropertyType.STRING);
        }};
        VertexLabel chocolateVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("Chocolate", properties);
        VertexLabel candyVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("Candy", properties);
        this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("Icecream", properties);
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(new HashSet() {{
            add(chocolateVertexLabel.getProperty("name").get());
            add(candyVertexLabel.getProperty("name").get());
        }});
        this.sqlgGraph.addVertex(T.label, "Chocolate", "name", "Yummy");
        this.sqlgGraph.tx().commit();

        try {
            this.sqlgGraph.addVertex(T.label, "Candy", "name", "Yummy");
            fail("A chocolate and a candy should not have the same name.");
        } catch (Exception e) {
            //good
            this.sqlgGraph.tx().rollback();
        }

        this.sqlgGraph.addVertex(T.label, "Icecream", "name", "Yummy");
        this.sqlgGraph.tx().commit();
    }

    @SuppressWarnings("OptionalGetWithoutIsPresent")
    @Test
    public void testVertexMultipleConstraintsOnSingleProperty() {
        Map properties = new HashMap() {{
            put("name", PropertyType.STRING);
        }};
        VertexLabel chocolateVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("Chocolate", properties);
        VertexLabel candyVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("Candy", properties);
        this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("Icecream", properties);
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(new HashSet() {{
            add(chocolateVertexLabel.getProperty("name").get());
        }});
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(new HashSet() {{
            add(candyVertexLabel.getProperty("name").get());
        }});

        this.sqlgGraph.addVertex(T.label, "Chocolate", "name", "Yummy");
        this.sqlgGraph.addVertex(T.label, "Candy", "name", "Yummy");
        this.sqlgGraph.addVertex(T.label, "Icecream", "name", "Yummy");
        this.sqlgGraph.addVertex(T.label, "Icecream", "name", "Yummy");
        this.sqlgGraph.tx().commit();

        try {
            this.sqlgGraph.addVertex(T.label, "Chocolate", "name", "Yummy");
            fail("Two chocolates should not have the same name.");
        } catch (Exception e) {
            //good
            this.sqlgGraph.tx().rollback();
        }

        try {
            this.sqlgGraph.addVertex(T.label, "Candy", "name", "Yummy");
            fail("Two candies should not have the same name.");
        } catch (Exception e) {
            //good
            this.sqlgGraph.tx().rollback();
        }
    }

    @SuppressWarnings("OptionalGetWithoutIsPresent")
    @Test
    public void testUpdateUniqueProperty() {

        Map properties = new HashMap() {{
            put("name", PropertyType.STRING);
        }};
        VertexLabel personVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("Person", properties);
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(new HashSet() {{
            add(personVertexLabel.getProperty("name").get());
        }});
        this.sqlgGraph.tx().commit();

        Vertex v1 = this.sqlgGraph.addVertex(T.label, "Person");
        v1.property("name", "Joseph");
        Vertex v2 = this.sqlgGraph.addVertex(T.label, "Person", "name", "Joe");
        this.sqlgGraph.tx().commit();
        v2 = this.sqlgGraph.traversal().V(v2.id()).next();
        try {
            v2.property("name", "Joseph");
            fail("Should not be able to call a person a pre-existing name.");
        } catch (Exception e) {
            //good
        }
    }

    @Test
    public void testDeleteUniqueProperty() {
        Map properties = new HashMap() {{
            put("name", PropertyType.STRING);
        }};
        VertexLabel personVertexLabel = this.sqlgGraph.getTopology().getPublicSchema().ensureVertexLabelExist("Person", properties);
        this.sqlgGraph.getTopology().ensureGlobalUniqueIndexExist(new HashSet<>(personVertexLabel.getProperties().values()));
        this.sqlgGraph.tx().commit();
        Vertex v = this.sqlgGraph.addVertex(T.label, "Person", "name", "Joseph");
        this.sqlgGraph.tx().commit();
        try {
            this.sqlgGraph.addVertex(T.label, "Person", "name", "Joseph");
            fail("Should not be able to call a person a pre-existing name.");
        } catch (Exception e) {
            this.sqlgGraph.tx().rollback();
            //good
        }
        this.sqlgGraph.traversal().V(v.id()).next().remove();
        //this time it passes
        this.sqlgGraph.addVertex(T.label, "Person", "name", "Joseph");
    }

}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy