blob: 71032f05afb67d90504efdecbe6e6c20edb9bddb [file] [log] [blame]
/*
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements. See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF 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
*
* 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.apache.shardingsphere.elasticjob.lite.spring.boot.job;
import org.apache.shardingsphere.elasticjob.api.ElasticJob;
import org.apache.shardingsphere.elasticjob.infra.concurrent.BlockUtils;
import org.apache.shardingsphere.elasticjob.lite.api.bootstrap.JobBootstrap;
import org.apache.shardingsphere.elasticjob.lite.api.bootstrap.impl.OneOffJobBootstrap;
import org.apache.shardingsphere.elasticjob.lite.api.bootstrap.impl.ScheduleJobBootstrap;
import org.apache.shardingsphere.elasticjob.lite.spring.boot.job.fixture.EmbedTestingServer;
import org.apache.shardingsphere.elasticjob.lite.spring.boot.job.fixture.job.impl.CustomTestJob;
import org.apache.shardingsphere.elasticjob.lite.spring.boot.reg.ZookeeperProperties;
import org.apache.shardingsphere.elasticjob.reg.zookeeper.ZookeeperRegistryCenter;
import org.apache.shardingsphere.elasticjob.tracing.api.TracingConfiguration;
import org.junit.BeforeClass;
import org.junit.Test;
import org.springframework.boot.autoconfigure.SpringBootApplication;
import org.springframework.boot.test.context.SpringBootTest;
import org.springframework.test.context.ActiveProfiles;
import org.springframework.test.context.junit4.AbstractJUnit4SpringContextTests;
import javax.sql.DataSource;
import java.sql.SQLException;
import java.util.Arrays;
import java.util.Map;
import static org.hamcrest.CoreMatchers.equalTo;
import static org.hamcrest.CoreMatchers.is;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertNull;
import static org.junit.Assert.assertThat;
import static org.junit.Assert.assertTrue;
@SpringBootTest
@SpringBootApplication
@ActiveProfiles("elasticjob")
public class ElasticJobSpringBootTest extends AbstractJUnit4SpringContextTests {
@BeforeClass
public static void init() {
EmbedTestingServer.start();
}
@Test
public void assertZookeeperProperties() {
assertNotNull(applicationContext);
ZookeeperProperties actual = applicationContext.getBean(ZookeeperProperties.class);
assertThat(actual.getServerLists(), is(EmbedTestingServer.getConnectionString()));
assertThat(actual.getNamespace(), is("elasticjob-lite-spring-boot-starter"));
}
@Test
public void assertRegistryCenterCreation() {
assertNotNull(applicationContext);
ZookeeperRegistryCenter zookeeperRegistryCenter = applicationContext.getBean(ZookeeperRegistryCenter.class);
assertNotNull(zookeeperRegistryCenter);
zookeeperRegistryCenter.persist("/foo", "bar");
assertThat(zookeeperRegistryCenter.get("/foo"), is("bar"));
}
@Test
public void assertTracingConfigurationCreation() throws SQLException {
assertNotNull(applicationContext);
TracingConfiguration<?> tracingConfig = applicationContext.getBean(TracingConfiguration.class);
assertNotNull(tracingConfig);
assertThat(tracingConfig.getType(), is("RDB"));
assertTrue(tracingConfig.getTracingStorageConfiguration().getStorage() instanceof DataSource);
DataSource dataSource = (DataSource) tracingConfig.getTracingStorageConfiguration().getStorage();
assertNotNull(dataSource.getConnection());
}
@Test
public void assertElasticJobProperties() {
assertNotNull(applicationContext);
ElasticJobProperties elasticJobProperties = applicationContext.getBean(ElasticJobProperties.class);
assertNotNull(elasticJobProperties);
assertNotNull(elasticJobProperties.getJobs());
assertThat(elasticJobProperties.getJobs().size(), is(4));
ElasticJobConfigurationProperties customTestJobProperties = elasticJobProperties.getJobs().get("customTestJob");
assertNotNull(customTestJobProperties);
assertThat(customTestJobProperties.getElasticJobClass(), is(CustomTestJob.class));
assertThat(customTestJobProperties.getJobBootstrapBeanName(), is("customTestJobBean"));
assertThat(customTestJobProperties.getShardingTotalCount(), is(3));
assertNull(customTestJobProperties.getElasticJobType());
assertThat(customTestJobProperties.getJobListenerTypes().size(), is(2));
assertThat(customTestJobProperties.getJobListenerTypes(), equalTo(Arrays.asList("NOOP", "LOG")));
ElasticJobConfigurationProperties printTestJobProperties = elasticJobProperties.getJobs().get("printTestJob");
assertNotNull(printTestJobProperties);
assertNull(printTestJobProperties.getElasticJobClass());
assertThat(printTestJobProperties.getElasticJobType(), is("PRINT"));
assertThat(printTestJobProperties.getJobBootstrapBeanName(), is("printTestJobBean"));
assertThat(printTestJobProperties.getShardingTotalCount(), is(3));
assertTrue(printTestJobProperties.getJobListenerTypes().isEmpty());
assertThat(printTestJobProperties.getProps().size(), is(1));
assertThat(printTestJobProperties.getProps().getProperty("print.content"), is("test print job"));
}
@Test
public void assertJobScheduleCreation() {
assertNotNull(applicationContext);
Map<String, ElasticJob> elasticJobBeans = applicationContext.getBeansOfType(ElasticJob.class);
assertFalse(elasticJobBeans.isEmpty());
Map<String, JobBootstrap> jobBootstrapBeans = applicationContext.getBeansOfType(JobBootstrap.class);
assertFalse(jobBootstrapBeans.isEmpty());
BlockUtils.waitingShortTime();
}
@Test
public void assertOneOffJobBootstrapBeanName() {
assertNotNull(applicationContext);
assertNotNull(applicationContext.getBean("customTestJobBean", OneOffJobBootstrap.class));
assertNotNull(applicationContext.getBean("printTestJobBean", OneOffJobBootstrap.class));
}
@Test
public void assertDefaultBeanNameWithClassJob() {
assertNotNull(applicationContext);
assertNotNull(applicationContext.getBean("defaultBeanNameClassJobScheduleJobBootstrap",
ScheduleJobBootstrap.class));
}
@Test
public void assertDefaultBeanNameWithTypeJob() {
assertNotNull(applicationContext);
assertNotNull(applicationContext.getBean("defaultBeanNameTypeJobScheduleJobBootstrap",
ScheduleJobBootstrap.class));
}
}