From fbd9771c8a283d5e4ecb27ae8379bbc9d73ec4ba Mon Sep 17 00:00:00 2001 From: Tobias Schneider Date: Thu, 12 Dec 2024 00:27:35 +0100 Subject: [PATCH] WIP: first fluent checker tests --- .../jollyday/tests/HolidayChecker.java | 86 ------ .../jollyday/tests/HolidayCheckerApi.java | 33 ++ .../jollyday/tests/HolidayCheckerFluent.java | 290 ++++++++++++++++++ .../jollyday/tests/country/HolidayADTest.java | 33 +- .../jollyday/tests/country/HolidayAETest.java | 31 +- .../jollyday/tests/country/HolidayATTest.java | 45 +-- 6 files changed, 379 insertions(+), 139 deletions(-) delete mode 100644 jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayChecker.java create mode 100644 jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayCheckerApi.java create mode 100644 jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayCheckerFluent.java diff --git a/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayChecker.java b/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayChecker.java deleted file mode 100644 index 8a685ae94..000000000 --- a/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayChecker.java +++ /dev/null @@ -1,86 +0,0 @@ -package de.focus_shift.jollyday.tests; - -import de.focus_shift.jollyday.core.Holiday; -import de.focus_shift.jollyday.core.HolidayCalendar; -import de.focus_shift.jollyday.core.HolidayManager; -import de.focus_shift.jollyday.core.HolidayType; -import net.jqwik.api.Arbitraries; -import net.jqwik.time.api.arbitraries.YearArbitrary; - -import java.time.LocalDate; -import java.time.Month; -import java.time.Year; -import java.util.Set; - -import static de.focus_shift.jollyday.core.HolidayType.PUBLIC_HOLIDAY; -import static de.focus_shift.jollyday.core.ManagerParameters.create; -import static org.assertj.core.api.Assertions.assertThat; - -public class HolidayChecker { - - public static final Year YEAR_FROM_DEFAULT = Year.of(1900); - public static final Year YEAR_TO_DEFAULT = Year.of(2500); - - public static void assertChristian(final HolidayCalendar calendar, final String propertiesKey) { - assertChristian(calendar, YEAR_FROM_DEFAULT, YEAR_TO_DEFAULT, propertiesKey, PUBLIC_HOLIDAY); - } - public static void assertChristian(final HolidayCalendar calendar, final Year from, final Year to, final String propertiesKey) { - assertChristian(calendar, from, to, propertiesKey, PUBLIC_HOLIDAY); - } - public static void assertChristian(final HolidayCalendar calendar, final Year from, final Year to, final String propertiesKey, final HolidayType holidayType) { - checkByKey(calendar, from, to, "christian." + propertiesKey, holidayType); - } - - public static void assertIslamic(final HolidayCalendar calendar, final String propertiesKey) { - assertIslamic(calendar, YEAR_FROM_DEFAULT, YEAR_TO_DEFAULT, propertiesKey, PUBLIC_HOLIDAY); - } - public static void assertIslamic(final HolidayCalendar calendar, final Year from, final Year to, final String propertiesKey) { - assertIslamic(calendar, from, to, propertiesKey, PUBLIC_HOLIDAY); - } - public static void assertIslamic(final HolidayCalendar calendar, final Year from, final Year to, final String propertiesKey, final HolidayType holidayType) { - checkByKey(calendar, from, to, "islamic." + propertiesKey, holidayType); - } - - - public static void assertFixed(final HolidayCalendar calendar, final Month month, final int day, final String propertiesKey) { - checkByDate(calendar, "", YEAR_FROM_DEFAULT, YEAR_TO_DEFAULT, month, day, propertiesKey, PUBLIC_HOLIDAY); - } - public static void assertFixed(final HolidayCalendar calendar, final String hierarchy, final Month month, final int day, final String propertiesKey) { - checkByDate(calendar, hierarchy, YEAR_FROM_DEFAULT, YEAR_TO_DEFAULT, month, day, propertiesKey, PUBLIC_HOLIDAY); - } - public static void assertFixed(final HolidayCalendar calendar, final Month month, final int day, final String propertiesKey, final HolidayType holidayType) { - checkByDate(calendar, "", YEAR_FROM_DEFAULT, YEAR_TO_DEFAULT, month, day, propertiesKey, holidayType); - } - public static void assertFixed(final HolidayCalendar calendar, final Year from, final Year to, final Month month, final int day, final String propertiesKey) { - checkByDate(calendar, "", from, to, month, day, propertiesKey, PUBLIC_HOLIDAY); - } - public static void assertFixed(final HolidayCalendar calendar, final Year from, final Year to , final Month month, final int day, final String propertiesKey, final HolidayType holidayType) { - checkByDate(calendar, "", from, to, month, day, propertiesKey, holidayType); - } - - private static void checkByKey(final HolidayCalendar calendar, final Year from, final Year to, final String propertiesKey, final HolidayType holidayType) { - ((YearArbitrary) Arbitraries.defaultFor(Year.class)) - .between(from.getValue(), to.getValue()) - .forEachValue(year -> { - final Set holidays = HolidayManager.getInstance(create(calendar)).getHolidays(year); - assertThat(holidays) - .isNotEmpty() - .filteredOn(holiday -> holiday.getPropertiesKey().equals(propertiesKey)) - .extracting(Holiday::getType) - .contains(holidayType); - } - ); - } - - private static void checkByDate(final HolidayCalendar calendar, final String hierarchy, final Year from, final Year to, final Month month, final int day, final String propertiesKey, final HolidayType holidayType) { - ((YearArbitrary) Arbitraries.defaultFor(Year.class)) - .between(from.getValue(), to.getValue()) - .forEachValue(year -> { - final Set holidays = HolidayManager.getInstance(create(calendar)).getHolidays(year, hierarchy); - assertThat(holidays) - .isNotEmpty() - .contains(new Holiday(LocalDate.of(year.getValue(), month, day), propertiesKey, holidayType)); - } - ); - } -} diff --git a/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayCheckerApi.java b/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayCheckerApi.java new file mode 100644 index 000000000..430970586 --- /dev/null +++ b/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayCheckerApi.java @@ -0,0 +1,33 @@ +package de.focus_shift.jollyday.tests; + +import de.focus_shift.jollyday.core.HolidayCalendar; +import de.focus_shift.jollyday.core.HolidayType; + +import java.time.Month; +import java.time.Year; + +public interface HolidayCheckerApi { + + interface Holiday { + Between hasFixedHoliday(final String propertyKey, final Month month, final int day); + Between hasFixedHoliday(final String propertyKey, final Month month, final int day, final HolidayType type); + + Between hasChristianHoliday(final String propertyKey); + Between hasChristianHoliday(final String propertyKey, final HolidayType type); + + Between hasIslamicHoliday(final String propertyKey); + Between hasIslamicHoliday(final String propertyKey, final HolidayType type); + } + + interface Between { + Between between(Year from, Year to); + + Holiday and(); + + void check(); + } + + static HolidayCheckerFluent assertFor(final HolidayCalendar calendar) { + return new HolidayCheckerFluent(calendar); + } +} diff --git a/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayCheckerFluent.java b/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayCheckerFluent.java new file mode 100644 index 000000000..1514f50b5 --- /dev/null +++ b/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/HolidayCheckerFluent.java @@ -0,0 +1,290 @@ +package de.focus_shift.jollyday.tests; + +import de.focus_shift.jollyday.core.Holiday; +import de.focus_shift.jollyday.core.HolidayCalendar; +import de.focus_shift.jollyday.core.HolidayManager; +import de.focus_shift.jollyday.core.HolidayType; +import net.jqwik.api.Arbitraries; +import net.jqwik.time.api.arbitraries.YearArbitrary; +import org.junit.jupiter.api.Assertions; + +import java.time.LocalDate; +import java.time.Month; +import java.time.Year; +import java.util.ArrayList; +import java.util.Collections; +import java.util.Iterator; +import java.util.List; +import java.util.NoSuchElementException; +import java.util.Objects; +import java.util.Set; + +import static de.focus_shift.jollyday.core.ManagerParameters.create; +import static de.focus_shift.jollyday.tests.HolidayCheckerFluent.Category.BY_DAY; +import static de.focus_shift.jollyday.tests.HolidayCheckerFluent.Category.BY_KEY; +import static org.assertj.core.api.Assertions.assertThat; + +public class HolidayCheckerFluent implements HolidayCheckerApi.Holiday, HolidayCheckerApi.Between { + + enum Category { + BY_DAY, + BY_KEY + } + + private final HolidayCalendar calendar; + private String propertyKey; + private Month month; + private int day; + private HolidayType type; + private Category category; + private List validRanges = new ArrayList<>(); + + private final List checks = new ArrayList<>(); + + public HolidayCheckerFluent(HolidayCalendar calendar) { + this.calendar = calendar; + } + + + @Override + public HolidayCheckerApi.Between hasChristianHoliday(final String propertyKey) { + return hasChristianHoliday(propertyKey, HolidayType.PUBLIC_HOLIDAY); + } + + @Override + public HolidayCheckerApi.Between hasChristianHoliday(final String propertyKey, final HolidayType type) { + Objects.requireNonNull(propertyKey, "propertyKey is required"); + Objects.requireNonNull(type, "holiday type is required"); + + this.category = BY_KEY; + this.propertyKey = "christian." + propertyKey; + this.type = type; + + return this; + } + + @Override + public HolidayCheckerApi.Between hasIslamicHoliday(final String propertyKey) { + return hasIslamicHoliday(propertyKey, HolidayType.PUBLIC_HOLIDAY); + } + + @Override + public HolidayCheckerApi.Between hasIslamicHoliday(final String propertyKey, final HolidayType type) { + Objects.requireNonNull(propertyKey, "propertyKey is required"); + Objects.requireNonNull(type, "holiday type is required"); + + this.category = BY_KEY; + this.propertyKey = "islamic." + propertyKey; + this.type = type; + + return this; + } + + @Override + public HolidayCheckerApi.Between hasFixedHoliday(final String propertyKey, final Month month, final int day) { + return hasFixedHoliday(propertyKey, month, day, HolidayType.PUBLIC_HOLIDAY); + } + + @Override + public HolidayCheckerApi.Between hasFixedHoliday(final String propertyKey, final Month month, final int day, final HolidayType type) { + + Objects.requireNonNull(propertyKey, "propertyKey is required"); + Objects.requireNonNull(month, "month is required"); + if (day >= 32 || day <= 0) { + throw new IllegalArgumentException("day must be between 1 and 31"); + } + Objects.requireNonNull(type, "holiday type is required"); + + this.category = BY_DAY; + this.propertyKey = propertyKey; + this.month = month; + this.day = day; + this.type = type; + + return this; + } + + @Override + public HolidayCheckerApi.Between between(final Year from, Year to) { + validRanges.add(new YearRange(from, to)); + return this; + } + + @Override + public HolidayCheckerApi.Holiday and() { + checks.add(new HolidayCheck(calendar, propertyKey, month, day, type, validRanges, category)); + + this.propertyKey = null; + this.month = null; + this.day = 0; + this.type = null; + this.category = null; + this.validRanges = new ArrayList<>(); + + return this; + } + + @Override + public void check() { + checks.add(new HolidayCheck(calendar, propertyKey, month, day, type, validRanges, category)); + + this.propertyKey = null; + this.month = null; + this.day = 0; + this.type = null; + this.category = null; + this.validRanges = new ArrayList<>(); + + for (HolidayCheck check : checks) { + switch (check.category) { + case BY_DAY: + checkByDate(check); + break; + case BY_KEY: + checkByKey(check); + break; + default: + throw new IllegalStateException("Unexpected value: " + check.category); + } + } + + this.checks.clear(); + } + + private void checkByDate(HolidayCheck check) { + for (final YearRange validRange : check.getValidRanges()) { + ((YearArbitrary) Arbitraries.defaultFor(Year.class)) + .between(validRange.getFrom().getValue(), validRange.getTo().getValue()) + .forEachValue(year -> { + final Set holidays = HolidayManager.getInstance(create(check.calendar)).getHolidays(year); + assertThat(holidays) + .isNotEmpty() + .contains(new Holiday(LocalDate.of(year.getValue(), check.getMonth(), check.getDay()), check.getPropertiesKey(), check.getHolidayType())); + } + ); + } + } + + private void checkByKey(HolidayCheck check) { + for (final YearRange validRange : check.getValidRanges()) { + ((YearArbitrary) Arbitraries.defaultFor(Year.class)) + .between(validRange.getFrom().getValue(), validRange.getTo().getValue()) + .forEachValue(year -> { + final Set holidays = HolidayManager.getInstance(create(check.calendar)).getHolidays(year); + assertThat(holidays) + .isNotEmpty() + .filteredOn(holiday -> holiday.getPropertiesKey().equals(check.getPropertiesKey())) + .extracting(Holiday::getType) + .contains(check.getHolidayType()); + } + ); + } + } + + private static final class HolidayCheck { + + private final HolidayCalendar calendar; + private final List validRanges; + private final Month month; + private final int day; + private final String propertiesKey; + private final HolidayType holidayType; + private final Category category; + + HolidayCheck(HolidayCalendar calendar, + String propertiesKey, Month month, int day, HolidayType holidayType, + List validRanges, Category category + ) { + this.calendar = calendar; + this.propertiesKey = propertiesKey; + this.month = month; + this.day = day; + this.holidayType = holidayType; + this.validRanges = validRanges.isEmpty() ? List.of(new YearRange(Year.of(1900), Year.of(2500))) : Collections.unmodifiableList(validRanges); + this.category = category; + } + + public HolidayCalendar getCalendar() { + return calendar; + } + + public List getValidRanges() { + return validRanges; + } + + public Month getMonth() { + return month; + } + + public int getDay() { + return day; + } + + public String getPropertiesKey() { + return propertiesKey; + } + + public HolidayType getHolidayType() { + return holidayType; + } + + public Category getCategory() { + return category; + } + } + + private static class YearRange implements Iterable { + + private final Year from; + private final Year to; + + YearRange(final Year from, final Year to) { + if (from != null && to != null) { + Assertions.assertFalse(from.isAfter(to), "To must be greater than or equal to the from year."); + } + this.from = from; + this.to = to; + } + + public Year getFrom() { + return from; + } + + public Year getTo() { + return to; + } + + @Override + public Iterator iterator() { + return new YearRangeIterator(from, to); + } + + private static final class YearRangeIterator implements Iterator { + + private final Year endYear; + private Year cursor; + + YearRangeIterator(final Year startYear, final Year endYear) { + this.cursor = startYear; + this.endYear = endYear; + } + + @Override + public boolean hasNext() { + return cursor.isBefore(endYear) || cursor.equals(endYear); + } + + @Override + public Year next() { + + if (cursor.isAfter(endYear)) { + throw new NoSuchElementException("next year is after endYear which is not in range anymore."); + } + + final Year current = cursor; + cursor = cursor.plusYears(1); + return current; + } + } + } +} diff --git a/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayADTest.java b/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayADTest.java index ddd758e13..4f7bdc963 100644 --- a/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayADTest.java +++ b/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayADTest.java @@ -3,8 +3,7 @@ import org.junit.jupiter.api.Test; import static de.focus_shift.jollyday.core.HolidayCalendar.ANDORRA; -import static de.focus_shift.jollyday.tests.HolidayChecker.assertChristian; -import static de.focus_shift.jollyday.tests.HolidayChecker.assertFixed; +import static de.focus_shift.jollyday.tests.HolidayCheckerApi.assertFor; import static java.time.Month.AUGUST; import static java.time.Month.DECEMBER; import static java.time.Month.JANUARY; @@ -17,19 +16,21 @@ class HolidayADTest { @Test void ensuresHolidays() { - assertFixed(ANDORRA, JANUARY, 1, "NEW_YEAR"); - assertFixed(ANDORRA, JANUARY, 6, "EPIPHANY"); - assertFixed(ANDORRA, MARCH, 14, "CONSTITUTION_DAY"); - assertFixed(ANDORRA, MAY, 1, "LABOUR_DAY"); - assertFixed(ANDORRA, AUGUST, 15, "ASSUMPTION_DAY"); - assertFixed(ANDORRA, SEPTEMBER, 8, "NATIONAL_DAY"); - assertFixed(ANDORRA, NOVEMBER, 1, "ALL_SAINTS"); - assertFixed(ANDORRA, DECEMBER, 8, "IMMACULATE_CONCEPTION"); - assertFixed(ANDORRA, DECEMBER, 25, "CHRISTMAS"); - assertFixed(ANDORRA, DECEMBER, 26, "STEPHENS"); - assertChristian(ANDORRA, "CARNIVAL"); - assertChristian(ANDORRA, "GOOD_FRIDAY"); - assertChristian(ANDORRA, "EASTER_MONDAY"); - assertChristian(ANDORRA, "WHIT_MONDAY"); + assertFor(ANDORRA) + .hasFixedHoliday("NEW_YEAR", JANUARY, 1).and() + .hasFixedHoliday("EPIPHANY", JANUARY, 6).and() + .hasFixedHoliday("CONSTITUTION_DAY", MARCH, 14).and() + .hasFixedHoliday("LABOUR_DAY", MAY, 1).and() + .hasFixedHoliday("ASSUMPTION_DAY", AUGUST, 15).and() + .hasFixedHoliday("NATIONAL_DAY", SEPTEMBER, 8).and() + .hasFixedHoliday("ALL_SAINTS", NOVEMBER, 1).and() + .hasFixedHoliday("IMMACULATE_CONCEPTION", DECEMBER, 8).and() + .hasFixedHoliday("CHRISTMAS", DECEMBER, 25).and() + .hasFixedHoliday("STEPHENS", DECEMBER, 26).and() + .hasChristianHoliday("CARNIVAL").and() + .hasChristianHoliday("GOOD_FRIDAY").and() + .hasChristianHoliday("EASTER_MONDAY").and() + .hasChristianHoliday("WHIT_MONDAY") + .check(); } } diff --git a/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayAETest.java b/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayAETest.java index 270b9864b..767fc93f5 100644 --- a/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayAETest.java +++ b/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayAETest.java @@ -5,8 +5,7 @@ import java.time.Year; import static de.focus_shift.jollyday.core.HolidayCalendar.UNITED_ARAB_EMIRATES; -import static de.focus_shift.jollyday.tests.HolidayChecker.assertFixed; -import static de.focus_shift.jollyday.tests.HolidayChecker.assertIslamic; +import static de.focus_shift.jollyday.tests.HolidayCheckerApi.assertFor; import static java.time.Month.DECEMBER; import static java.time.Month.JANUARY; @@ -17,18 +16,20 @@ class HolidayAETest { @Test void ensuresHolidays() { - assertFixed(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, JANUARY, 1, "NEW_YEAR"); - assertFixed(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, DECEMBER, 1, "AE_COMMEMORATION_DAY"); - assertFixed(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, DECEMBER, 2, "NATIONAL_DAY"); - assertFixed(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, DECEMBER, 3, "NATIONAL_DAY"); - assertIslamic(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, "RAMADAN_END"); - assertIslamic(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, "ID_AL_FITR"); - assertIslamic(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, "ID_AL_FITR_2"); - assertIslamic(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, "ID_AL_FITR_3"); - assertIslamic(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, "ARAFAAT"); - assertIslamic(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, "ID_UL_ADHA"); - assertIslamic(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, "ID_UL_ADHA_2"); - assertIslamic(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, "ID_UL_ADHA_3"); - assertIslamic(UNITED_ARAB_EMIRATES, YEAR_FROM, YEAR_TO, "NEWYEAR"); + assertFor(UNITED_ARAB_EMIRATES) + .hasFixedHoliday("NEW_YEAR", JANUARY, 1).between(YEAR_FROM, YEAR_TO).and() + .hasFixedHoliday("AE_COMMEMORATION_DAY", DECEMBER, 1).between(YEAR_FROM, YEAR_TO).and() + .hasFixedHoliday("NATIONAL_DAY", DECEMBER, 2).between(YEAR_FROM, YEAR_TO).and() + .hasFixedHoliday("NATIONAL_DAY", DECEMBER, 3).between(YEAR_FROM, YEAR_TO).and() + .hasIslamicHoliday("RAMADAN_END").between(YEAR_FROM, YEAR_TO).and() + .hasIslamicHoliday("ID_AL_FITR").between(YEAR_FROM, YEAR_TO).and() + .hasIslamicHoliday("ID_AL_FITR_2").between(YEAR_FROM, YEAR_TO).and() + .hasIslamicHoliday("ID_AL_FITR_3").between(YEAR_FROM, YEAR_TO).and() + .hasIslamicHoliday("ARAFAAT").between(YEAR_FROM, YEAR_TO).and() + .hasIslamicHoliday("ID_UL_ADHA").between(YEAR_FROM, YEAR_TO).and() + .hasIslamicHoliday("ID_UL_ADHA_2").between(YEAR_FROM, YEAR_TO).and() + .hasIslamicHoliday("ID_UL_ADHA_3").between(YEAR_FROM, YEAR_TO).and() + .hasIslamicHoliday("NEWYEAR").between(YEAR_FROM, YEAR_TO) + .check(); } } diff --git a/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayATTest.java b/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayATTest.java index 1077b507f..920d554c4 100644 --- a/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayATTest.java +++ b/jollyday-tests/src/test/java/de/focus_shift/jollyday/tests/country/HolidayATTest.java @@ -4,39 +4,40 @@ import static de.focus_shift.jollyday.core.HolidayCalendar.AUSTRIA; import static de.focus_shift.jollyday.core.HolidayType.OBSERVANCE; -import static de.focus_shift.jollyday.tests.HolidayChecker.assertChristian; -import static de.focus_shift.jollyday.tests.HolidayChecker.assertFixed; +import static de.focus_shift.jollyday.tests.HolidayCheckerApi.assertFor; import static java.time.Month.AUGUST; import static java.time.Month.DECEMBER; import static java.time.Month.JANUARY; -import static java.time.Month.MARCH; import static java.time.Month.MAY; import static java.time.Month.NOVEMBER; import static java.time.Month.OCTOBER; -import static java.time.Month.SEPTEMBER; class HolidayATTest { @Test void ensuresHolidays() { - assertFixed(AUSTRIA, JANUARY, 1, "NEW_YEAR"); - assertFixed(AUSTRIA, JANUARY, 6, "EPIPHANY"); - assertFixed(AUSTRIA, MAY, 1, "LABOUR_DAY"); - assertFixed(AUSTRIA, AUGUST, 15, "ASSUMPTION_DAY"); - assertFixed(AUSTRIA, OCTOBER, 26, "NATIONAL_DAY"); - assertFixed(AUSTRIA, NOVEMBER, 1, "ALL_SAINTS"); - assertFixed(AUSTRIA, DECEMBER, 8, "IMMACULATE_CONCEPTION"); - assertFixed(AUSTRIA, DECEMBER, 24, "CHRISTMAS_EVE", OBSERVANCE); - assertFixed(AUSTRIA, DECEMBER, 25, "CHRISTMAS"); - assertFixed(AUSTRIA, DECEMBER, 26, "STEPHENS"); - assertFixed(AUSTRIA, DECEMBER, 31, "NEW_YEARS_EVE", OBSERVANCE); - assertChristian(AUSTRIA, "EASTER"); - assertChristian(AUSTRIA, "EASTER_MONDAY"); - assertChristian(AUSTRIA, "ASCENSION_DAY"); - assertChristian(AUSTRIA, "WHIT_MONDAY"); - assertChristian(AUSTRIA, "CORPUS_CHRISTI"); - assertFixed(AUSTRIA, "1", NOVEMBER, 11, "MARTINS_DAY"); + assertFor(AUSTRIA) + .hasFixedHoliday("NEW_YEAR", JANUARY, 1).and() + .hasFixedHoliday("EPIPHANY", JANUARY, 6).and() + .hasFixedHoliday("LABOUR_DAY", MAY, 1).and() + .hasFixedHoliday("ASSUMPTION_DAY", AUGUST, 15).and() + .hasFixedHoliday("NATIONAL_DAY", OCTOBER, 26).and() + .hasFixedHoliday("ALL_SAINTS", NOVEMBER, 1).and() + .hasFixedHoliday("IMMACULATE_CONCEPTION", DECEMBER, 8).and() + .hasFixedHoliday("CHRISTMAS_EVE", DECEMBER, 24, OBSERVANCE).and() + .hasFixedHoliday("CHRISTMAS", DECEMBER, 25).and() + .hasFixedHoliday("STEPHENS", DECEMBER, 26).and() + .hasFixedHoliday("NEW_YEARS_EVE", DECEMBER, 31, OBSERVANCE).and() + .hasChristianHoliday("EASTER").and() + .hasChristianHoliday("EASTER_MONDAY").and() + .hasChristianHoliday("ASCENSION_DAY").and() + .hasChristianHoliday("WHIT_MONDAY").and() + .hasChristianHoliday("CORPUS_CHRISTI") + .check(); + +/* TODO + assertFixed(AUSTRIA, "1", NOVEMBER, 11, "MARTINS_DAY"); assertFixed(AUSTRIA, "2", MARCH, 19, "JOSEFS_DAY"); assertFixed(AUSTRIA, "2", OCTOBER, 10, "PLEBISCITE"); assertFixed(AUSTRIA, "3", NOVEMBER, 15, "LEOPOLD"); @@ -45,6 +46,6 @@ void ensuresHolidays() { assertFixed(AUSTRIA, "6", MARCH, 19, "JOSEFS_DAY"); assertFixed(AUSTRIA, "7", MARCH, 19, "JOSEFS_DAY"); assertFixed(AUSTRIA, "8", MARCH, 19, "JOSEFS_DAY"); - assertFixed(AUSTRIA, "9", NOVEMBER, 15, "LEOPOLD"); + assertFixed(AUSTRIA, "9", NOVEMBER, 15, "LEOPOLD");*/ } }