Skip to content

Commit

Permalink
Åpner opp for å resette perioder som har vurdering kopiert fra forrig…
Browse files Browse the repository at this point in the history
…e behandling
  • Loading branch information
espenjv committed Jun 27, 2024
1 parent 65f9d5e commit 485e206
Show file tree
Hide file tree
Showing 3 changed files with 29 additions and 8 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -73,6 +73,9 @@ private static BeregningsgrunnlagDto oppdaterRefusjonIRelevantePerioder(Beregnin
if (matchetSplittAndel.isPresent() && refusjonSkalEndres(eksisterendePeriode, matchetSplittAndel.get().getStartdatoRefusjon())) {
BGAndelArbeidsforholdDto.Builder bgAndelArbforBuilder = BGAndelArbeidsforholdDto.Builder.oppdater(eksisterendeAndel.getBgAndelArbeidsforhold());
bgAndelArbforBuilder.medSaksbehandletRefusjonPrÅr(matchetSplittAndel.get().getDelvisRefusjonBeløpPrÅr());
} else if (matchetSplittAndel.isPresent()) {
BGAndelArbeidsforholdDto.Builder bgAndelArbforBuilder = BGAndelArbeidsforholdDto.Builder.oppdater(eksisterendeAndel.getBgAndelArbeidsforhold());
bgAndelArbforBuilder.medSaksbehandletRefusjonPrÅr(null);
}
}));
return nyttGrunnlag;
Expand All @@ -89,7 +92,7 @@ private static boolean refusjonSkalEndres(BeregningsgrunnlagPeriodeDto eksistere
return eksisterendePeriode.getBeregningsgrunnlagPeriodeFom().isBefore(startdatoRefusjon);
}

private static Optional<RefusjonSplittAndel> finnFastsattAndelForBGAndel(BeregningsgrunnlagPrStatusOgAndelDto bgAndel, List<RefusjonSplittAndel> splittAndeler) {
private static Optional<RefusjonSplittAndel> finnFastsattAndelForBGAndel(BeregningsgrunnlagPrStatusOgAndelDto bgAndel, List<RefusjonSplittAndel> splittAndeler) {
return splittAndeler.stream().filter(splittAndel -> splittAndel.gjelderFor(bgAndel)).findFirst();
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -125,12 +125,9 @@ public Hjemmel getHjemmelForRefusjonskravfrist() {
}

private void medSaksbehandletRefusjonPrÅr(Beløp saksbehandletRefusjonPrÅr) {
if (saksbehandletRefusjonPrÅr == null) {
return;
}
if (refusjon == null) {
if (refusjon == null && saksbehandletRefusjonPrÅr != null) {
refusjon = Refusjon.medSaksbehandletRefusjonPrÅr(saksbehandletRefusjonPrÅr);
} else {
} else if (refusjon != null) {
refusjon.setSaksbehandletRefusjonPrÅr(saksbehandletRefusjonPrÅr);
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -73,8 +73,21 @@ void skal_ikke_splitte_noe_hvis_refusjon_aggregat_er_tomt() {
assertPeriode(STP, UENDELIG, AG1, REF1, 250000, resultat, 1);
}

@Test
void skal_kunne_resette_periode_satt_i_tidligere_behandling() {
lagBGPeriode(STP, UENDELIG, lagBGAndel(AG1, REF1, 250000, 0));
lagSaksbehandlerDto(AG1, REF1, STP);

@Test
BeregningsgrunnlagDto resultat = oppdater();

assertThat(resultat).isEqualTo(grunnlagBuilder.build());
assertThat(resultat.getBeregningsgrunnlagPerioder()).hasSize(1);
assertPeriode(STP, UENDELIG, AG1, REF1, 250000, resultat, 1);
}



@Test
void skal_kopiere_med_tidligere_andeler_som_ikke_er_arbeidstakerandeler() {
lagBGPeriode(STP, null, lagBGAndel(AG1, REF1, 150000), lagBGAndel(null, null, 0));
lagSaksbehandlerDto(AG1, REF1, dagerEtterSTP(10));
Expand Down Expand Up @@ -299,14 +312,22 @@ private LocalDate dagerEtterSTP(int i) {
return STP.plusDays(i);
}

private BeregningsgrunnlagPrStatusOgAndelDto.Builder lagBGAndel(Arbeidsgiver ag, InternArbeidsforholdRefDto ref, int refusjonPrÅr) {

private BeregningsgrunnlagPrStatusOgAndelDto.Builder lagBGAndel(Arbeidsgiver ag, InternArbeidsforholdRefDto ref, int refusjonPrÅr) {
return lagBGAndel(ag, ref, refusjonPrÅr, null);
}

private BeregningsgrunnlagPrStatusOgAndelDto.Builder lagBGAndel(Arbeidsgiver ag, InternArbeidsforholdRefDto ref, int refusjonPrÅr, Integer saksbehandletRefusjonPrÅr) {
BeregningsgrunnlagPrStatusOgAndelDto.Builder andelBuilder = BeregningsgrunnlagPrStatusOgAndelDto.ny()
.medAktivitetStatus(ag == null ? AktivitetStatus.SELVSTENDIG_NÆRINGSDRIVENDE : AktivitetStatus.ARBEIDSTAKER);
if (ag != null) {
BGAndelArbeidsforholdDto.Builder arbforBuilder = BGAndelArbeidsforholdDto.builder()
.medRefusjonskravPrÅr(Beløp.fra(refusjonPrÅr), Utfall.GODKJENT)
.medArbeidsforholdRef(ref)
.medArbeidsgiver(ag);
if (saksbehandletRefusjonPrÅr != null) {
arbforBuilder.medSaksbehandletRefusjonPrÅr(Beløp.fra(saksbehandletRefusjonPrÅr));
}
andelBuilder.medBGAndelArbeidsforhold(arbforBuilder);
}
return andelBuilder;
Expand Down

0 comments on commit 485e206

Please sign in to comment.