/** * Licensed to Apereo under one or more contributor license agreements. See the NOTICE file * distributed with this work for additional information regarding copyright ownership. Apereo * licenses this file to you 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 the * following location: * * <p>http://www.apache.org/licenses/LICENSE-2.0 * * <p>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.apereo.portal.utils.jdbc; import static junit.framework.Assert.assertEquals; import static junit.framework.Assert.assertNull; import com.google.common.collect.ImmutableMap; import org.apereo.portal.utils.PostgreSQL81Dialect; import org.hibernate.dialect.Dialect; import org.hibernate.dialect.HSQLDialect; import org.hibernate.dialect.MySQL5InnoDBDialect; import org.hibernate.dialect.MySQLDialect; import org.hibernate.dialect.Oracle10gDialect; import org.hibernate.dialect.Oracle8iDialect; import org.hibernate.dialect.Oracle9iDialect; import org.junit.Test; import org.junit.runner.RunWith; import org.mockito.InjectMocks; import org.mockito.runners.MockitoJUnitRunner; @RunWith(MockitoJUnitRunner.class) public class DelayedValidationQueryResolverImplTest { @InjectMocks private DelayedValidationQueryResolverImpl validationQueryResolver = new DelayedValidationQueryResolverImpl(); @Test public void testQueryResolution() { validationQueryResolver.setValidationQueryMap( ImmutableMap.<Class<? extends Dialect>, String>of( Oracle8iDialect.class, "SELECT 1 FROM DUAL", HSQLDialect.class, "select 1 from INFORMATION_SCHEMA.SYSTEM_USERS", MySQLDialect.class, "select 1")); String vq = validationQueryResolver.resolveValidationQuery(Oracle8iDialect.class); assertEquals("SELECT 1 FROM DUAL", vq); vq = validationQueryResolver.resolveValidationQuery(Oracle9iDialect.class); assertEquals("SELECT 1 FROM DUAL", vq); vq = validationQueryResolver.resolveValidationQuery(Oracle10gDialect.class); assertEquals("SELECT 1 FROM DUAL", vq); vq = validationQueryResolver.resolveValidationQuery(PostgreSQL81Dialect.class); assertNull(vq); vq = validationQueryResolver.resolveValidationQuery(MySQL5InnoDBDialect.class); assertEquals("select 1", vq); } }