/*
* This file is part of LibrePlan
*
* Copyright (C) 2009-2010 Fundación para o Fomento da Calidade Industrial e
* Desenvolvemento Tecnolóxico de Galicia
* Copyright (C) 2010-2011 Igalia, S.L.
*
* This program is free software: you can redistribute it and/or modify
* it under the terms of the GNU Affero General Public License as published by
* the Free Software Foundation, either version 3 of the License, or
* (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU Affero General Public License for more details.
*
* You should have received a copy of the GNU Affero General Public License
* along with this program. If not, see <http://www.gnu.org/licenses/>.
*/
package org.libreplan.business.test.resources.entities;
import static org.junit.Assert.assertEquals;
import static org.hamcrest.CoreMatchers.equalTo;
import static org.junit.Assert.assertFalse;
import static org.junit.Assert.assertThat;
import static org.junit.Assert.assertTrue;
import static org.libreplan.business.test.resources.daos.CriterionSatisfactionDAOTest.year;
import java.util.ArrayList;
import java.util.Collections;
import java.util.List;
import org.joda.time.LocalDate;
import org.junit.Test;
import org.libreplan.business.resources.entities.Criterion;
import org.libreplan.business.resources.entities.CriterionSatisfaction;
import org.libreplan.business.resources.entities.Interval;
import org.libreplan.business.resources.entities.Worker;
import org.libreplan.business.test.resources.daos.CriterionDAOTest;
/**
* Tests for {@link CriterionSatisfaction} <br />
* @author Óscar González Fernández <ogonzalez@igalia.com>
*/
public class CriterionSatisfactionTest {
@Test
public void testFinish() {
final Criterion criterion = CriterionDAOTest.createValidCriterion();
Worker worker = Worker.create("firstName", "surName", "2333232");
CriterionSatisfaction criterionSatisfaction = CriterionSatisfaction.create(year(2000), criterion, worker);
LocalDate end = year(2006);
criterionSatisfaction.finish(end);
assertTrue(criterionSatisfaction.isFinished());
assertEquals(end, criterionSatisfaction.getEndDate());
}
@Test
public void canFinishWhenItStarted() {
final Criterion criterion = CriterionDAOTest.createValidCriterion();
Worker worker = Worker.create("firstName", "surName", "2333232");
LocalDate start = year(2000);
CriterionSatisfaction criterionSatisfaction = CriterionSatisfaction.create(start, criterion, worker);
criterionSatisfaction.finish(start);
assertTrue(criterionSatisfaction.isFinished());
}
@Test(expected = IllegalArgumentException.class)
public void testCantFinishBeforeStart() {
final Criterion criterion = CriterionDAOTest.createValidCriterion();
Worker worker = Worker.create("firstName", "surName", "2333232");
CriterionSatisfaction criterionSatisfaction = CriterionSatisfaction.create(year(2000), criterion, worker);
criterionSatisfaction.finish(year(1999));
}
@Test
public void testIsEnforcedAtDate() {
final Criterion criterion = CriterionDAOTest.createValidCriterion();
Worker worker = Worker.create("firstName", "surName", "2333232");
CriterionSatisfaction criterionSatisfaction = CriterionSatisfaction.create(year(2000), criterion, worker);
assertTrue(criterionSatisfaction.isEnforcedAt(year(3000)));
assertTrue(criterionSatisfaction.isEnforcedAt(year(2000)));
assertFalse(criterionSatisfaction.isEnforcedAt(year(1999)));
criterionSatisfaction.finish(year(2005));
assertFalse(criterionSatisfaction.isEnforcedAt(year(3000)));
assertFalse(criterionSatisfaction.isAlwaysEnforcedIn(Interval.range(
year(2001), year(2006))));
assertTrue(criterionSatisfaction.isEnforcedAt(year(2000)));
assertTrue(criterionSatisfaction.isEnforcedAt(year(2001)));
assertFalse(criterionSatisfaction.isEnforcedAt(year(1999)));
}
@Test
public void testEnforcedAtSomePointInInterval() {
final Criterion criterion = CriterionDAOTest.createValidCriterion();
Worker worker = Worker.create("firstName", "surName", "2333232");
CriterionSatisfaction criterionSatisfaction = CriterionSatisfaction.create(year(2000), criterion, worker);
assertTrue(criterionSatisfaction.overlapsWith(Interval.range(
year(2001), year(4000))));
assertTrue(criterionSatisfaction.overlapsWith(Interval.range(
year(2005), year(4000))));
assertTrue(criterionSatisfaction.overlapsWith(Interval.range(
year(1999), year(2001))));
criterionSatisfaction.finish(year(2004));
assertTrue(criterionSatisfaction.overlapsWith(Interval.range(
year(2002), year(4000))));
assertTrue(criterionSatisfaction.overlapsWith(Interval.range(
year(2002), null)));
assertFalse(criterionSatisfaction.overlapsWith(Interval.range(
year(2005), year(4000))));
assertTrue(criterionSatisfaction.overlapsWith(Interval.range(
year(1999), null)));
assertFalse(criterionSatisfaction.overlapsWith(Interval.range(
year(1990), year(1995))));
}
@Test
public void testCriterionSatisfactionsStartComparator() {
final Criterion criterion = CriterionDAOTest.createValidCriterion();
Worker worker = Worker.create("firstName", "surName", "2333232");
Interval[] intervals = { Interval.from(year(1000)),
Interval.range(year(1100), year(9000)),
Interval.point(year(1101)), Interval.from(year(1200)),
Interval.range(year(3000), year(4000)) };
List<CriterionSatisfaction> orderedSatisfactions = new ArrayList<CriterionSatisfaction>();
for (Interval interval : intervals) {
orderedSatisfactions.add(CriterionSatisfaction.create(criterion, worker, interval));
}
List<CriterionSatisfaction> copy = new ArrayList<CriterionSatisfaction>(
orderedSatisfactions);
assertThat(copy, equalTo(orderedSatisfactions));
for (int i = 0; i < 20; i++) {
Collections.shuffle(copy);
Collections.sort(copy, CriterionSatisfaction.BY_START_COMPARATOR);
assertThat(copy, equalTo(orderedSatisfactions));
}
}
@Test
public void testGoesBeforeWithoutOverlapping() {
final Criterion criterion = CriterionDAOTest.createValidCriterion();
CriterionSatisfaction posterior = CriterionSatisfaction.create();
posterior.setCriterion(criterion);
posterior.setStartDate(year(2000));
posterior.setEndDate(year(2008));
Interval[] goesAfterOrOverlapsIntervals = { Interval.from(year(2000)),
Interval.from(year(2001)), Interval.from(year(1999)),
Interval.range(year(1999), year(2001)),
Interval.from(year(2009)),
Interval.range(year(2009), year(2012)) };
for (Interval interval : goesAfterOrOverlapsIntervals) {
CriterionSatisfaction copied = posterior.copy();
copied.setStartDate(interval.getStart());
copied.setEndDate(interval.getEnd());
assertFalse(interval + " shouldn't go before", copied
.goesBeforeWithoutOverlapping(posterior));
}
Interval[] goesBeforeWithoutOverlappingInterval = {
Interval.point(year(2000)),
Interval.range(year(1990), year(2000)),
Interval.range(year(1990), year(1997)) };
for (Interval interval : goesBeforeWithoutOverlappingInterval) {
CriterionSatisfaction copied = posterior.copy();
copied.setStartDate(interval.getStart());
copied.setEndDate(interval.getEnd());
assertTrue(copied.goesBeforeWithoutOverlapping(posterior));
}
}
}