/* 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.
*/
package org.activiti.engine.test.api.task;
import java.util.Date;
import java.util.List;
import org.activiti.engine.history.HistoricTaskInstance;
import org.activiti.engine.impl.history.HistoryLevel;
import org.activiti.engine.impl.test.PluggableActivitiTestCase;
import org.activiti.engine.task.Task;
/**
* @author Joram Barrez
*/
public class TaskDueDateTest extends PluggableActivitiTestCase {
@Override
protected void tearDown() throws Exception {
for (Task task : taskService.createTaskQuery().list()) {
taskService.deleteTask(task.getId(), true);
}
super.tearDown();
}
/**
* See https://activiti.atlassian.net/browse/ACT-2089
*/
public void testDueDateSortingWithNulls() {
Date now = processEngineConfiguration.getClock().getCurrentTime();
// 4 tasks with a due date
createTask("task0", new Date(now.getTime() + (4L * 7L * 24L * 60L * 60L * 1000L))); // 4 weeks in future
createTask("task1", new Date(now.getTime() + (2 * 24L * 60L * 60L * 1000L))); // 2 days in future
createTask("task2", new Date(now.getTime() + (7L * 24L * 60L * 60L * 1000L))); // 1 week in future
createTask("task3", new Date(now.getTime() + (24L * 60L * 60L * 1000L))); // 1 day in future
// 2 tasks without a due date
createTask("task4", null);
createTask("task5", null);
assertEquals(6, taskService.createTaskQuery().count());
// Sorting on due date asc should put the nulls at the end
List<Task> tasks = taskService.createTaskQuery().orderByDueDateNullsLast().asc().list();
for (int i=0; i<4; i++) {
assertNotNull(tasks.get(i).getDueDate());
}
assertEquals("task3", tasks.get(0).getName());
assertEquals("task1", tasks.get(1).getName());
assertEquals("task2", tasks.get(2).getName());
assertEquals("task0", tasks.get(3).getName());
assertNull(tasks.get(4).getDueDate());
assertNull(tasks.get(5).getDueDate());
// The same, but now desc
tasks = taskService.createTaskQuery().orderByDueDateNullsLast().desc().list();
for (int i=0; i<4; i++) {
assertNotNull(tasks.get(i).getDueDate());
}
assertEquals("task0", tasks.get(0).getName());
assertEquals("task2", tasks.get(1).getName());
assertEquals("task1", tasks.get(2).getName());
assertEquals("task3", tasks.get(3).getName());
assertNull(tasks.get(4).getDueDate());
assertNull(tasks.get(5).getDueDate());
// The same but now nulls first
tasks = taskService.createTaskQuery().orderByDueDateNullsFirst().asc().list();
assertNull(tasks.get(0).getDueDate());
assertNull(tasks.get(1).getDueDate());
assertEquals("task3", tasks.get(2).getName());
assertEquals("task1", tasks.get(3).getName());
assertEquals("task2", tasks.get(4).getName());
assertEquals("task0", tasks.get(5).getName());
// And now desc
tasks = taskService.createTaskQuery().orderByDueDateNullsFirst().desc().list();
assertNull(tasks.get(0).getDueDate());
assertNull(tasks.get(1).getDueDate());
assertEquals("task0", tasks.get(2).getName());
assertEquals("task2", tasks.get(3).getName());
assertEquals("task1", tasks.get(4).getName());
assertEquals("task3", tasks.get(5).getName());
if (processEngineConfiguration.getHistoryLevel().isAtLeast(HistoryLevel.AUDIT)) {
// And now the same, but for history!
List<HistoricTaskInstance> historicTasks = historyService.createHistoricTaskInstanceQuery().orderByDueDateNullsLast().asc().list();
for (int i=0; i<4; i++) {
assertNotNull(historicTasks.get(i).getDueDate());
}
assertEquals("task3", historicTasks.get(0).getName());
assertEquals("task1", historicTasks.get(1).getName());
assertEquals("task2", historicTasks.get(2).getName());
assertEquals("task0", historicTasks.get(3).getName());
assertNull(historicTasks.get(4).getDueDate());
assertNull(historicTasks.get(5).getDueDate());
// The same, but now desc
historicTasks = historyService.createHistoricTaskInstanceQuery().orderByDueDateNullsLast().desc().list();
for (int i=0; i<4; i++) {
assertNotNull(historicTasks.get(i).getDueDate());
}
assertEquals("task0", historicTasks.get(0).getName());
assertEquals("task2", historicTasks.get(1).getName());
assertEquals("task1", historicTasks.get(2).getName());
assertEquals("task3", historicTasks.get(3).getName());
assertNull(historicTasks.get(4).getDueDate());
assertNull(historicTasks.get(5).getDueDate());
// The same but now nulls first
historicTasks = historyService.createHistoricTaskInstanceQuery().orderByDueDateNullsFirst().asc().list();
assertNull(historicTasks.get(0).getDueDate());
assertNull(historicTasks.get(1).getDueDate());
assertEquals("task3", historicTasks.get(2).getName());
assertEquals("task1", historicTasks.get(3).getName());
assertEquals("task2", historicTasks.get(4).getName());
assertEquals("task0", historicTasks.get(5).getName());
// And now desc
historicTasks = historyService.createHistoricTaskInstanceQuery().orderByDueDateNullsFirst().desc().list();
assertNull(historicTasks.get(0).getDueDate());
assertNull(historicTasks.get(1).getDueDate());
assertEquals("task0", historicTasks.get(2).getName());
assertEquals("task2", historicTasks.get(3).getName());
assertEquals("task1", historicTasks.get(4).getName());
assertEquals("task3", historicTasks.get(5).getName());
}
}
private Task createTask(String name, Date dueDate) {
Task task = taskService.newTask();
task.setName(name);
task.setDueDate(dueDate);
taskService.saveTask(task);
return task;
}
}