/* * Copyright 2012-2017 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 * * http://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.springframework.boot.jdbc; import org.junit.Rule; import org.junit.Test; import org.junit.rules.ExpectedException; import static org.assertj.core.api.Assertions.assertThat; /** * Tests for {@link DatabaseDriver}. * * @author Phillip Webb * @author Maciej Walkowiak * @author Stephane Nicoll */ public class DatabaseDriverTests { @Rule public ExpectedException thrown = ExpectedException.none(); @Test public void classNameForKnownDatabase() { String driverClassName = DatabaseDriver .fromJdbcUrl("jdbc:postgresql://hostname/dbname").getDriverClassName(); assertThat(driverClassName).isEqualTo("org.postgresql.Driver"); } @Test public void nullClassNameForUnknownDatabase() { String driverClassName = DatabaseDriver .fromJdbcUrl("jdbc:unknowndb://hostname/dbname").getDriverClassName(); assertThat(driverClassName).isNull(); } @Test public void unknownOnNullJdbcUrl() { DatabaseDriver actual = DatabaseDriver.fromJdbcUrl(null); assertThat(actual).isEqualTo(DatabaseDriver.UNKNOWN); } @Test public void failureOnMalformedJdbcUrl() { this.thrown.expect(IllegalArgumentException.class); this.thrown.expectMessage("URL must start with"); DatabaseDriver.fromJdbcUrl("malformed:url"); } @Test public void unknownOnNullProductName() { DatabaseDriver actual = DatabaseDriver.fromProductName(null); assertThat(actual).isEqualTo(DatabaseDriver.UNKNOWN); } @Test public void databaseProductNameLookups() throws Exception { assertThat(DatabaseDriver.fromProductName("newone")) .isEqualTo(DatabaseDriver.UNKNOWN); assertThat(DatabaseDriver.fromProductName("Apache Derby")) .isEqualTo(DatabaseDriver.DERBY); assertThat(DatabaseDriver.fromProductName("H2")).isEqualTo(DatabaseDriver.H2); assertThat(DatabaseDriver.fromProductName("HSQL Database Engine")) .isEqualTo(DatabaseDriver.HSQLDB); assertThat(DatabaseDriver.fromProductName("SQLite")) .isEqualTo(DatabaseDriver.SQLITE); assertThat(DatabaseDriver.fromProductName("MySQL")) .isEqualTo(DatabaseDriver.MYSQL); assertThat(DatabaseDriver.fromProductName("Oracle")) .isEqualTo(DatabaseDriver.ORACLE); assertThat(DatabaseDriver.fromProductName("PostgreSQL")) .isEqualTo(DatabaseDriver.POSTGRESQL); assertThat(DatabaseDriver.fromProductName("Microsoft SQL Server")) .isEqualTo(DatabaseDriver.SQLSERVER); assertThat(DatabaseDriver.fromProductName("SQL SERVER")) .isEqualTo(DatabaseDriver.SQLSERVER); assertThat(DatabaseDriver.fromProductName("DB2")).isEqualTo(DatabaseDriver.DB2); assertThat(DatabaseDriver.fromProductName("Firebird 2.5.WI")) .isEqualTo(DatabaseDriver.FIREBIRD); assertThat(DatabaseDriver.fromProductName("Firebird 2.1.LI")) .isEqualTo(DatabaseDriver.FIREBIRD); assertThat(DatabaseDriver.fromProductName("DB2/LINUXX8664")) .isEqualTo(DatabaseDriver.DB2); assertThat(DatabaseDriver.fromProductName("DB2 UDB for AS/400")) .isEqualTo(DatabaseDriver.DB2_AS400); assertThat(DatabaseDriver.fromProductName("DB3 XDB for AS/400")) .isEqualTo(DatabaseDriver.DB2_AS400); assertThat(DatabaseDriver.fromProductName("Teradata")) .isEqualTo(DatabaseDriver.TERADATA); assertThat(DatabaseDriver.fromProductName("Informix Dynamic Server")) .isEqualTo(DatabaseDriver.INFORMIX); } @Test public void databaseJdbcUrlLookups() { assertThat(DatabaseDriver.fromJdbcUrl("jdbc:newone://localhost")) .isEqualTo(DatabaseDriver.UNKNOWN); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:derby:sample")) .isEqualTo(DatabaseDriver.DERBY); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:h2:~/sample")) .isEqualTo(DatabaseDriver.H2); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:hsqldb:hsql://localhost")) .isEqualTo(DatabaseDriver.HSQLDB); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:sqlite:sample.db")) .isEqualTo(DatabaseDriver.SQLITE); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:mysql://localhost:3306/sample")) .isEqualTo(DatabaseDriver.MYSQL); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:oracle:thin:@localhost:1521:orcl")) .isEqualTo(DatabaseDriver.ORACLE); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:postgresql://127.0.0.1:5432/sample")) .isEqualTo(DatabaseDriver.POSTGRESQL); assertThat( DatabaseDriver.fromJdbcUrl("jdbc:jtds:sqlserver://127.0.0.1:1433/sample")) .isEqualTo(DatabaseDriver.JTDS); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:sqlserver://127.0.0.1:1433")) .isEqualTo(DatabaseDriver.SQLSERVER); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:firebirdsql://localhost/sample")) .isEqualTo(DatabaseDriver.FIREBIRD); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:db2://localhost:50000/sample ")) .isEqualTo(DatabaseDriver.DB2); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:as400://localhost")) .isEqualTo(DatabaseDriver.DB2_AS400); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:teradata://localhost/SAMPLE")) .isEqualTo(DatabaseDriver.TERADATA); assertThat( DatabaseDriver.fromJdbcUrl("jdbc:informix-sqli://localhost:1533/sample")) .isEqualTo(DatabaseDriver.INFORMIX); assertThat(DatabaseDriver.fromJdbcUrl("jdbc:informix-direct://sample")) .isEqualTo(DatabaseDriver.INFORMIX); } }