Skip to content

Commit

Permalink
Custodial isn't optional
Browse files Browse the repository at this point in the history
  • Loading branch information
emileswarts committed Aug 30, 2023
1 parent ee422ba commit edc2129
Show file tree
Hide file tree
Showing 5 changed files with 18 additions and 12 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,6 @@ data class Sentence(
val dateOfSentencing: LocalDate? = null,
val description: String? = null,
val isActive: Boolean? = null,
val isCustodial: Boolean? = null,
val isCustodial: Boolean,
val terms: List<IntegrationApiTerm> = listOf(IntegrationApiTerm()),
)
Original file line number Diff line number Diff line change
Expand Up @@ -8,7 +8,7 @@ import uk.gov.justice.digital.hmpps.hmppsintegrationapi.models.ndelius.Sentence

data class Supervision(
val active: Boolean? = null,
val custodial: Boolean? = null,
val custodial: Boolean,
val additionalOffences: List<AdditionalOffence> = listOf(AdditionalOffence()),
val courtAppearances: List<CourtAppearance> = listOf(CourtAppearance()),
val mainOffence: MainOffence = MainOffence(),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -225,6 +225,7 @@ internal class SentencesControllerTest(
List(20) {
IntegrationApiSentence(
dateOfSentencing = LocalDate.parse("2023-01-01"),
isCustodial = true,
)
},
),
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,11 +17,13 @@ class SupervisionsTest : DescribeSpec(
val supervisions = Supervisions(
supervisions = listOf(
Supervision(
custodial = true,
mainOffence = MainOffence(description = "foobar", code = "05800", date = "2000-01-02"),
additionalOffences = listOf(AdditionalOffence(description = "additionalFoo", code = "12345", date = "2001-01-01")),
courtAppearances = listOf(CourtAppearance(date = "2009-07-07T00:00:00+01:00")),
),
Supervision(
custodial = true,
mainOffence = MainOffence(description = "barbaz", code = "05800", date = "2003-03-03"),
additionalOffences = listOf(AdditionalOffence(description = "additionalFoo2", code = "98765", date = "2001-02-02")),
courtAppearances = listOf(CourtAppearance(date = "2010-07-07T00:00:00+01:00")),
Expand Down Expand Up @@ -67,11 +69,13 @@ class SupervisionsTest : DescribeSpec(
val supervisions = Supervisions(
supervisions = listOf(
Supervision(
custodial = true,
mainOffence = MainOffence(description = "foobar", code = "05800", date = "2019-09-09"),
additionalOffences = emptyList(),
courtAppearances = listOf(CourtAppearance(date = "2009-07-07T00:00:00+01:00")),
),
Supervision(
custodial = true,
mainOffence = MainOffence(description = "barbaz", code = "05800", date = "2020-02-03"),
additionalOffences = emptyList(),
courtAppearances = listOf(CourtAppearance(date = "2010-07-07T00:00:00+01:00")),
Expand Down Expand Up @@ -104,26 +108,26 @@ class SupervisionsTest : DescribeSpec(
it("maps one-to-one attributes to integration API sentence attributes") {
val supervisions = Supervisions(
listOf(
Supervision(active = true, sentence = NDeliusSentence(date = "2009-07-07", description = "CJA - Community Order")),
Supervision(active = false, sentence = NDeliusSentence(date = "2010-07-07", description = "CJA - Suspended Sentence Order")),
Supervision(active = true, custodial = true, sentence = NDeliusSentence(date = "2009-07-07", description = "CJA - Community Order")),
Supervision(active = false, custodial = true, sentence = NDeliusSentence(date = "2010-07-07", description = "CJA - Suspended Sentence Order")),
),
)

val integrationApiSentences = supervisions.supervisions.map { it.toSentence() }

integrationApiSentences.shouldBe(
listOf(
IntegrationApiSentence(dateOfSentencing = LocalDate.parse("2009-07-07"), isActive = true, description = "CJA - Community Order"),
IntegrationApiSentence(dateOfSentencing = LocalDate.parse("2010-07-07"), isActive = false, description = "CJA - Suspended Sentence Order"),
IntegrationApiSentence(dateOfSentencing = LocalDate.parse("2009-07-07"), isActive = true, isCustodial = true, description = "CJA - Community Order"),
IntegrationApiSentence(dateOfSentencing = LocalDate.parse("2010-07-07"), isActive = false, isCustodial = true, description = "CJA - Suspended Sentence Order"),
),
)
}

it("maps nDelius sentence length to Integration API terms") {
val supervisions = Supervisions(
listOf(
Supervision(sentence = NDeliusSentence(date = "2009-07-07", length = 11, lengthUnits = "Months")),
Supervision(sentence = NDeliusSentence(date = "2010-07-07", length = 2, lengthUnits = "Years")),
Supervision(custodial = true, sentence = NDeliusSentence(date = "2009-07-07", length = 11, lengthUnits = "Months")),
Supervision(custodial = false, sentence = NDeliusSentence(date = "2010-07-07", length = 2, lengthUnits = "Years")),
),
)

Expand All @@ -134,6 +138,7 @@ class SupervisionsTest : DescribeSpec(
IntegrationApiSentence(
dateOfSentencing = LocalDate.parse("2009-07-07"),
isActive = null,
isCustodial = true,
terms = listOf(
Term(
years = null,
Expand All @@ -147,6 +152,7 @@ class SupervisionsTest : DescribeSpec(
IntegrationApiSentence(
dateOfSentencing = LocalDate.parse("2010-07-07"),
isActive = null,
isCustodial = false,
terms = listOf(
Term(
years = 2,
Expand All @@ -164,8 +170,8 @@ class SupervisionsTest : DescribeSpec(
it("deals with NULL values") {
val supervisions = Supervisions(
listOf(
Supervision(),
Supervision(),
Supervision(custodial = true),
Supervision(custodial = true),
),
)

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -210,10 +210,9 @@ class PersonSentencesTest : DescribeSpec(
}

it("deals with NULL values") {
val integrationApiSentence = IntegrationApiSentence()
val integrationApiSentence = IntegrationApiSentence(isCustodial = true)
integrationApiSentence.dateOfSentencing.shouldBeNull()
integrationApiSentence.isActive.shouldBeNull()
integrationApiSentence.isCustodial.shouldBeNull()
integrationApiSentence.terms.shouldBe(listOf(IntegrationApiTerm()))
integrationApiSentence.description.shouldBeNull()
}
Expand Down

0 comments on commit edc2129

Please sign in to comment.