package org.apereo.cas.ticket.registry; import com.hazelcast.config.Config; import com.hazelcast.config.EvictionPolicy; import com.hazelcast.config.MapConfig; import com.hazelcast.core.HazelcastInstance; import org.apereo.cas.config.CasCoreAuthenticationConfiguration; import org.apereo.cas.config.CasCoreAuthenticationHandlersConfiguration; import org.apereo.cas.config.CasCoreAuthenticationMetadataConfiguration; import org.apereo.cas.config.CasCoreAuthenticationPolicyConfiguration; import org.apereo.cas.config.CasCoreAuthenticationPrincipalConfiguration; import org.apereo.cas.config.CasCoreAuthenticationServiceSelectionStrategyConfiguration; import org.apereo.cas.config.CasCoreAuthenticationSupportConfiguration; import org.apereo.cas.config.CasCoreConfiguration; import org.apereo.cas.config.CasCoreHttpConfiguration; import org.apereo.cas.config.CasCoreServicesConfiguration; import org.apereo.cas.config.CasCoreTicketsConfiguration; import org.apereo.cas.config.CasCoreUtilConfiguration; import org.apereo.cas.config.CasPersonDirectoryConfiguration; import org.apereo.cas.config.CasCoreTicketCatalogConfiguration; import org.apereo.cas.config.HazelcastTicketRegistryConfiguration; import org.apereo.cas.config.support.EnvironmentConversionServiceInitializer; import org.apereo.cas.logout.config.CasCoreLogoutConfiguration; import org.junit.After; import org.junit.Test; import org.junit.runner.RunWith; import org.slf4j.Logger; import org.slf4j.LoggerFactory; import org.springframework.beans.factory.annotation.Autowired; import org.springframework.beans.factory.annotation.Qualifier; import org.springframework.boot.test.context.SpringBootTest; import org.springframework.cloud.autoconfigure.RefreshAutoConfiguration; import org.springframework.test.annotation.DirtiesContext; import org.springframework.test.context.ContextConfiguration; import org.springframework.test.context.TestPropertySource; import org.springframework.test.context.junit4.SpringRunner; import java.util.Arrays; import static org.junit.Assert.*; /** * @author Dmitriy Kopylenko * @since 4.2.0 */ @RunWith(SpringRunner.class) @SpringBootTest(classes = { HazelcastTicketRegistryReplicationTests.HazelcastTestConfiguration.class, HazelcastTicketRegistryConfiguration.class, CasCoreTicketsConfiguration.class, CasCoreTicketCatalogConfiguration.class, CasCoreUtilConfiguration.class, CasCoreConfiguration.class, CasCoreAuthenticationServiceSelectionStrategyConfiguration.class, CasCoreAuthenticationConfiguration.class, CasCoreAuthenticationPrincipalConfiguration.class, CasCoreAuthenticationPolicyConfiguration.class, CasCoreAuthenticationMetadataConfiguration.class, CasCoreAuthenticationSupportConfiguration.class, CasCoreAuthenticationHandlersConfiguration.class, CasCoreHttpConfiguration.class, CasCoreServicesConfiguration.class, CasCoreLogoutConfiguration.class, RefreshAutoConfiguration.class, CasPersonDirectoryConfiguration.class, CasCoreLogoutConfiguration.class}) @ContextConfiguration(locations = "classpath:HazelcastInstanceConfigurationTests-config.xml", initializers = EnvironmentConversionServiceInitializer.class) @TestPropertySource(locations = {"classpath:/hazelcast.properties"}) @DirtiesContext public class ProvidedHazelcastInstanceConfigurationTests { private static final Logger LOGGER = LoggerFactory.getLogger(ProvidedHazelcastInstanceConfigurationTests.class); @Autowired @Qualifier("hazelcast") private HazelcastInstance hzInstance; @Test public void hazelcastInstanceIsCreatedNormally() throws Exception { assertNotNull(this.hzInstance); final Config config = this.hzInstance.getConfig(); assertTrue(config.getNetworkConfig().getJoin().getMulticastConfig().isEnabled()); assertEquals(Arrays.asList("127.0.0.1"), config.getNetworkConfig().getJoin().getTcpIpConfig().getMembers()); assertFalse(config.getNetworkConfig().isPortAutoIncrement()); assertEquals(5801, config.getNetworkConfig().getPort()); final MapConfig mapConfig = config.getMapConfig("tickets-from-external-config"); assertNotNull(mapConfig); assertEquals(20000, mapConfig.getMaxIdleSeconds()); assertEquals(EvictionPolicy.LFU, mapConfig.getEvictionPolicy()); assertEquals(99, mapConfig.getEvictionPercentage()); } @After public void shutdownHz() { LOGGER.info("Shutting down hazelcast instance [{}]", this.hzInstance.getConfig().getInstanceName()); this.hzInstance.shutdown(); while (this.hzInstance.getLifecycleService().isRunning()) { LOGGER.info("Waiting for instances to shut down"); } } }