Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

FixInvalidDayOffsetPreprocessor: Allow DURATION as value #182

Merged
Show file tree
Hide file tree
Changes from 6 commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Original file line number Diff line number Diff line change
Expand Up @@ -14,7 +14,8 @@ object FixInvalidDayOffsetPreprocessor : StreamPreprocessor() {
// Examples:
// TRIGGER:-P2DT
// TRIGGER:-PT2D
"^(DURATION|TRIGGER):-?P((T-?\\d+D)|(-?\\d+DT))\$",
// REFRESH-INTERVAL;VALUE=DURATION:PT1D
"(?:^|(^(DURATION|REFRESH-INTERVAL|RELATED-TO|TRIGGER));VALUE=)(DURATION|TRIGGER):-?P((T-?\\d+D)|(-?\\d+DT))\$",
sunkup marked this conversation as resolved.
Show resolved Hide resolved
setOf(RegexOption.MULTILINE, RegexOption.IGNORE_CASE)
)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,16 +12,23 @@ import java.time.Duration

class FixInvalidDayOffsetPreprocessorTest {

private fun fixAndAssert(expected: String, testValue: String) {

/**
* Calls [FixInvalidDayOffsetPreprocessor.fixString] and asserts the result is equal to [expected].
*
* @param expected The expected result
* @param testValue The value to test
* @param parseDuration If `true`, [Duration.parse] is called on the fixed value to make sure it's a valid duration
*/
private fun assertFixedEquals(expected: String, testValue: String, parseDuration: Boolean = true) {
// Fix the duration string
val fixed = FixInvalidDayOffsetPreprocessor.fixString(testValue)

// Test the duration can now be parsed
for (line in fixed.split('\n')) {
val duration = line.substring(line.indexOf(':') + 1)
Duration.parse(duration)
}
if (parseDuration)
for (line in fixed.split('\n')) {
val duration = line.substring(line.indexOf(':') + 1)
Duration.parse(duration)
}

// Assert
assertEquals(expected, fixed)
Expand All @@ -35,36 +42,57 @@ class FixInvalidDayOffsetPreprocessorTest {
)
}

@Test
fun test_FixString_SucceedsAsValueOnCorrectProperties() {
// By RFC 5545 the only properties allowed to hold DURATION as a VALUE are:
// DURATION, REFRESH, RELATED, TRIGGER
assertFixedEquals("DURATION;VALUE=DURATION:P1D", "DURATION;VALUE=DURATION:PT1D")
assertFixedEquals("REFRESH-INTERVAL;VALUE=DURATION:P1D", "REFRESH-INTERVAL;VALUE=DURATION:PT1D")
assertFixedEquals("RELATED-TO;VALUE=DURATION:P1D", "RELATED-TO;VALUE=DURATION:PT1D")
assertFixedEquals("TRIGGER;VALUE=DURATION:P1D", "TRIGGER;VALUE=DURATION:PT1D")
}

@Test
fun test_FixString_FailsAsValueOnWrongProperty() {
// The update from RFC 2445 to RFC 5545 disallows using DURATION as a VALUE in FREEBUSY
assertFixedEquals("FREEBUSY;VALUE=DURATION:PT1D", "FREEBUSY;VALUE=DURATION:PT1D", parseDuration = false)
}

@Test
fun test_FixString_FailsIfNotAtStartOfLine() {
assertFixedEquals("xxDURATION;VALUE=DURATION:PT1D", "xxDURATION;VALUE=DURATION:PT1D", parseDuration = false)
}

@Test
fun test_FixString_DayOffsetFrom_Invalid() {
fixAndAssert("DURATION:-P1D", "DURATION:-PT1D")
fixAndAssert("TRIGGER:-P2D", "TRIGGER:-PT2D")
assertFixedEquals("DURATION:-P1D", "DURATION:-PT1D")
assertFixedEquals("TRIGGER:-P2D", "TRIGGER:-PT2D")

fixAndAssert("DURATION:-P1D", "DURATION:-P1DT")
fixAndAssert("TRIGGER:-P2D", "TRIGGER:-P2DT")
assertFixedEquals("DURATION:-P1D", "DURATION:-P1DT")
assertFixedEquals("TRIGGER:-P2D", "TRIGGER:-P2DT")
}

@Test
fun test_FixString_DayOffsetFrom_Valid() {
fixAndAssert("DURATION:-PT12H", "DURATION:-PT12H")
fixAndAssert("TRIGGER:-PT12H", "TRIGGER:-PT12H")
assertFixedEquals("DURATION:-PT12H", "DURATION:-PT12H")
assertFixedEquals("TRIGGER:-PT12H", "TRIGGER:-PT12H")
}

@Test
fun test_FixString_DayOffsetFromMultiple_Invalid() {
fixAndAssert("DURATION:-P1D\nTRIGGER:-P2D", "DURATION:-PT1D\nTRIGGER:-PT2D")
fixAndAssert("DURATION:-P1D\nTRIGGER:-P2D", "DURATION:-P1DT\nTRIGGER:-P2DT")
assertFixedEquals("DURATION:-P1D\nTRIGGER:-P2D", "DURATION:-PT1D\nTRIGGER:-PT2D")
assertFixedEquals("DURATION:-P1D\nTRIGGER:-P2D", "DURATION:-P1DT\nTRIGGER:-P2DT")
}

@Test
fun test_FixString_DayOffsetFromMultiple_Valid() {
fixAndAssert("DURATION:-PT12H\nTRIGGER:-PT12H", "DURATION:-PT12H\nTRIGGER:-PT12H")
assertFixedEquals("DURATION:-PT12H\nTRIGGER:-PT12H", "DURATION:-PT12H\nTRIGGER:-PT12H")
}

@Test
fun test_FixString_DayOffsetFromMultiple_Mixed() {
fixAndAssert("DURATION:-P1D\nDURATION:-PT12H\nTRIGGER:-P2D", "DURATION:-PT1D\nDURATION:-PT12H\nTRIGGER:-PT2D")
fixAndAssert("DURATION:-P1D\nDURATION:-PT12H\nTRIGGER:-P2D", "DURATION:-P1DT\nDURATION:-PT12H\nTRIGGER:-P2DT")
assertFixedEquals("DURATION:-P1D\nDURATION:-PT12H\nTRIGGER:-P2D", "DURATION:-PT1D\nDURATION:-PT12H\nTRIGGER:-PT2D")
assertFixedEquals("DURATION:-P1D\nDURATION:-PT12H\nTRIGGER:-P2D", "DURATION:-P1DT\nDURATION:-PT12H\nTRIGGER:-P2DT")
}

@Test
Expand Down
Loading