Add SlackTimeScheduling algorithm (#5814)

This commit is contained in:
Hardik Pawar
2024-10-26 12:10:39 +05:30
committed by GitHub
parent 59a8e1d418
commit 92a04f8f8d
3 changed files with 114 additions and 0 deletions

View File

@@ -0,0 +1,48 @@
package com.thealgorithms.scheduling;
import static org.junit.jupiter.api.Assertions.assertEquals;
import java.util.List;
import org.junit.jupiter.api.BeforeEach;
import org.junit.jupiter.api.Test;
public class SlackTimeSchedulingTest {
private SlackTimeScheduling scheduler;
@BeforeEach
public void setup() {
scheduler = new SlackTimeScheduling();
}
@Test
public void testAddAndScheduleSingleTask() {
scheduler.addTask("Task1", 2, 5);
List<String> expected = List.of("Task1");
assertEquals(expected, scheduler.scheduleTasks());
}
@Test
public void testScheduleMultipleTasks() {
scheduler.addTask("Task1", 2, 5);
scheduler.addTask("Task2", 1, 4);
scheduler.addTask("Task3", 3, 7);
List<String> expected = List.of("Task1", "Task2", "Task3");
assertEquals(expected, scheduler.scheduleTasks());
}
@Test
public void testScheduleTasksWithSameSlackTime() {
scheduler.addTask("Task1", 2, 5);
scheduler.addTask("Task2", 3, 6);
scheduler.addTask("Task3", 1, 4);
List<String> expected = List.of("Task1", "Task2", "Task3");
assertEquals(expected, scheduler.scheduleTasks());
}
@Test
public void testEmptyScheduler() {
List<String> expected = List.of();
assertEquals(expected, scheduler.scheduleTasks());
}
}