package com.thinkbiganalytics.metadata.jpa.job; /*- * #%L * thinkbig-operational-metadata-jpa * %% * Copyright (C) 2017 ThinkBig Analytics * %% * 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. * #L% */ import com.querydsl.core.BooleanBuilder; import com.thinkbiganalytics.DateTimeUtil; import com.thinkbiganalytics.metadata.api.MetadataAccess; import com.thinkbiganalytics.metadata.api.jobrepo.job.BatchJobExecution; import com.thinkbiganalytics.metadata.api.jobrepo.job.BatchJobExecutionProvider; import com.thinkbiganalytics.metadata.api.jobrepo.job.JobStatusCount; import com.thinkbiganalytics.metadata.config.OperationalMetadataConfig; import com.thinkbiganalytics.metadata.jpa.TestJpaConfiguration; import com.thinkbiganalytics.metadata.jpa.jobrepo.job.QJpaBatchJobExecution; import com.thinkbiganalytics.metadata.jpa.support.GenericQueryDslFilter; import com.thinkbiganalytics.spring.CommonsSpringConfiguration; import com.thinkbiganalytics.test.security.WithMockJaasUser; import org.joda.time.Period; import org.junit.Test; import org.junit.runner.RunWith; import org.springframework.boot.test.SpringApplicationConfiguration; import org.springframework.data.domain.Page; import org.springframework.data.domain.PageRequest; import org.springframework.data.domain.Sort; import org.springframework.test.context.TestPropertySource; import org.springframework.test.context.junit4.SpringJUnit4ClassRunner; import java.lang.reflect.Field; import java.util.Arrays; import java.util.List; import java.util.Map; import java.util.stream.Collectors; import javax.inject.Inject; /** */ @RunWith(SpringJUnit4ClassRunner.class) @TestPropertySource(locations = "classpath:test-application.properties") @SpringApplicationConfiguration(classes = {CommonsSpringConfiguration.class, OperationalMetadataConfig.class, TestJpaConfiguration.class}) public class JpaBatchJobExecutionTest { @Inject private BatchJobExecutionProvider jobExecutionProvider; @Inject private MetadataAccess operationalMetadataAccess; public static Map<String, Field> getFields(Class<?> cl) { return Arrays.asList(cl.getDeclaredFields()).stream().collect(Collectors.toMap(f -> f.getName(), f -> f)); } @WithMockJaasUser(username = "dladmin", password = "secret", authorities = {"admin"}) @Test public void testPaging() { operationalMetadataAccess.read(() -> { String filter = "jobInstance.feed.feedType==FEED,jobInstance.feed.name==movies.new_releases"; //String feed = "movies.new_releases"; Page<? extends BatchJobExecution> page = jobExecutionProvider.findAll(filter, new PageRequest(0, 10, Sort.Direction.DESC, "jobExecutionId")); return page; }); } @WithMockJaasUser(username = "dladmin", password = "secret", authorities = {"admin"}) @Test public void testJobStatusCount() { operationalMetadataAccess.read(() -> { List<JobStatusCount> counts = jobExecutionProvider.getJobStatusCountByDate(); return counts; }); } @WithMockJaasUser(username = "dladmin", password = "secret", authorities = {"admin"}) @Test public void testJobStatusCountFromNow() { operationalMetadataAccess.read(() -> { Period period = DateTimeUtil.period("3Y"); List<JobStatusCount> counts = jobExecutionProvider.getJobStatusCountByDateFromNow(period, null); return counts; }); } @WithMockJaasUser(username = "dladmin", password = "secret", authorities = {"admin"}) @Test public void testFilters() { operationalMetadataAccess.read(() -> { QJpaBatchJobExecution jobExecution = QJpaBatchJobExecution.jpaBatchJobExecution; BooleanBuilder builder = GenericQueryDslFilter.buildFilter(jobExecution, "status==\"COMPLETED,FAILED\""); int i = 0; return null; }); } }