-
Notifications
You must be signed in to change notification settings - Fork 7
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
SDIT-826 Model agency establishment as embeddedid #1602
Changes from all commits
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,19 @@ | ||
package uk.gov.justice.hmpps.prison.repository.jpa.model | ||
|
||
import jakarta.persistence.DiscriminatorValue | ||
import jakarta.persistence.Entity | ||
import lombok.NoArgsConstructor | ||
|
||
@Entity | ||
@DiscriminatorValue(AgencyEstablishmentType.ESTABLISHMENT_TYPE) | ||
@NoArgsConstructor | ||
class AgencyEstablishmentType(code: String?, description: String?) : | ||
ReferenceCode(ESTABLISHMENT_TYPE, code, description) { | ||
|
||
companion object { | ||
const val ESTABLISHMENT_TYPE = "ESTAB_TYPE" | ||
fun pk(code: String?): Pk { | ||
return Pk(ESTABLISHMENT_TYPE, code) | ||
} | ||
} | ||
} |
This file was deleted.
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,61 @@ | ||
package uk.gov.justice.hmpps.prison.repository.jpa.model | ||
|
||
import jakarta.persistence.Column | ||
import jakarta.persistence.Embeddable | ||
import jakarta.persistence.EmbeddedId | ||
import jakarta.persistence.Entity | ||
import jakarta.persistence.FetchType | ||
import jakarta.persistence.JoinColumn | ||
import jakarta.persistence.ManyToOne | ||
import jakarta.persistence.Table | ||
import org.hibernate.Hibernate | ||
import org.hibernate.annotations.JoinColumnOrFormula | ||
import org.hibernate.annotations.JoinColumnsOrFormulas | ||
import org.hibernate.annotations.JoinFormula | ||
import java.io.Serializable | ||
|
||
@Embeddable | ||
data class AgencyLocationEstablishmentId( | ||
@Column(name = "AGY_LOC_ID", nullable = false) | ||
val agencyLocationId: String, | ||
|
||
@Column(name = "ESTABLISHMENT_TYPE", nullable = false) | ||
val establishmentTypeCode: String, | ||
) : Serializable | ||
|
||
@Entity | ||
@Table(name = "AGY_LOC_ESTABLISHMENTS") | ||
data class AgencyLocationEstablishment( | ||
@EmbeddedId | ||
val id: AgencyLocationEstablishmentId, | ||
Comment on lines
+29
to
+30
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Switch to There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Actually to be more accurate... We could have just continued to use BUT as I changed the |
||
|
||
@ManyToOne(optional = false, fetch = FetchType.LAZY) | ||
@JoinColumn(name = "AGY_LOC_ID", updatable = false, insertable = false) | ||
val agencyLocation: AgencyLocation, | ||
|
||
@ManyToOne | ||
@JoinColumnsOrFormulas( | ||
value = [ | ||
JoinColumnOrFormula( | ||
formula = JoinFormula( | ||
value = "'" + AgencyEstablishmentType.ESTABLISHMENT_TYPE + "'", | ||
referencedColumnName = "domain", | ||
), | ||
), JoinColumnOrFormula(column = JoinColumn(name = "ESTABLISHMENT_TYPE", referencedColumnName = "code", nullable = true, updatable = false, insertable = false)), | ||
], | ||
) | ||
val establishmentType: AgencyEstablishmentType, | ||
) { | ||
|
||
override fun equals(other: Any?): Boolean { | ||
if (this === other) return true | ||
if (other == null || Hibernate.getClass(this) != Hibernate.getClass(other)) return false | ||
other as AgencyLocationEstablishment | ||
return id.agencyLocationId == other.id.agencyLocationId && | ||
id.establishmentTypeCode == other.id.establishmentTypeCode | ||
} | ||
|
||
override fun hashCode(): Int { | ||
return this.javaClass.hashCode() | ||
} | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -36,7 +36,6 @@ public class OffenderSubAccount { | |
@Column(name = "TRUST_ACCOUNT_CODE", nullable = false, insertable = false, updatable = false) | ||
private Long accountCode; | ||
|
||
@Id | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Not actually included in the id and causes an error in latest Hibernate verison. |
||
@Column(name = "BALANCE", nullable = false) | ||
private BigDecimal balance; | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -31,7 +31,6 @@ public class OffenderTrustAccount { | |
@Column(name = "OFFENDER_ID", nullable = false, insertable = false, updatable = false) | ||
private Long offenderId; | ||
|
||
@Id | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Not actually included in the id and causes an error in latest Hibernate verison. |
||
@Column(name = "ACCOUNT_CLOSED_FLAG", nullable = false) | ||
private String accountClosedFlag; | ||
|
||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,18 +2,15 @@ | |
|
||
import org.springframework.data.jpa.repository.Query; | ||
import org.springframework.data.repository.CrudRepository; | ||
import uk.gov.justice.hmpps.prison.api.model.Assessment; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AssessmentEntry; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.OffenderAssessment; | ||
|
||
import java.util.List; | ||
import java.util.Optional; | ||
|
||
public interface AssessmentRepository extends CrudRepository<AssessmentEntry, Long> { | ||
@Query("SELECT question FROM AssessmentEntry question " + | ||
"INNER JOIN question.parentAssessment questionSet INNER JOIN questionSet.parentAssessment type " + | ||
"WHERE type.assessmentId = :assessmentId AND type.parentAssessment is null " + | ||
"AND type.cellSharingAlertFlag = 'Y' AND questionSet.assessmentCode != 'COMPLETE' " + | ||
"AND type.cellSharingAlertFlag = 'Y' AND questionSet.assessmentCode <> 'COMPLETE' " + | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Work around bug in latest Spring data which removed |
||
"ORDER BY question.listSeq ASC") | ||
List<AssessmentEntry> findCsraQuestionsByAssessmentTypeIdOrderedByListSeq(Long assessmentId); | ||
} |
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -8,13 +8,10 @@ | |
import org.springframework.security.test.context.support.WithMockUser; | ||
import org.springframework.test.context.ActiveProfiles; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AgencyLocation; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AgencyLocationEstablishment; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AgencyLocationType; | ||
import uk.gov.justice.hmpps.prison.security.AuthenticationFacade; | ||
import uk.gov.justice.hmpps.prison.web.config.AuditorAwareImpl; | ||
|
||
import java.util.List; | ||
|
||
import static org.assertj.core.api.Assertions.assertThat; | ||
import static org.springframework.boot.test.autoconfigure.jdbc.AutoConfigureTestDatabase.Replace.NONE; | ||
|
||
|
@@ -86,9 +83,6 @@ public void createAnAgency() { | |
.description("A Test Agency") | ||
.active(true) | ||
.type(AgencyLocationType.PRISON_TYPE) | ||
.establishmentTypes(List.of(AgencyLocationEstablishment.builder() | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. We can't test by creating an AgencyLocationEstablishment first because it now has a child relationship with AgencyLocation. But the real createAgency endpoint doesn't allow establishment types to be created at the same time anyway so just removed from the test. |
||
.agencyLocId("AgencyRepositoryTestTEST") | ||
.establishmentType("IF").build())) | ||
.build(); | ||
|
||
final var createdAgency = repository.save(newAgency); | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -6,19 +6,18 @@ | |
import org.junit.jupiter.api.extension.ExtendWith; | ||
import org.mockito.Mock; | ||
import org.mockito.junit.jupiter.MockitoExtension; | ||
import uk.gov.justice.hmpps.prison.api.model.AgencyEstablishmentType; | ||
import uk.gov.justice.hmpps.prison.api.model.AgencyEstablishmentTypes; | ||
import uk.gov.justice.hmpps.prison.api.model.OffenderCell; | ||
import uk.gov.justice.hmpps.prison.api.model.OffenderCellAttribute; | ||
import uk.gov.justice.hmpps.prison.api.model.PrisonContactDetail; | ||
import uk.gov.justice.hmpps.prison.api.model.ReferenceCode; | ||
import uk.gov.justice.hmpps.prison.api.model.Telephone; | ||
import uk.gov.justice.hmpps.prison.repository.AgencyRepository; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AddressType; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AgencyEstablishmentType; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AgencyInternalLocation; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AgencyInternalLocationProfile; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AgencyLocation; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AgencyLocationEstablishment; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AgencyLocationEstablishmentId; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.AgencyLocationType; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.City; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.Country; | ||
|
@@ -219,20 +218,22 @@ public void shouldReturnCellWithAttributes_notFoundLivingUnit() { | |
|
||
@Test | ||
public void shouldReturnAllEstablishmentTypesForMoorland() { | ||
final var agencyLocation = AgencyLocation.builder() | ||
.id("MDI") | ||
.description("Moorland") | ||
.type(AgencyLocationType.PRISON_TYPE) | ||
.build(); | ||
final var establishmentType = new AgencyEstablishmentType("IM", "Closed Young Offender Institute (Male)"); | ||
when(agencyLocationRepository.findById("MDI")).thenReturn(Optional.of(AgencyLocation.builder() | ||
.id("MDI") | ||
.establishmentTypes(List.of(AgencyLocationEstablishment | ||
.builder() | ||
.agencyLocId("MDI") | ||
.establishmentType("IM") | ||
.build())) | ||
.establishmentTypes(List.of(new AgencyLocationEstablishment(new AgencyLocationEstablishmentId(agencyLocation.getId(), establishmentType.getCode()), agencyLocation, establishmentType))) | ||
.build())); | ||
|
||
when(referenceDomainService.getReferenceCodeByDomainAndCode("ESTAB_TYPE", "IM", false)).thenReturn(Optional.of(ReferenceCode.builder().code("IM").description("Closed Young Offender Institute (Male)").build())); | ||
|
||
final var establishmentTypes = service.getEstablishmentTypes("MDI"); | ||
|
||
assertThat(establishmentTypes).isEqualTo(AgencyEstablishmentTypes.builder().agencyId("MDI").establishmentTypes(List.of(AgencyEstablishmentType.builder().code("IM").description("Closed Young Offender Institute (Male)").build())).build()); | ||
assertThat(establishmentTypes.getAgencyId()).isEqualTo("MDI"); | ||
assertThat(establishmentTypes.getEstablishmentTypes()).extracting("code").containsExactly("IM"); | ||
assertThat(establishmentTypes.getEstablishmentTypes()).extracting("description").containsExactly("Closed Young Offender Institute (Male)"); | ||
} | ||
|
||
@Test | ||
|
@@ -242,22 +243,6 @@ public void shouldFailForEstablishmentTypesWhenAgencyNotFound() { | |
assertThatThrownBy(() -> service.getEstablishmentTypes("unknown")).isInstanceOf(EntityNotFoundException.class).hasMessage("Resource with id [unknown] not found."); | ||
} | ||
|
||
@Test | ||
public void shouldFailForEstablishmentTypesWhenAgencyEstablishmentNotFound() { | ||
Comment on lines
-245
to
-246
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. There are no agency location establishments with an invalid establishment type code (DOMAIN=ESTAB_TYPE) in any Nomis env. So as we are now modelling the establishment type as a reference code this test is redundant. |
||
when(agencyLocationRepository.findById("MDI")).thenReturn(Optional.of(AgencyLocation.builder() | ||
.id("MDI") | ||
.establishmentTypes(List.of(AgencyLocationEstablishment | ||
.builder() | ||
.agencyLocId("MDI") | ||
.establishmentType("IM") | ||
.build())) | ||
.build())); | ||
|
||
when(referenceDomainService.getReferenceCodeByDomainAndCode("ESTAB_TYPE", "IM", false)).thenReturn(Optional.empty()); | ||
|
||
assertThatThrownBy(() -> service.getEstablishmentTypes("MDI")).isInstanceOf(EntityNotFoundException.class).hasMessage("Establishment type IM for agency MDI not found."); | ||
} | ||
|
||
private List<PrisonContactDetail> buildPrisonContactDetailsList() { | ||
return ImmutableList.of( | ||
PrisonContactDetail.builder().agencyId("ABC") | ||
|
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -68,7 +68,6 @@ | |
import uk.gov.justice.hmpps.prison.repository.jpa.model.SentenceTerm; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.VisitInformation; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.VisitVisitor; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.VisitorInformation; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.model.WarZone; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.repository.AgencyInternalLocationRepository; | ||
import uk.gov.justice.hmpps.prison.repository.jpa.repository.AvailablePrisonIepLevelRepository; | ||
|
@@ -231,7 +230,7 @@ public void verifyCanViewSensitiveBookingInfo() { | |
|
||
@Test | ||
public void verifyCanViewSensitiveBookingInfo_systemUser() { | ||
when(authenticationFacade.isOverrideRole(any())).thenReturn(true); | ||
when(authenticationFacade.isOverrideRole(any(String[].class))).thenReturn(true); | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Mocks for vararg parameters changed in Mockito 5 so that you have to either match the correct number of args or instead use an array type. |
||
|
||
when(bookingRepository.getLatestBookingIdentifierForOffender("off-1")).thenReturn(Optional.of(new OffenderBookingIdSeq("off-1", -1L, 1))); | ||
|
||
|
@@ -1192,7 +1191,7 @@ private ScheduledEvent createEvent(final String type, final String time) { | |
|
||
@Test | ||
public void getOffenderSentenceSummaries_forOveriddenRole() { | ||
when(authenticationFacade.isOverrideRole(any())).thenReturn(true); | ||
when(authenticationFacade.isOverrideRole(any(String[].class))).thenReturn(true); | ||
when(caseloadToAgencyMappingService.agenciesForUsersWorkingCaseload(any())).thenReturn(List.of()); | ||
assertThatThrownBy(() -> bookingService.getOffenderSentencesSummary(null, List.of())) | ||
.isInstanceOf(HttpClientErrorException.class).hasMessage("400 Request must be restricted to either a caseload, agency or list of offenders"); | ||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Model this as a reference code instead of loading manually.