|
4 | 4 | import static org.mockito.ArgumentMatchers.any; |
5 | 5 | import static org.mockito.Mockito.*; |
6 | 6 |
|
7 | | -import com.databricks.sdk.service.jobs.GetRunRequest; |
8 | | -import com.databricks.sdk.service.jobs.JobsService; |
9 | | -import com.databricks.sdk.service.jobs.Run; |
10 | | -import com.databricks.sdk.service.jobs.RunTask; |
| 7 | +import com.databricks.sdk.service.jobs.*; |
11 | 8 | import java.util.ArrayList; |
12 | 9 | import java.util.Collection; |
| 10 | +import java.util.List; |
13 | 11 | import org.junit.jupiter.api.Test; |
14 | 12 | import org.mockito.Mockito; |
15 | 13 |
|
@@ -82,4 +80,113 @@ private void addIterations(Run run, long... iterationRunIds) { |
82 | 80 | } |
83 | 81 | run.setIterations(iterations); |
84 | 82 | } |
| 83 | + |
| 84 | + private void addJobClusters(Run run, String... clusterKeys) { |
| 85 | + Collection<JobCluster> clusters = new ArrayList<>(); |
| 86 | + for (String clusterKey : clusterKeys) { |
| 87 | + clusters.add(new JobCluster().setJobClusterKey(clusterKey)); |
| 88 | + } |
| 89 | + run.setJobClusters(clusters); |
| 90 | + } |
| 91 | + |
| 92 | + private void addJobParameters(Run run, String... parameterKeys) { |
| 93 | + Collection<JobParameter> parameters = new ArrayList<>(); |
| 94 | + for (String parameterKey : parameterKeys) { |
| 95 | + parameters.add(new JobParameter().setName(parameterKey).setValue(parameterKey)); |
| 96 | + } |
| 97 | + run.setJobParameters(parameters); |
| 98 | + } |
| 99 | + |
| 100 | + @Test |
| 101 | + public void testGetJobPaginationWithTasks() { |
| 102 | + JobsService service = Mockito.mock(JobsService.class); |
| 103 | + Task taskKey1 = new Task().setTaskKey("taskKey1"); |
| 104 | + Task taskKey2 = new Task().setTaskKey("taskKey2"); |
| 105 | + List<Task> tasks = new ArrayList<>(); |
| 106 | + tasks.add(taskKey1); |
| 107 | + tasks.add(taskKey2); |
| 108 | + |
| 109 | + JobCluster jobClusterKey1 = new JobCluster().setJobClusterKey("jobClusterKey1"); |
| 110 | + List<JobCluster> jobClusters = new ArrayList<>(); |
| 111 | + jobClusters.add(jobClusterKey1); |
| 112 | + Job firstPage = |
| 113 | + new Job().setSettings(new JobSettings().setTasks(tasks).setJobClusters(jobClusters)); |
| 114 | + |
| 115 | + when(service.get(any())).thenReturn(firstPage); |
| 116 | + JobsExt jobsExt = new JobsExt(service); |
| 117 | + |
| 118 | + GetJobRequest request = new GetJobRequest(); |
| 119 | + Job job = jobsExt.get(request); |
| 120 | + |
| 121 | + Job expectedJob = |
| 122 | + new Job().setSettings(new JobSettings().setTasks(tasks).setJobClusters(jobClusters)); |
| 123 | + assertEquals(expectedJob, job); |
| 124 | + verify(service, times(1)).get(any()); |
| 125 | + } |
| 126 | + |
| 127 | + @Test |
| 128 | + public void testGetJobPaginationWithJobClusters() { |
| 129 | + JobsService service = Mockito.mock(JobsService.class); |
| 130 | + Job firstPage = new Job().setSettings(new JobSettings()).setNextPageToken("tokenToSecondPage"); |
| 131 | + addTasks(firstPage, "taskKey1", "taskKey2"); |
| 132 | + addJobClusters(firstPage, "clusterKey1", "clusterKey2"); |
| 133 | + addJobParameters(firstPage, "parameterKey1"); |
| 134 | + addJobEnvironments(firstPage, "environmentKey1"); |
| 135 | + |
| 136 | + Job secondPage = new Job().setSettings(new JobSettings()).setNextPageToken("tokenToThirdPage"); |
| 137 | + addTasks(secondPage, "taskKey3", "taskKey4"); |
| 138 | + addJobClusters(secondPage, "clusterKey3"); |
| 139 | + addJobParameters(secondPage, "parameterKey2"); |
| 140 | + addJobEnvironments(secondPage, "environmentKey2"); |
| 141 | + |
| 142 | + Job thirdPage = new Job().setSettings(new JobSettings()); |
| 143 | + addTasks(thirdPage, "taskKey5"); |
| 144 | + addJobParameters(thirdPage, "parameterKey3"); |
| 145 | + |
| 146 | + when(service.get(any())).thenReturn(firstPage).thenReturn(secondPage).thenReturn(thirdPage); |
| 147 | + JobsExt jobsExt = new JobsExt(service); |
| 148 | + |
| 149 | + GetJobRequest request = new GetJobRequest(); |
| 150 | + Job job = jobsExt.get(request); |
| 151 | + |
| 152 | + Job expectedJob = new Job().setSettings(new JobSettings()); |
| 153 | + addTasks(expectedJob, "taskKey1", "taskKey2", "taskKey3", "taskKey4", "taskKey5"); |
| 154 | + addJobClusters(expectedJob, "clusterKey1", "clusterKey2", "clusterKey3"); |
| 155 | + addJobParameters(expectedJob, "parameterKey1", "parameterKey2", "parameterKey3"); |
| 156 | + addJobEnvironments(expectedJob, "environmentKey1", "environmentKey2"); |
| 157 | + assertEquals(expectedJob, job); |
| 158 | + verify(service, times(3)).get(any()); |
| 159 | + } |
| 160 | + |
| 161 | + private void addTasks(Job job, String... taskKeys) { |
| 162 | + Collection<Task> tasks = new ArrayList<>(); |
| 163 | + for (String taskKey : taskKeys) { |
| 164 | + tasks.add(new Task().setTaskKey(taskKey)); |
| 165 | + } |
| 166 | + job.getSettings().setTasks(tasks); |
| 167 | + } |
| 168 | + |
| 169 | + private void addJobClusters(Job job, String... clusterKeys) { |
| 170 | + Collection<JobCluster> jobClusters = new ArrayList<>(); |
| 171 | + for (String clusterKey : clusterKeys) { |
| 172 | + jobClusters.add(new JobCluster().setJobClusterKey(clusterKey)); |
| 173 | + } |
| 174 | + job.getSettings().setJobClusters(jobClusters); |
| 175 | + } |
| 176 | + |
| 177 | + private void addJobParameters(Job job, String... parameterKeys) { |
| 178 | + Collection<JobParameterDefinition> parameters = new ArrayList<>(); |
| 179 | + for (String parameterKey : parameterKeys) { |
| 180 | + parameters.add(new JobParameterDefinition().setName(parameterKey)); |
| 181 | + } |
| 182 | + job.getSettings().setParameters(parameters); |
| 183 | + } |
| 184 | + |
| 185 | + private void addJobEnvironments(Job job, String... environmentKeys) { |
| 186 | + Collection<JobEnvironment> environments = new ArrayList<>(); |
| 187 | + for (String environmentKey : environmentKeys) { |
| 188 | + environments.add(new JobEnvironment().setEnvironmentKey(environmentKey)); |
| 189 | + } |
| 190 | + job.getSettings().setEnvironments(environments); |
| 191 | + } |
85 | 192 | } |
0 commit comments