-
Notifications
You must be signed in to change notification settings - Fork 33
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
[1408] Milestone picker: pick next milestone by default
- Loading branch information
Showing
3 changed files
with
192 additions
and
32 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,119 @@ | ||
package tests; | ||
|
||
import backend.resource.TurboMilestone; | ||
import org.junit.BeforeClass; | ||
import org.junit.Test; | ||
import ui.components.pickers.PickerMilestone; | ||
|
||
import java.time.LocalDate; | ||
import java.util.ArrayList; | ||
import java.util.List; | ||
import java.util.Optional; | ||
|
||
import static org.junit.Assert.assertEquals; | ||
|
||
public class PickerMilestoneTest { | ||
|
||
private static final String REPO_ID = "test/testrepo"; | ||
|
||
private static List<PickerMilestone> listWithNoExistingAndSelected, listWithNoDefaultMilestone, | ||
listWithExisting, listWithSelected, listWithNextMilestone, listWithMilestonesWithNoDueDates, | ||
listWithMilesonesWithSameDueDates; | ||
private static PickerMilestone noDueDateMilestone1, noDueDateMilestone2, openMilestone1, openMilestone2, | ||
closedMilestone, existingMilestone, selectedMilestone; | ||
|
||
@BeforeClass | ||
public static void initialize() { | ||
noDueDateMilestone1 = new PickerMilestone(new TurboMilestone(REPO_ID, 1, "noDueDateMilestone1")); | ||
|
||
noDueDateMilestone2 = new PickerMilestone(new TurboMilestone(REPO_ID, 2, "noDueDateMilestone2")); | ||
|
||
openMilestone1 = new PickerMilestone(new TurboMilestone(REPO_ID, 3, "openMilestone1")); | ||
openMilestone1.setDueDate(Optional.of(LocalDate.now().plusDays(1))); | ||
|
||
openMilestone2 = new PickerMilestone(new TurboMilestone(REPO_ID, 4, "openMilestone2")); | ||
openMilestone2.setDueDate(Optional.of(LocalDate.now().plusDays(1))); | ||
|
||
closedMilestone = new PickerMilestone(new TurboMilestone(REPO_ID, 5, "closedMilestone")); | ||
closedMilestone.setOpen(false); | ||
|
||
existingMilestone = new PickerMilestone(new TurboMilestone(REPO_ID, 6, "existingMilestone")); | ||
existingMilestone.setExisting(true); | ||
|
||
selectedMilestone = new PickerMilestone(new TurboMilestone(REPO_ID, 7, "selectedMilestone")); | ||
selectedMilestone.setSelected(true); | ||
|
||
listWithNoExistingAndSelected = new ArrayList<>(); | ||
listWithNoExistingAndSelected.add(openMilestone1); | ||
listWithNoExistingAndSelected.add(openMilestone2); | ||
|
||
listWithNoDefaultMilestone = new ArrayList<>(); | ||
listWithNoDefaultMilestone.add(closedMilestone); | ||
listWithNoDefaultMilestone.add(closedMilestone); | ||
|
||
listWithExisting = new ArrayList<>(); | ||
listWithExisting.add(existingMilestone); | ||
listWithExisting.add(openMilestone1); | ||
|
||
listWithSelected = new ArrayList<>(); | ||
listWithSelected.add(selectedMilestone); | ||
listWithSelected.add(openMilestone1); | ||
|
||
listWithNextMilestone = new ArrayList<>(); | ||
listWithNextMilestone.add(openMilestone1); | ||
listWithNextMilestone.add(closedMilestone); | ||
|
||
listWithMilestonesWithNoDueDates = new ArrayList<>(); | ||
listWithMilestonesWithNoDueDates.add(noDueDateMilestone1); | ||
listWithMilestonesWithNoDueDates.add(noDueDateMilestone2); | ||
|
||
listWithMilesonesWithSameDueDates = listWithNoExistingAndSelected; | ||
} | ||
|
||
@Test | ||
public void getExistingMilestone_noExistingMilestone_returnEmpty() { | ||
assertEquals(Optional.empty(), PickerMilestone.getExistingMilestone(listWithNoExistingAndSelected)); | ||
} | ||
|
||
@Test | ||
public void getExistingMilestone_haveExistingMilestone_returnExistingMilestone() { | ||
assertEquals(Optional.of(existingMilestone), PickerMilestone.getExistingMilestone(listWithExisting)); | ||
} | ||
|
||
@Test | ||
public void getSelectedMilestone_noSelectedMilestone_returnEmpty() { | ||
assertEquals(Optional.empty(), PickerMilestone.getSelectedMilestone(listWithNoExistingAndSelected)); | ||
} | ||
|
||
@Test | ||
public void getSelectedMilestone_haveSelectedMilestone_returnSelectedMilestone() { | ||
assertEquals(Optional.of(selectedMilestone), PickerMilestone.getSelectedMilestone(listWithSelected)); | ||
} | ||
|
||
@Test | ||
public void getDefaultMilestone_noDefaultMilestone_returnEmpty() { | ||
assertEquals(Optional.empty(), PickerMilestone.getDefaultMilestone(listWithNoDefaultMilestone)); | ||
} | ||
|
||
@Test | ||
public void getDefaultMilestone_haveExistingMilestone_returnExistingMilestone() { | ||
assertEquals(Optional.of(existingMilestone), PickerMilestone.getDefaultMilestone(listWithExisting)); | ||
} | ||
|
||
@Test | ||
public void getDefaultMilestone_haveNoExistingButHaveNextMilestone_returnNextMilestone() { | ||
assertEquals(Optional.of(openMilestone1), PickerMilestone.getDefaultMilestone(listWithNextMilestone)); | ||
} | ||
|
||
@Test | ||
public void getDefaultMilestone_haveMilestonesWithNoDueDates_returnMilestoneWithLexicographicallySmallerName() { | ||
assertEquals(Optional.of(noDueDateMilestone1), | ||
PickerMilestone.getDefaultMilestone(listWithMilestonesWithNoDueDates)); | ||
} | ||
|
||
@Test | ||
public void getDefaultMilestone_haveMilestonesWithSameDueDates_returnMilestoneWithLexicographicallySmallerName() { | ||
assertEquals(Optional.of(openMilestone1), | ||
PickerMilestone.getDefaultMilestone(listWithMilesonesWithSameDueDates)); | ||
} | ||
} |