001/* 002 * Licensed under the Apache License, Version 2.0 (the "License"); 003 * you may not use this file except in compliance with the License. 004 * You may obtain a copy of the License at 005 * 006 * http://www.apache.org/licenses/LICENSE-2.0 007 * 008 * Unless required by applicable law or agreed to in writing, software 009 * distributed under the License is distributed on an "AS IS" BASIS, 010 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 011 * See the License for the specific language governing permissions and 012 * limitations under the License. 013 */ 014package de.softwareforge.testing.postgres.junit5; 015 016import static org.junit.jupiter.api.Assertions.assertEquals; 017import static org.junit.jupiter.api.Assertions.assertNotEquals; 018 019import de.softwareforge.testing.postgres.embedded.DatabaseInfo; 020import de.softwareforge.testing.postgres.embedded.FlywayPreparer; 021 022import java.sql.Connection; 023import java.sql.ResultSet; 024import java.sql.SQLException; 025import java.sql.Statement; 026 027import org.junit.jupiter.api.Test; 028import org.junit.jupiter.api.extension.RegisterExtension; 029 030@RequirePostgresVersion(atLeast = "10") 031public class Junit5FlywayTest { 032 033 @RegisterExtension 034 public static EmbeddedPgExtension singleDatabase = SingleDatabaseBuilder.preparedInstanceWithDefaults(FlywayPreparer.forClasspathLocation("db/testing")) 035 .build(); 036 037 @RegisterExtension 038 public static EmbeddedPgExtension multiDatabase = MultiDatabaseBuilder.preparedInstanceWithDefaults(FlywayPreparer.forClasspathLocation("db/testing")) 039 .build(); 040 041 042 @Test 043 public void testSingleTables() throws Exception { 044 045 DatabaseInfo firstDatabaseInfo = singleDatabase.createDatabaseInfo(); 046 DatabaseInfo secondDatabaseInfo = singleDatabase.createDatabaseInfo(); 047 048 // get the same database on every call 049 assertEquals(firstDatabaseInfo, secondDatabaseInfo); 050 051 // make sure tables exist 052 assertEquals("bar", fetchData(firstDatabaseInfo)); 053 } 054 055 @Test 056 public void testMultiTables() throws Exception { 057 058 DatabaseInfo firstDatabaseInfo = multiDatabase.createDatabaseInfo(); 059 DatabaseInfo secondDatabaseInfo = multiDatabase.createDatabaseInfo(); 060 061 // different databases 062 assertNotEquals(firstDatabaseInfo, secondDatabaseInfo); 063 064 // both database contain the data 065 assertEquals("bar", fetchData(firstDatabaseInfo)); 066 assertEquals("bar", fetchData(secondDatabaseInfo)); 067 } 068 069 private static String fetchData(DatabaseInfo databaseInfo) throws SQLException { 070 try (Connection c = databaseInfo.asDataSource().getConnection(); 071 Statement s = c.createStatement()) { 072 try (ResultSet rs = s.executeQuery("SELECT * FROM foo")) { 073 if (!rs.next()) { 074 return null; 075 } 076 return rs.getString(1); 077 } 078 } 079 } 080}