How to use performSimpleTest method of org.testcontainers.jdbc.AbstractJDBCDriverTest class

Best Testcontainers-java code snippet using org.testcontainers.jdbc.AbstractJDBCDriverTest.performSimpleTest

Source:AbstractJDBCDriverTest.java Github

copy

Full Screen

...41 }42 @Test43 public void test() throws SQLException {44 try (HikariDataSource dataSource = getDataSource(jdbcUrl, 1)) {45 performSimpleTest(dataSource);46 if (options.contains(Options.ScriptedSchema)) {47 performTestForScriptedSchema(dataSource);48 }49 if (options.contains(Options.JDBCParams)) {50 performTestForJDBCParamUsage(dataSource);51 }52 if (options.contains(Options.CharacterSet)) {53 performSimpleTestWithCharacterSet(jdbcUrl);54 performTestForCharacterEncodingForInitialScriptConnection(dataSource);55 }56 if (options.contains(Options.CustomIniFile)) {57 performTestForCustomIniFile(dataSource);58 }59 }60 }61 private void performSimpleTest(HikariDataSource dataSource) throws SQLException {62 String query = "SELECT 1";63 if (jdbcUrl.startsWith("jdbc:tc:db2:")) {64 query = "SELECT 1 FROM SYSIBM.SYSDUMMY1";65 }66 boolean result = new QueryRunner(dataSource, options.contains(Options.PmdKnownBroken)).query(query, rs -> {67 rs.next();68 int resultSetInt = rs.getInt(1);69 assertEquals("A basic SELECT query succeeds", 1, resultSetInt);70 return true;71 });72 assertTrue("The database returned a record as expected", result);73 }74 private void performTestForScriptedSchema(HikariDataSource dataSource) throws SQLException {75 boolean result = new QueryRunner(dataSource).query("SELECT foo FROM bar WHERE foo LIKE '%world'", rs -> {76 rs.next();77 String resultSetString = rs.getString(1);78 assertEquals("A basic SELECT query succeeds where the schema has been applied from a script", "hello world", resultSetString);79 return true;80 });81 assertTrue("The database returned a record as expected", result);82 }83 private void performTestForJDBCParamUsage(HikariDataSource dataSource) throws SQLException {84 boolean result = new QueryRunner(dataSource).query("select CURRENT_USER", rs -> {85 rs.next();86 String resultUser = rs.getString(1);87 // Not all databases (eg. Postgres) return @% at the end of user name. We just need to make sure the user name matches.88 if (resultUser.endsWith("@%")) {89 resultUser = resultUser.substring(0, resultUser.length() - 2);90 }91 assertEquals("User from query param is created.", "someuser", resultUser);92 return true;93 });94 assertTrue("The database returned a record as expected", result);95 String databaseQuery = "SELECT DATABASE()";96 // Postgres does not have Database() as a function97 String databaseType = ConnectionUrl.newInstance(jdbcUrl).getDatabaseType();98 if (databaseType.equalsIgnoreCase("postgresql") ||99 databaseType.equalsIgnoreCase("postgis") ||100 databaseType.equalsIgnoreCase("timescaledb")) {101 databaseQuery = "SELECT CURRENT_DATABASE()";102 }103 result = new QueryRunner(dataSource).query(databaseQuery, rs -> {104 rs.next();105 String resultDB = rs.getString(1);106 assertEquals("Database name from URL String is used.", "databasename", resultDB);107 return true;108 });109 assertTrue("The database returned a record as expected", result);110 }111 private void performTestForCharacterEncodingForInitialScriptConnection(HikariDataSource dataSource) throws SQLException {112 boolean result = new QueryRunner(dataSource).query("SELECT foo FROM bar WHERE foo LIKE '%мир'", rs -> {113 rs.next();114 String resultSetString = rs.getString(1);115 assertEquals("A SELECT query succeed and the correct charset has been applied for the init script", "привет мир", resultSetString);116 return true;117 });118 assertTrue("The database returned a record as expected", result);119 }120 /**121 * This method intentionally verifies encoding twice to ensure that the query string parameters are used when122 * Connections are created from cached containers.123 *124 * @param jdbcUrl125 * @throws SQLException126 */127 private void performSimpleTestWithCharacterSet(String jdbcUrl) throws SQLException {128 HikariDataSource datasource1 = verifyCharacterSet(jdbcUrl);129 HikariDataSource datasource2 = verifyCharacterSet(jdbcUrl);130 datasource1.close();131 datasource2.close();132 }133 private HikariDataSource verifyCharacterSet(String jdbcUrl) throws SQLException {134 HikariDataSource dataSource = getDataSource(jdbcUrl, 1);135 boolean result = new QueryRunner(dataSource).query("SHOW VARIABLES LIKE 'character\\_set\\_connection'", rs -> {136 rs.next();137 String resultSetString = rs.getString(2);138 assertTrue("Passing query parameters to set DB connection encoding is successful", resultSetString.startsWith("utf8"));139 return true;140 });141 assertTrue("The database returned a record as expected", result);...

Full Screen

Full Screen

performSimpleTest

Using AI Code Generation

copy

Full Screen

1def driverTest = new org.testcontainers.jdbc.AbstractJDBCDriverTest()2def performSimpleTestMethod = driverTest.getClass().getDeclaredMethod("performSimpleTest", String)3performSimpleTestMethod.setAccessible(true)4performSimpleTestMethod.invoke(driverTest, "couchbase/couchbase-server:community-6.5.1")5Class.forName("com.couchbase.jdbc.CBJDBCDriver")6new org.testcontainers.jdbc.AbstractJDBCDriverTest().performSimpleTest("couchbase/couchbase-server:community-6.5.1")7def driverTest = new org.testcontainers.jdbc.AbstractJDBCDriverTest()8def performSimpleTestMethod = driverTest.getClass().getDeclaredMethod("performSimpleTest", String)9performSimpleTestMethod.setAccessible(true)10performSimpleTestMethod.invoke(driverTest, "couchbase/couchbase-server:community-6.5.1")

Full Screen

Full Screen

Automation Testing Tutorials

Learn to execute automation testing from scratch with LambdaTest Learning Hub. Right from setting up the prerequisites to run your first automation test, to following best practices and diving deeper into advanced test scenarios. LambdaTest Learning Hubs compile a list of step-by-step guides to help you be proficient with different test automation frameworks i.e. Selenium, Cypress, TestNG etc.

LambdaTest Learning Hubs:

YouTube

You could also refer to video tutorials over LambdaTest YouTube channel to get step by step demonstration from industry experts.

Try LambdaTest Now !!

Get 100 minutes of automation test minutes FREE!!

Next-Gen App & Browser Testing Cloud

Was this article helpful?

Helpful

NotHelpful