Skip to content

Commit

Permalink
Add Unit Test for PooledDataSource
Browse files Browse the repository at this point in the history
  • Loading branch information
hogimn committed Feb 19, 2023
1 parent 88ddca6 commit 1640f1a
Showing 1 changed file with 156 additions and 0 deletions.
Original file line number Diff line number Diff line change
@@ -0,0 +1,156 @@
/*
* Copyright 2009-2023 the original author or authors.
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* https://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
package org.apache.ibatis.datasource.pooled;

import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;

import java.sql.Connection;
import java.sql.SQLException;
import java.util.ArrayList;
import java.util.List;
import java.util.concurrent.CountDownLatch;
import java.util.concurrent.TimeUnit;

import static org.junit.jupiter.api.Assertions.*;

class PooledDataSourceTest {

PooledDataSource dataSource;

@BeforeEach
void beforeEach() {
dataSource = new PooledDataSource("org.hsqldb.jdbcDriver", "jdbc:hsqldb:mem:multipledrivers", "sa", "");
}

@Test
void shouldBlockUntilConnectionIsAvailableInPooledDataSource() throws Exception {
dataSource.setPoolMaximumCheckoutTime(20000);

List<Connection> connections = new ArrayList<>();
CountDownLatch latch = new CountDownLatch(1);

for (int i = 0; i < dataSource.getPoolMaximumActiveConnections(); i++) {
connections.add(dataSource.getConnection());
}

new Thread(() -> {
try {
dataSource.getConnection();
latch.countDown();
} catch (Exception e) {
throw new RuntimeException(e);
}
}).start();

assertFalse(latch.await(1000, TimeUnit.MILLISECONDS));
connections.get(0).close();
assertTrue(latch.await(1000, TimeUnit.MILLISECONDS));
}

@Test
void PoppedConnectionShouldBeNotEqualToClosedConnection() throws Exception {
Connection connectionToClose = dataSource.getConnection();

new Thread(() -> {
try {
assertNotEquals(connectionToClose, dataSource.getConnection());
} catch (Exception e) {
throw new RuntimeException(e);
}
}).start();

connectionToClose.close();
}

@Test
void shouldEnsureCorrectIdleConnectionCount() throws Exception {
dataSource.setPoolMaximumActiveConnections(10);
dataSource.setPoolMaximumIdleConnections(5);

PoolState poolState = dataSource.getPoolState();
List<Connection> connections = new ArrayList<>();

for (int i = 0; i < dataSource.getPoolMaximumActiveConnections(); i++) {
connections.add(dataSource.getConnection());
}

assertEquals(0, poolState.getIdleConnectionCount());

for (int i = 0; i < dataSource.getPoolMaximumActiveConnections(); i++) {
connections.get(i).close();
}

assertEquals(dataSource.getPoolMaximumIdleConnections(), poolState.getIdleConnectionCount());

for (int i = 0; i < dataSource.getPoolMaximumIdleConnections(); i++) {
dataSource.getConnection();
}

assertEquals(0, poolState.getIdleConnectionCount());
}

@Test
void connectionShouldBeAvailableAfterMaximumCheckoutTime() throws Exception {
dataSource.setPoolMaximumCheckoutTime(1000);
dataSource.setPoolTimeToWait(500);

int poolMaximumActiveConnections = dataSource.getPoolMaximumActiveConnections();
CountDownLatch latch = new CountDownLatch(1);

for (int i = 0; i < poolMaximumActiveConnections; i++) {
dataSource.getConnection();
}

new Thread(() -> {
try {
dataSource.getConnection();
latch.countDown();
} catch (Exception e) {
throw new RuntimeException(e);
}
}).start();

assertTrue(latch.await(5000, TimeUnit.MILLISECONDS));
}

@Test
void forceCloseAllShouldRemoveAllActiveAndIdleConnection() throws SQLException {
dataSource.setPoolMaximumActiveConnections(10);
dataSource.setPoolMaximumIdleConnections(5);

PoolState poolState = dataSource.getPoolState();
List<Connection> connections = new ArrayList<>();

for (int i = 0; i < dataSource.getPoolMaximumActiveConnections(); i++) {
connections.add(dataSource.getConnection());
}

for (int i = 0; i < dataSource.getPoolMaximumIdleConnections(); i++) {
connections.get(i).close();
}

assertEquals(dataSource.getPoolMaximumActiveConnections() - poolState.getIdleConnectionCount(),
poolState.getActiveConnectionCount());
assertEquals(dataSource.getPoolMaximumIdleConnections(),
poolState.getIdleConnectionCount());

dataSource.forceCloseAll();

assertEquals(0, poolState.getActiveConnectionCount());
assertEquals(0, poolState.getIdleConnectionCount());
}
}

0 comments on commit 1640f1a

Please sign in to comment.