mirror of
https://github.com/Kingsrook/qqq.git
synced 2025-07-17 20:50:44 +00:00
Initial checkin
This commit is contained in:
@ -0,0 +1,161 @@
|
|||||||
|
/*
|
||||||
|
* QQQ - Low-code Application Framework for Engineers.
|
||||||
|
* Copyright (C) 2021-2025. Kingsrook, LLC
|
||||||
|
* 651 N Broad St Ste 205 # 6917 | Middletown DE 19709 | United States
|
||||||
|
* contact@kingsrook.com
|
||||||
|
* https://github.com/Kingsrook/
|
||||||
|
*
|
||||||
|
* This program is free software: you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU Affero General Public License as
|
||||||
|
* published by the Free Software Foundation, either version 3 of the
|
||||||
|
* License, or (at your option) any later version.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU Affero General Public License for more details.
|
||||||
|
*
|
||||||
|
* You should have received a copy of the GNU Affero General Public License
|
||||||
|
* along with this program. If not, see <https://www.gnu.org/licenses/>.
|
||||||
|
*/
|
||||||
|
|
||||||
|
package com.kingsrook.qqq.backend.module.rdbms.strategy;
|
||||||
|
|
||||||
|
|
||||||
|
import java.math.BigDecimal;
|
||||||
|
import java.nio.charset.StandardCharsets;
|
||||||
|
import java.sql.Connection;
|
||||||
|
import java.sql.Date;
|
||||||
|
import java.sql.PreparedStatement;
|
||||||
|
import java.sql.SQLException;
|
||||||
|
import java.sql.Timestamp;
|
||||||
|
import java.time.LocalDate;
|
||||||
|
import java.time.LocalDateTime;
|
||||||
|
import java.time.OffsetDateTime;
|
||||||
|
import java.util.GregorianCalendar;
|
||||||
|
import com.kingsrook.qqq.backend.core.actions.automation.AutomationStatus;
|
||||||
|
import com.kingsrook.qqq.backend.module.rdbms.BaseTest;
|
||||||
|
import com.kingsrook.qqq.backend.module.rdbms.TestUtils;
|
||||||
|
import com.kingsrook.qqq.backend.module.rdbms.jdbc.ConnectionManager;
|
||||||
|
import com.kingsrook.qqq.backend.module.rdbms.jdbc.QueryManager;
|
||||||
|
import org.junit.jupiter.api.AfterEach;
|
||||||
|
import org.junit.jupiter.api.BeforeEach;
|
||||||
|
import org.junit.jupiter.api.Test;
|
||||||
|
import static org.junit.jupiter.api.Assertions.assertThrows;
|
||||||
|
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
** Unit test for BaseRDBMSActionStrategy
|
||||||
|
*******************************************************************************/
|
||||||
|
class BaseRDBMSActionStrategyTest extends BaseTest
|
||||||
|
{
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
**
|
||||||
|
*******************************************************************************/
|
||||||
|
@BeforeEach
|
||||||
|
void beforeEach() throws SQLException
|
||||||
|
{
|
||||||
|
try(Connection connection = getConnection())
|
||||||
|
{
|
||||||
|
QueryManager.executeUpdate(connection, """
|
||||||
|
CREATE TABLE test_table
|
||||||
|
(
|
||||||
|
int_col INTEGER,
|
||||||
|
datetime_col DATETIME,
|
||||||
|
char_col CHAR(1),
|
||||||
|
date_col DATE,
|
||||||
|
time_col TIME,
|
||||||
|
long_col LONG
|
||||||
|
)
|
||||||
|
""");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
**
|
||||||
|
*******************************************************************************/
|
||||||
|
@AfterEach
|
||||||
|
void afterEach() throws SQLException
|
||||||
|
{
|
||||||
|
try(Connection connection = getConnection())
|
||||||
|
{
|
||||||
|
QueryManager.executeUpdate(connection, "DROP TABLE test_table");
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
**
|
||||||
|
*******************************************************************************/
|
||||||
|
private Connection getConnection() throws SQLException
|
||||||
|
{
|
||||||
|
return new ConnectionManager().getConnection(TestUtils.defineBackend());
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
/*******************************************************************************
|
||||||
|
** Test the various overloads that bind params.
|
||||||
|
** Note, we're just confirming that these methods don't throw...
|
||||||
|
*******************************************************************************/
|
||||||
|
@Test
|
||||||
|
void testBindParams() throws SQLException
|
||||||
|
{
|
||||||
|
try(Connection connection = getConnection())
|
||||||
|
{
|
||||||
|
long ctMillis = System.currentTimeMillis();
|
||||||
|
PreparedStatement ps = connection.prepareStatement("UPDATE test_table SET int_col = ? WHERE int_col > 0");
|
||||||
|
|
||||||
|
BaseRDBMSActionStrategy strategy = new BaseRDBMSActionStrategy();
|
||||||
|
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
// these calls - we just want to assert that they don't throw any exceptions //
|
||||||
|
///////////////////////////////////////////////////////////////////////////////
|
||||||
|
strategy.bindParamObject(ps, 1, (short) 1);
|
||||||
|
strategy.bindParamObject(ps, 1, (long) 1);
|
||||||
|
strategy.bindParamObject(ps, 1, true);
|
||||||
|
strategy.bindParamObject(ps, 1, BigDecimal.ONE);
|
||||||
|
strategy.bindParamObject(ps, 1, "hello".getBytes(StandardCharsets.UTF_8));
|
||||||
|
strategy.bindParamObject(ps, 1, new Timestamp(ctMillis));
|
||||||
|
strategy.bindParamObject(ps, 1, new Date(ctMillis));
|
||||||
|
strategy.bindParamObject(ps, 1, new GregorianCalendar());
|
||||||
|
strategy.bindParamObject(ps, 1, LocalDate.now());
|
||||||
|
strategy.bindParamObject(ps, 1, OffsetDateTime.now());
|
||||||
|
strategy.bindParamObject(ps, 1, LocalDateTime.now());
|
||||||
|
strategy.bindParamObject(ps, 1, AutomationStatus.PENDING_INSERT_AUTOMATIONS);
|
||||||
|
|
||||||
|
assertThrows(SQLException.class, () -> strategy.bindParamObject(ps, 1, new Object()));
|
||||||
|
|
||||||
|
strategy.bindParam(ps, 1, (Integer) null);
|
||||||
|
strategy.bindParam(ps, 1, (Boolean) null);
|
||||||
|
strategy.bindParam(ps, 1, (BigDecimal) null);
|
||||||
|
strategy.bindParam(ps, 1, (byte[]) null);
|
||||||
|
strategy.bindParam(ps, 1, (Timestamp) null);
|
||||||
|
strategy.bindParam(ps, 1, (String) null);
|
||||||
|
strategy.bindParam(ps, 1, (Date) null);
|
||||||
|
strategy.bindParam(ps, 1, (GregorianCalendar) null);
|
||||||
|
strategy.bindParam(ps, 1, (LocalDate) null);
|
||||||
|
strategy.bindParam(ps, 1, (LocalDateTime) null);
|
||||||
|
|
||||||
|
strategy.bindParam(ps, 1, 1);
|
||||||
|
strategy.bindParam(ps, 1, true);
|
||||||
|
strategy.bindParam(ps, 1, BigDecimal.ONE);
|
||||||
|
strategy.bindParam(ps, 1, "hello".getBytes(StandardCharsets.UTF_8));
|
||||||
|
strategy.bindParam(ps, 1, new Timestamp(ctMillis));
|
||||||
|
strategy.bindParam(ps, 1, "hello");
|
||||||
|
strategy.bindParam(ps, 1, new Date(ctMillis));
|
||||||
|
strategy.bindParam(ps, 1, new GregorianCalendar());
|
||||||
|
strategy.bindParam(ps, 1, LocalDate.now());
|
||||||
|
strategy.bindParam(ps, 1, LocalDateTime.now());
|
||||||
|
|
||||||
|
////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
// originally longs were being downgraded to int when binding, so, verify that doesn't happen //
|
||||||
|
////////////////////////////////////////////////////////////////////////////////////////////////
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
Reference in New Issue
Block a user