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

org.umlg.sqlg.test.edges.TestForeignKeysAreOptional Maven / Gradle / Ivy

package org.umlg.sqlg.test.edges;

import java.sql.Connection;
import java.sql.DatabaseMetaData;
import java.sql.PreparedStatement;
import java.sql.ResultSet;

import org.apache.commons.configuration.Configuration;
import org.apache.tinkerpop.gremlin.structure.T;
import org.apache.tinkerpop.gremlin.structure.Vertex;
import org.junit.Assert;
import org.junit.Assume;
import org.junit.Test;
import org.umlg.sqlg.structure.SqlgGraph;
import org.umlg.sqlg.test.BaseTest;

/**
 * Date: 2015/05/27
 * Time: 9:15 PM
 */
public class TestForeignKeysAreOptional extends BaseTest {

	
    @Test
    public void testForeignKeysOnPostgres() throws Exception {
        Assume.assumeTrue(this.sqlgGraph.getSqlDialect().getClass().getSimpleName().contains("Postgres"));
        Configuration conf=getConfigurationClone();
        conf.setProperty("implement.foreign.keys", "true");
        try (SqlgGraph g = SqlgGraph.open(conf)) {
            Vertex v1 = g.addVertex(T.label, "Person");
            Vertex v2 = g.addVertex(T.label, "Person");
            v1.addEdge("Edge1", v2);
            g.tx().commit();
            Connection conn = g.tx().getConnection();
            DatabaseMetaData dm = conn.getMetaData();
            ResultSet rs = dm.getImportedKeys("sqlggraphdb", "public", "E_Edge1");
            Assert.assertTrue(rs.next());
        }
    }

    @Test
    public void testForeignKeysOnHsqldb() throws Exception {
        Assume.assumeTrue(this.sqlgGraph.getSqlDialect().getClass().getSimpleName().contains("Hsqldb"));
        Configuration conf=getConfigurationClone();
        conf.setProperty("implement.foreign.keys", "true");
        try (SqlgGraph g = SqlgGraph.open(conf)) {
            Vertex v1 = g.addVertex(T.label, "Person");
            Vertex v2 = g.addVertex(T.label, "Person");
            v1.addEdge("Edge1", v2);
            g.tx().commit();
            Connection conn = g.tx().getConnection();
            try (PreparedStatement preparedStatement = conn.prepareStatement("select * from information_schema.constraint_table_usage where CONSTRAINT_NAME like '%FK%'")) {
                ResultSet rs = preparedStatement.executeQuery();
                Assert.assertTrue(rs.next());
            }
        }
    }

    @Test
    public void testForeignKeysOffPostgres() throws Exception {
        Assume.assumeTrue(this.sqlgGraph.getSqlDialect().getClass().getSimpleName().contains("Postgres"));
        Configuration conf=getConfigurationClone();
        conf.setProperty("implement.foreign.keys", "false");
        try (SqlgGraph g = SqlgGraph.open(conf)) {
            Vertex v1 = g.addVertex(T.label, "Person");
            Vertex v2 = g.addVertex(T.label, "Person");
            v1.addEdge("Edge1", v2);
            g.tx().commit();
            Connection conn = g.tx().getConnection();
            DatabaseMetaData dm = conn.getMetaData();
            ResultSet rs = dm.getImportedKeys("sqlgraphdb", "public", "E_Edge1");
            Assert.assertFalse(rs.next());
        }
    }

    @Test
    public void testForeignKeysOffHsqldb() throws Exception {
        Assume.assumeTrue(this.sqlgGraph.getSqlDialect().getClass().getSimpleName().contains("Hsqldb"));
        Configuration conf=getConfigurationClone();
        conf.setProperty("implement.foreign.keys", "false");
        try (SqlgGraph g = SqlgGraph.open(conf)) {
            Vertex v1 = g.addVertex(T.label, "Person");
            Vertex v2 = g.addVertex(T.label, "Person");
            v1.addEdge("Edge1", v2);
            g.tx().commit();
            Connection conn = g.tx().getConnection();
            try (PreparedStatement preparedStatement = conn.prepareStatement(
                    "select * from information_schema.constraint_table_usage " +
                            "where TABLE_NAME = 'E_Edge1' and CONSTRAINT_NAME like '%FK%'")) {
                ResultSet rs = preparedStatement.executeQuery();
                Assert.assertFalse(rs.next());
            }
        }
    }
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy