Search in sources :

Example 46 with Job

use of com.google.cloud.dataproc.v1.Job in project pentaho-platform by pentaho.

the class SchedulerResourceTest method testTriggerNow.

@Test
public void testTriggerNow() throws Exception {
    JobRequest mockJobRequest = mock(JobRequest.class);
    String jobId = "jobId";
    doReturn(jobId).when(mockJobRequest).getJobId();
    Job mockJob = mock(Job.class);
    doReturn(mockJob).when(schedulerResource.schedulerService).triggerNow(jobId);
    Job.JobState mockJobState = Job.JobState.BLOCKED;
    doReturn(mockJobState).when(mockJob).getState();
    Response mockResponse = mock(Response.class);
    doReturn(mockResponse).when(schedulerResource).buildPlainTextOkResponse(mockJobState.name());
    Response testResponse = schedulerResource.triggerNow(mockJobRequest);
    assertEquals(mockResponse, testResponse);
    verify(mockJobRequest, times(1)).getJobId();
    verify(schedulerResource.schedulerService, times(1)).triggerNow(jobId);
    verify(mockJob, times(1)).getState();
    verify(schedulerResource, times(1)).buildPlainTextOkResponse(mockJobState.name());
}
Also used : Response(javax.ws.rs.core.Response) Job(org.pentaho.platform.api.scheduler2.Job) Test(org.junit.Test)

Example 47 with Job

use of com.google.cloud.dataproc.v1.Job in project pentaho-platform by pentaho.

the class SchedulerResourceTest method testRemoveJob.

@Test
public void testRemoveJob() throws Exception {
    JobRequest mockJobRequest = mock(JobRequest.class);
    String jobId = "jobId";
    doReturn(jobId).when(mockJobRequest).getJobId();
    Job mockJob = mock(Job.class);
    doReturn(mockJob).when(schedulerResource.schedulerService).getJob(jobId);
    Job.JobState mockJobState = Job.JobState.BLOCKED;
    doReturn(mockJobState).when(mockJob).getState();
    Response mockRemovedResponse = mock(Response.class);
    doReturn(mockRemovedResponse).when(schedulerResource).buildPlainTextOkResponse("REMOVED");
    Response mockJobStateResponse = mock(Response.class);
    doReturn(mockJobStateResponse).when(schedulerResource).buildPlainTextOkResponse(mockJobState.name());
    // Test 1
    doReturn(true).when(schedulerResource.schedulerService).removeJob(jobId);
    Response testResponse = schedulerResource.removeJob(mockJobRequest);
    assertEquals(mockRemovedResponse, testResponse);
    // Test 2
    doReturn(false).when(schedulerResource.schedulerService).removeJob(jobId);
    testResponse = schedulerResource.removeJob(mockJobRequest);
    assertEquals(mockJobStateResponse, testResponse);
    verify(mockJobRequest, times(3)).getJobId();
    verify(schedulerResource.schedulerService, times(1)).getJob(jobId);
    verify(mockJob, times(1)).getState();
    verify(schedulerResource, times(1)).buildPlainTextOkResponse("REMOVED");
    verify(schedulerResource, times(1)).buildPlainTextOkResponse(mockJobState.name());
}
Also used : Response(javax.ws.rs.core.Response) Job(org.pentaho.platform.api.scheduler2.Job) Test(org.junit.Test)

Example 48 with Job

use of com.google.cloud.dataproc.v1.Job in project pentaho-platform by pentaho.

the class SchedulerResourceTest method testGetJob.

@Test
public void testGetJob() throws Exception {
    String jobId = "jobId";
    String asCronString = "asCronString";
    Job mockJob = mock(Job.class);
    doReturn(mockJob).when(schedulerResource.schedulerService).getJobInfo(jobId);
    Response mockResponse = mock(Response.class);
    doReturn(mockResponse).when(schedulerResource).buildOkResponse(mockJob);
    Response testResponse = schedulerResource.getJob(jobId, asCronString);
    assertEquals(mockResponse, testResponse);
    verify(schedulerResource.schedulerService, times(1)).getJobInfo(jobId);
}
Also used : Response(javax.ws.rs.core.Response) Job(org.pentaho.platform.api.scheduler2.Job) Test(org.junit.Test)

Example 49 with Job

use of com.google.cloud.dataproc.v1.Job in project pentaho-platform by pentaho.

the class RepositoryCleanerSystemListenerTest method doesNotRescheduleJob_IfFoundSame.

@Test
public void doesNotRescheduleJob_IfFoundSame() throws Exception {
    final String oldJobId = "oldJobId";
    Job oldJob = new Job();
    oldJob.setJobTrigger(Frequency.WEEKLY.createTrigger());
    oldJob.setJobId(oldJobId);
    when(scheduler.getJobs(any(IJobFilter.class))).thenReturn(Collections.singletonList(oldJob));
    prepareMp();
    listener.setExecute(Frequency.WEEKLY.getValue());
    assertTrue(listener.startup(null));
    verify(scheduler, never()).removeJob(oldJobId);
    verifyJobHaveNotCreated();
}
Also used : IJobFilter(org.pentaho.platform.api.scheduler2.IJobFilter) Job(org.pentaho.platform.api.scheduler2.Job) Test(org.junit.Test)

Example 50 with Job

use of com.google.cloud.dataproc.v1.Job in project pentaho-platform by pentaho.

the class RepositoryCleanerSystemListenerTest method removesJobs_WhenDisabled.

@Test
public void removesJobs_WhenDisabled() throws Exception {
    final String jobId = "jobId";
    Job job = new Job();
    job.setJobId(jobId);
    when(scheduler.getJobs(any(IJobFilter.class))).thenReturn(Collections.singletonList(job));
    prepareMp();
    listener.setGcEnabled(false);
    assertTrue(listener.startup(null));
    verifyJobRemoved(jobId);
}
Also used : IJobFilter(org.pentaho.platform.api.scheduler2.IJobFilter) Job(org.pentaho.platform.api.scheduler2.Job) Test(org.junit.Test)

Aggregations

Job (org.pentaho.platform.api.scheduler2.Job)94 Test (org.junit.Test)91 Job (io.fabric8.kubernetes.api.model.batch.v1.Job)38 Serializable (java.io.Serializable)25 ArrayList (java.util.ArrayList)24 HashMap (java.util.HashMap)22 SimpleJobTrigger (org.pentaho.platform.api.scheduler2.SimpleJobTrigger)21 Job (com.google.cloud.talent.v4beta1.Job)20 JobScheduleRequest (org.pentaho.platform.web.http.api.resources.JobScheduleRequest)19 ComplexJobTrigger (org.pentaho.platform.api.scheduler2.ComplexJobTrigger)18 SchedulerException (org.pentaho.platform.api.scheduler2.SchedulerException)17 JobServiceClient (com.google.cloud.talent.v4beta1.JobServiceClient)16 Date (java.util.Date)14 IJobFilter (org.pentaho.platform.api.scheduler2.IJobFilter)14 Job (com.google.cloud.video.transcoder.v1.Job)13 TranscoderServiceClient (com.google.cloud.video.transcoder.v1.TranscoderServiceClient)13 JobBuilder (io.fabric8.kubernetes.api.model.batch.v1.JobBuilder)13 IJobTrigger (org.pentaho.platform.api.scheduler2.IJobTrigger)12 Map (java.util.Map)11 Test (org.junit.jupiter.api.Test)10