Package com.zaxxer.hikari

Source Code of com.zaxxer.hikari.ConnectionStateTest

package com.zaxxer.hikari;

import java.sql.Connection;
import java.sql.ResultSet;
import java.sql.SQLException;
import java.sql.Statement;

import org.junit.Assert;
import org.junit.Test;

import com.zaxxer.hikari.util.PoolUtilities;

public class ConnectionStateTest
{
   @SuppressWarnings("deprecation")
   @Test
   public void testAutoCommit() throws SQLException
   {
      HikariDataSource ds = new HikariDataSource();
      ds.setAutoCommit(true);
      ds.setMinimumIdle(1);
      ds.setMaximumPoolSize(1);
      ds.setJdbc4ConnectionTest(false);
      ds.setConnectionTestQuery("VALUES 1");
      ds.setDataSourceClassName("com.zaxxer.hikari.mocks.StubDataSource");
      ds.addDataSourceProperty("user", "bar");
      ds.addDataSourceProperty("password", "secret");
      ds.addDataSourceProperty("url", "baf");
      ds.addDataSourceProperty("loginTimeout", "10");

      try {
         Connection connection = ds.getConnection();
         connection.setAutoCommit(false);
         connection.close();

         PoolUtilities.quietlySleep(1100L);

         Connection connection2 = ds.getConnection();
         Assert.assertSame(connection.unwrap(Connection.class), connection2.unwrap(Connection.class));
         Assert.assertTrue(connection2.getAutoCommit());
         connection2.close();
      }
      finally {
         ds.close();
      }
   }

   @Test
   public void testTransactionIsolation() throws SQLException
   {
      HikariDataSource ds = new HikariDataSource();
      ds.setTransactionIsolation("TRANSACTION_READ_COMMITTED");
      ds.setMinimumIdle(1);
      ds.setMaximumPoolSize(1);
      ds.setConnectionTestQuery("VALUES 1");
      ds.setDataSourceClassName("com.zaxxer.hikari.mocks.StubDataSource");

      try {
         Connection connection = ds.getConnection();
         connection.setTransactionIsolation(Connection.TRANSACTION_READ_UNCOMMITTED);
         connection.close();

         Connection connection2 = ds.getConnection();
         Assert.assertSame(connection.unwrap(Connection.class), connection2.unwrap(Connection.class));
         Assert.assertEquals(Connection.TRANSACTION_READ_COMMITTED, connection2.getTransactionIsolation());
         connection2.close();
      }
      finally {
         ds.close();
      }
   }

   @Test
   public void testIsolation() throws Exception
   {
      HikariConfig config = new HikariConfig();
      config.setDataSourceClassName("com.zaxxer.hikari.mocks.StubDataSource");
      config.setTransactionIsolation("TRANSACTION_REPEATABLE_READ");
      config.validate();

      int transactionIsolation = PoolUtilities.getTransactionIsolation(config.getTransactionIsolation());
      Assert.assertSame(Connection.TRANSACTION_REPEATABLE_READ, transactionIsolation);
   }

   @Test
   public void testReadOnly() throws Exception
   {
      HikariDataSource ds = new HikariDataSource();
      ds.setCatalog("test");
      ds.setMinimumIdle(1);
      ds.setMaximumPoolSize(1);
      ds.setConnectionTestQuery("VALUES 1");
      ds.setDataSourceClassName("com.zaxxer.hikari.mocks.StubDataSource");

      try {
         Connection connection = ds.getConnection();
         connection.setReadOnly(true);
         connection.close();

         Connection connection2 = ds.getConnection();
         Assert.assertSame(connection.unwrap(Connection.class), connection2.unwrap(Connection.class));
         Assert.assertFalse(connection2.isReadOnly());
         connection2.close();
      }
      finally {
         ds.close();
      }
   }

   @Test
   public void testCatalog() throws SQLException
   {
      HikariDataSource ds = new HikariDataSource();
      ds.setCatalog("test");
      ds.setMinimumIdle(1);
      ds.setMaximumPoolSize(1);
      ds.setConnectionTestQuery("VALUES 1");
      ds.setDataSourceClassName("com.zaxxer.hikari.mocks.StubDataSource");

      try {
         Connection connection = ds.getConnection();
         connection.setCatalog("other");
         connection.close();

         Connection connection2 = ds.getConnection();
         Assert.assertSame(connection.unwrap(Connection.class), connection2.unwrap(Connection.class));
         Assert.assertEquals("test", connection2.getCatalog());
         connection2.close();
      }
      finally {
         ds.close();
      }
   }

   @Test
   public void testCommitTracking() throws SQLException
   {
      HikariDataSource ds = new HikariDataSource();
      ds.setMinimumIdle(1);
      ds.setMaximumPoolSize(1);
      ds.setConnectionTestQuery("VALUES 1");
      ds.setDataSourceClassName("com.zaxxer.hikari.mocks.StubDataSource");

      try {
         Connection connection = ds.getConnection();

         Statement statement = connection.createStatement();
         statement.execute("SELECT something");
         Assert.assertTrue(TestElf.getConnectionCommitDirtyState(connection));

         connection.commit();
         Assert.assertFalse(TestElf.getConnectionCommitDirtyState(connection));

         statement.execute("SELECT something", Statement.NO_GENERATED_KEYS);
         Assert.assertTrue(TestElf.getConnectionCommitDirtyState(connection));

         connection.rollback();
         Assert.assertFalse(TestElf.getConnectionCommitDirtyState(connection));

         ResultSet resultSet = statement.executeQuery("SELECT something");
         Assert.assertTrue(TestElf.getConnectionCommitDirtyState(connection));

         connection.rollback(null);
         Assert.assertFalse(TestElf.getConnectionCommitDirtyState(connection));

         resultSet.updateRow();
         Assert.assertTrue(TestElf.getConnectionCommitDirtyState(connection));

         connection.close();
      }
      finally {
         ds.close();
      }
     
   }
}
TOP

Related Classes of com.zaxxer.hikari.ConnectionStateTest

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.