From d371f90b35326e3552bacf576dee53cf46039a25 Mon Sep 17 00:00:00 2001 From: Helene Arnesen Date: Thu, 21 Nov 2024 10:37:37 +0100 Subject: [PATCH] chore: fix tests and try to fix build MIME-Version: 1.0 Content-Type: text/plain; charset=UTF-8 Content-Transfer-Encoding: 8bit Co-authored-by: Natalie Uranes Co-authored-by: Jørn-Are Flaten --- build.gradle.kts | 1 + .../digitalisering/dokarkiv/DokarkivClient.kt | 7 +- .../digitalisering/exceptions/Exceptions.kt | 2 + .../exceptions/GlobalExceptionHandler.kt | 6 ++ .../helsenett/client/HelsenettClient.kt | 3 - .../NasjonalSykmeldingService.kt | 17 +--- .../api/NasjonalOppgaveController.kt | 9 +- .../papirsykmelding/api/RegelClient.kt | 4 +- .../api/model/ValidationRules.kt | 1 + .../db/model/NasjonalSykmeldingDAO.kt | 4 +- .../saf/SafJournalpostService.kt | 3 +- .../sykmelding/service/JournalpostService.kt | 4 +- .../NasjonalSykmeldingFellesformatMapper.kt | 1 + .../sykdig/utils/NasjonalSykmeldingMapper.kt | 1 + .../helsenett/SykmelderServiceTest.kt | 5 +- .../sykdig/saf/SafJournalpostServiceTest.kt | 84 ++++++++++++------- src/test/resources/application.yaml | 8 ++ 17 files changed, 98 insertions(+), 62 deletions(-) diff --git a/build.gradle.kts b/build.gradle.kts index 5060588d..1ea69537 100644 --- a/build.gradle.kts +++ b/build.gradle.kts @@ -114,6 +114,7 @@ dependencies { because("overstyrer sårbar dependency fra com.opentable.components:otj-pg-embedded") } } + testImplementation(kotlin("test")) } tasks { diff --git a/src/main/kotlin/no/nav/sykdig/digitalisering/dokarkiv/DokarkivClient.kt b/src/main/kotlin/no/nav/sykdig/digitalisering/dokarkiv/DokarkivClient.kt index 595230ac..c37c4c1e 100644 --- a/src/main/kotlin/no/nav/sykdig/digitalisering/dokarkiv/DokarkivClient.kt +++ b/src/main/kotlin/no/nav/sykdig/digitalisering/dokarkiv/DokarkivClient.kt @@ -123,7 +123,7 @@ class DokarkivClient( oppdaterJournalpostRequest: OppdaterJournalpostRequest, sykmeldingId: String, journalpostId: String, - ) { + ): ResponseEntity { val headers = HttpHeaders() headers.contentType = MediaType.APPLICATION_JSON headers.accept = listOf(MediaType.APPLICATION_JSON) @@ -131,13 +131,14 @@ class DokarkivClient( try { securelog.info("createOppdaterJournalpostRequest: ${objectMapper.writeValueAsString(oppdaterJournalpostRequest)}") - dokarkivRestTemplate.exchange( + val response = dokarkivRestTemplate.exchange( "$url/$journalpostId", HttpMethod.PUT, HttpEntity(oppdaterJournalpostRequest, headers), String::class.java, ) log.info("Oppdatert journalpost $journalpostId for sykmelding $sykmeldingId") + return response } catch (e: HttpClientErrorException) { if (e.statusCode.value() == 401 || e.statusCode.value() == 403) { log.warn("Veileder har ikke tilgang til å oppdatere journalpostId $journalpostId: ${e.message}") @@ -425,7 +426,7 @@ class DokarkivClient( listOf( DokumentInfo( dokumentInfoId = dokumentInfoId, - tittel = createTitleNasjonal(receivedSykmelding.sykmelding.perioder, avvist), //TODO skal receivedSykmelding være nullable?? why? + tittel = createTitleNasjonal(receivedSykmelding.sykmelding.perioder, avvist), ), ) } else { diff --git a/src/main/kotlin/no/nav/sykdig/digitalisering/exceptions/Exceptions.kt b/src/main/kotlin/no/nav/sykdig/digitalisering/exceptions/Exceptions.kt index df9a2c6e..5be6aa49 100644 --- a/src/main/kotlin/no/nav/sykdig/digitalisering/exceptions/Exceptions.kt +++ b/src/main/kotlin/no/nav/sykdig/digitalisering/exceptions/Exceptions.kt @@ -13,6 +13,8 @@ class NoOppgaveException(override val message: String) : RuntimeException(messag class SykmelderNotFoundException(message: String) : RuntimeException(message) +class MissingJournalpostException(message: String) : RuntimeException(message) + class UnauthorizedException(message: String) : Exception(message) class ValidationException(val validationResult: ValidationResult) : Exception() diff --git a/src/main/kotlin/no/nav/sykdig/digitalisering/exceptions/GlobalExceptionHandler.kt b/src/main/kotlin/no/nav/sykdig/digitalisering/exceptions/GlobalExceptionHandler.kt index c25666c8..a69d0b88 100644 --- a/src/main/kotlin/no/nav/sykdig/digitalisering/exceptions/GlobalExceptionHandler.kt +++ b/src/main/kotlin/no/nav/sykdig/digitalisering/exceptions/GlobalExceptionHandler.kt @@ -56,6 +56,12 @@ class GlobalExceptionHandler { return ResponseEntity.status(HttpStatus.NOT_FOUND).body("Sykmelder not found") } + @ExceptionHandler(MissingJournalpostException::class) + fun handleMissingJournalpostException(e: MissingJournalpostException): ResponseEntity { + log.error("Journalpost is missing: ${e.message}", e) + return ResponseEntity.status(HttpStatus.BAD_REQUEST).body("Journalpost is missing") + } + @ExceptionHandler(UnauthorizedException::class) fun handleUnAuthorizedException(e: UnauthorizedException): ResponseEntity { log.warn("Caught UnauthorizedException ${e.message}", e) diff --git a/src/main/kotlin/no/nav/sykdig/digitalisering/helsenett/client/HelsenettClient.kt b/src/main/kotlin/no/nav/sykdig/digitalisering/helsenett/client/HelsenettClient.kt index 871b61c4..eacfb55a 100644 --- a/src/main/kotlin/no/nav/sykdig/digitalisering/helsenett/client/HelsenettClient.kt +++ b/src/main/kotlin/no/nav/sykdig/digitalisering/helsenett/client/HelsenettClient.kt @@ -1,8 +1,6 @@ package no.nav.sykdig.digitalisering.helsenett.client import no.nav.sykdig.applog -import no.nav.sykdig.digitalisering.exceptions.SykmelderNotFoundException -import no.nav.sykdig.digitalisering.exceptions.UnauthorizedException import no.nav.sykdig.digitalisering.helsenett.Behandler import no.nav.sykdig.securelog import org.springframework.beans.factory.annotation.Value @@ -13,7 +11,6 @@ import org.springframework.http.HttpStatus import org.springframework.stereotype.Component import org.springframework.web.client.HttpClientErrorException import org.springframework.web.client.RestTemplate -import java.io.IOException @Component class HelsenettClient( diff --git a/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/NasjonalSykmeldingService.kt b/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/NasjonalSykmeldingService.kt index f7c512fc..1ae95da4 100644 --- a/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/NasjonalSykmeldingService.kt +++ b/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/NasjonalSykmeldingService.kt @@ -73,6 +73,7 @@ class NasjonalSykmeldingService( suspend fun sendPapirsykmelding(smRegistreringManuell: SmRegistreringManuell, navEnhet: String, callId: String, oppgaveId: Int): ResponseEntity { val oppgave = nasjonalOppgaveService.findByOppgaveId(oppgaveId) ?: return ResponseEntity(HttpStatus.NOT_FOUND) val sykmeldingId = oppgave.sykmeldingId + log.info("Forsøker å ferdigstille papirsykmelding med sykmeldingId $sykmeldingId") val loggingMeta = getLoggingMeta(sykmeldingId, oppgave) val sykmelder = getSykmelder(smRegistreringManuell, loggingMeta, callId) @@ -113,18 +114,6 @@ class NasjonalSykmeldingService( } return handleOK(validationResult, receivedSykmelding.copy(validationResult = validationResult), ferdigstillRegistrering, loggingMeta) - - - // logging meta sykmeldingId, dokumentInfoId, journalpostId - - // sender med et isUpdate - som sjekker om saksbehandler har superuseraccess. men dette brukes kun i endre, som ikke har blitt brukt - - // sjekker om saksbehandler har tilgang, men jeg tror dette kan gjøres gjennom obo token i controlleren - - // val sykmelderHpr - // val sykmelder = personServise.hentPerson(sykmeldderHpr) -- callId er en randomUUID - spørre seg om kanskje ha callId som sykmeldingId - - } private suspend fun handleOK( @@ -156,7 +145,7 @@ class NasjonalSykmeldingService( ferdigstiltAv = veileder.veilederIdent, avvisningsgrunn = null, ) - + log.info("Ferdigstilt papirsykmelding med sykmelding id ${receivedSykmelding.sykmelding.id}") return ResponseEntity(HttpStatus.OK) } log.error( @@ -319,7 +308,7 @@ class NasjonalSykmeldingService( val nasjonalManuellOppgaveDAO = NasjonalSykmeldingDAO( sykmeldingId = receivedSykmelding.sykmelding.id, - sykmelding = receivedSykmelding, + sykmelding = receivedSykmelding.sykmelding, timestamp = OffsetDateTime.now(ZoneOffset.UTC), ferdigstiltAv = veileder.veilederIdent, datoFerdigstilt = LocalDateTime.now(ZoneOffset.UTC), diff --git a/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/NasjonalOppgaveController.kt b/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/NasjonalOppgaveController.kt index 3b8ee116..b7c43724 100644 --- a/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/NasjonalOppgaveController.kt +++ b/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/NasjonalOppgaveController.kt @@ -103,13 +103,10 @@ class NasjonalOppgaveController( @RequestHeader("X-Nav-Enhet") navEnhet: String, @RequestBody papirSykmelding: SmRegistreringManuell, ): ResponseEntity { - - // TODO: sjekk when oppgaveId er null: lage en guard og responder med bad request - // TODO: hvis accesstoken er null responder med unauthorized val callId = UUID.randomUUID().toString() - nasjonalSykmeldingService.sendPapirsykmelding(papirSykmelding, navEnhet, callId, oppgaveId) - log.info("papirsykmelding: sender oppgave med oppgaveId $oppgaveId gjennom syk-dig proxy") - return smregistreringClient.postSendOppgaveRequest(authorization, oppgaveId, navEnhet, papirSykmelding) + return nasjonalSykmeldingService.sendPapirsykmelding(papirSykmelding, navEnhet, callId, oppgaveId) + //log.info("papirsykmelding: sender oppgave med oppgaveId $oppgaveId gjennom syk-dig proxy") + //return smregistreringClient.postSendOppgaveRequest(authorization, oppgaveId, navEnhet, papirSykmelding) } @GetMapping("/sykmelding/{sykmeldingId}/ferdigstilt") diff --git a/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/RegelClient.kt b/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/RegelClient.kt index d02551a6..c7de6ab7 100644 --- a/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/RegelClient.kt +++ b/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/RegelClient.kt @@ -2,7 +2,7 @@ package no.nav.sykdig.digitalisering.papirsykmelding.api import net.logstash.logback.argument.StructuredArguments.kv import no.nav.sykdig.applog -import no.nav.sykdig.digitalisering.papirsykmelding.db.model.ReceivedSykmeldingNasjonal +import no.nav.sykdig.digitalisering.sykmelding.ReceivedSykmelding import no.nav.sykdig.digitalisering.sykmelding.ValidationResult import no.nav.sykdig.securelog import org.springframework.beans.factory.annotation.Value @@ -24,7 +24,7 @@ class RegelClient( val log = applog() val securelog = securelog() - fun valider(sykmelding: ReceivedSykmeldingNasjonal, msgId: String): ValidationResult { + fun valider(sykmelding: ReceivedSykmelding, msgId: String): ValidationResult { log.info("validating against rules {}", kv("sykmeldingId", sykmelding.sykmelding.id)) val headers = HttpHeaders() headers["Nav-CallId"] = msgId diff --git a/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/model/ValidationRules.kt b/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/model/ValidationRules.kt index b20bf3da..5b79e75a 100644 --- a/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/model/ValidationRules.kt +++ b/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/api/model/ValidationRules.kt @@ -2,6 +2,7 @@ package no.nav.sykdig.digitalisering.papirsykmelding.api.model import java.time.LocalDate import no.nav.sykdig.digitalisering.exceptions.ValidationException +import no.nav.sykdig.digitalisering.felles.Periode import no.nav.sykdig.digitalisering.sykmelding.RuleInfo import no.nav.sykdig.digitalisering.sykmelding.Status import no.nav.sykdig.digitalisering.sykmelding.ValidationResult diff --git a/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/db/model/NasjonalSykmeldingDAO.kt b/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/db/model/NasjonalSykmeldingDAO.kt index 0275096a..5b1ce62d 100644 --- a/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/db/model/NasjonalSykmeldingDAO.kt +++ b/src/main/kotlin/no/nav/sykdig/digitalisering/papirsykmelding/db/model/NasjonalSykmeldingDAO.kt @@ -1,13 +1,13 @@ package no.nav.sykdig.digitalisering.papirsykmelding.db.model import jakarta.persistence.GeneratedValue -import no.nav.sykdig.digitalisering.papirsykmelding.api.model.Sykmelding +import no.nav.sykdig.digitalisering.felles.Sykmelding import org.springframework.data.annotation.Id import org.springframework.data.relational.core.mapping.Column import org.springframework.data.relational.core.mapping.Table import java.time.LocalDateTime import java.time.OffsetDateTime -import java.util.UUID +import java.util.* @Table(name = "nasjonal_sykmelding") open class NasjonalSykmeldingDAO( diff --git a/src/main/kotlin/no/nav/sykdig/digitalisering/saf/SafJournalpostService.kt b/src/main/kotlin/no/nav/sykdig/digitalisering/saf/SafJournalpostService.kt index 92630730..4443a2f0 100644 --- a/src/main/kotlin/no/nav/sykdig/digitalisering/saf/SafJournalpostService.kt +++ b/src/main/kotlin/no/nav/sykdig/digitalisering/saf/SafJournalpostService.kt @@ -2,6 +2,7 @@ package no.nav.sykdig.digitalisering.saf import no.nav.syfo.oppgave.saf.model.DokumentMedTittel import no.nav.sykdig.applog +import no.nav.sykdig.digitalisering.exceptions.MissingJournalpostException import no.nav.sykdig.digitalisering.saf.graphql.DokumentInfo import no.nav.sykdig.digitalisering.saf.graphql.Journalstatus import no.nav.sykdig.digitalisering.saf.graphql.SafJournalpost @@ -58,7 +59,7 @@ class SafJournalpostService( fun erIkkeJournalfort(journalpostId: String): Boolean { val journalpost = safJournalpostGraphQlClient.getJournalpostM2m(journalpostId) - if (journalpost.journalpost == null) return false + if (journalpost.journalpost == null) throw MissingJournalpostException("Journalpost med id $journalpostId finnes ikke i SAF") return erIkkeJournalfort(journalpost.journalpost) } diff --git a/src/main/kotlin/no/nav/sykdig/digitalisering/sykmelding/service/JournalpostService.kt b/src/main/kotlin/no/nav/sykdig/digitalisering/sykmelding/service/JournalpostService.kt index e28855ad..f1d5bf81 100644 --- a/src/main/kotlin/no/nav/sykdig/digitalisering/sykmelding/service/JournalpostService.kt +++ b/src/main/kotlin/no/nav/sykdig/digitalisering/sykmelding/service/JournalpostService.kt @@ -6,13 +6,13 @@ import no.nav.sykdig.applog import no.nav.sykdig.digitalisering.SykDigOppgaveService import no.nav.sykdig.digitalisering.dokarkiv.DokarkivClient import no.nav.sykdig.digitalisering.papirsykmelding.api.model.FerdigstillRegistrering -import no.nav.sykdig.digitalisering.papirsykmelding.db.model.ReceivedSykmeldingNasjonal import no.nav.sykdig.digitalisering.pdl.PersonService import no.nav.sykdig.digitalisering.saf.SafJournalpostService import no.nav.sykdig.digitalisering.saf.graphql.SafJournalpost import no.nav.sykdig.digitalisering.saf.graphql.TEMA_SYKEPENGER import no.nav.sykdig.digitalisering.saf.graphql.TEMA_SYKMELDING import no.nav.sykdig.digitalisering.saf.graphql.Type +import no.nav.sykdig.digitalisering.sykmelding.ReceivedSykmelding import no.nav.sykdig.digitalisering.sykmelding.db.JournalpostSykmeldingRepository import no.nav.sykdig.generated.types.Document import no.nav.sykdig.generated.types.Journalpost @@ -131,7 +131,7 @@ class JournalpostService( } suspend fun ferdigstillJournalpost( ferdigstillRegistrering: FerdigstillRegistrering, - receivedSykmelding: ReceivedSykmeldingNasjonal?, + receivedSykmelding: ReceivedSykmelding, loggingMeta: LoggingMeta, ) { if ( diff --git a/src/main/kotlin/no/nav/sykdig/utils/NasjonalSykmeldingFellesformatMapper.kt b/src/main/kotlin/no/nav/sykdig/utils/NasjonalSykmeldingFellesformatMapper.kt index c170bdfa..38b7b986 100644 --- a/src/main/kotlin/no/nav/sykdig/utils/NasjonalSykmeldingFellesformatMapper.kt +++ b/src/main/kotlin/no/nav/sykdig/utils/NasjonalSykmeldingFellesformatMapper.kt @@ -27,6 +27,7 @@ import no.nav.helse.sm2013.NavnType import no.nav.helse.sm2013.TeleCom import no.nav.helse.sm2013.URL import no.nav.sykdig.applog +import no.nav.sykdig.digitalisering.felles.* import no.nav.sykdig.digitalisering.papirsykmelding.api.model.* import no.nav.sykdig.digitalisering.pdl.Person import no.nav.sykdig.digitalisering.pdl.client.graphql.PdlPerson diff --git a/src/main/kotlin/no/nav/sykdig/utils/NasjonalSykmeldingMapper.kt b/src/main/kotlin/no/nav/sykdig/utils/NasjonalSykmeldingMapper.kt index 581041c3..74becf3a 100644 --- a/src/main/kotlin/no/nav/sykdig/utils/NasjonalSykmeldingMapper.kt +++ b/src/main/kotlin/no/nav/sykdig/utils/NasjonalSykmeldingMapper.kt @@ -6,6 +6,7 @@ import no.nav.helse.sm2013.ArsakType import no.nav.helse.sm2013.CS import no.nav.helse.sm2013.CV import no.nav.helse.sm2013.HelseOpplysningerArbeidsuforhet +import no.nav.sykdig.digitalisering.felles.* import no.nav.sykdig.digitalisering.papirsykmelding.api.model.* fun HelseOpplysningerArbeidsuforhet.toSykmelding( diff --git a/src/test/kotlin/no/nav/sykdig/digitalisering/helsenett/SykmelderServiceTest.kt b/src/test/kotlin/no/nav/sykdig/digitalisering/helsenett/SykmelderServiceTest.kt index 6f378f88..30bb0aa0 100644 --- a/src/test/kotlin/no/nav/sykdig/digitalisering/helsenett/SykmelderServiceTest.kt +++ b/src/test/kotlin/no/nav/sykdig/digitalisering/helsenett/SykmelderServiceTest.kt @@ -6,6 +6,7 @@ import io.mockk.mockk import kotlinx.coroutines.runBlocking import no.nav.sykdig.digitalisering.exceptions.SykmelderNotFoundException import no.nav.sykdig.digitalisering.helsenett.client.HelsenettClient +import no.nav.sykdig.digitalisering.helsenett.client.SmtssClient import no.nav.sykdig.digitalisering.papirsykmelding.api.model.Godkjenning import no.nav.sykdig.digitalisering.papirsykmelding.api.model.Kode import no.nav.sykdig.digitalisering.pdl.Navn @@ -18,7 +19,9 @@ import org.junit.jupiter.api.Test class SykmelderServiceTest { private val pdlService = mockk() private val helsenettClient = mockk() - private val sykmelderService = SykmelderService(helsenettClient, pdlService) + private val personService = mockk() + private val smtssClient = mockk() + private val sykmelderService = SykmelderService(helsenettClient, personService, smtssClient) @Test fun `get sykmelder happy case`() { diff --git a/src/test/kotlin/no/nav/sykdig/saf/SafJournalpostServiceTest.kt b/src/test/kotlin/no/nav/sykdig/saf/SafJournalpostServiceTest.kt index 584fba96..928b9064 100644 --- a/src/test/kotlin/no/nav/sykdig/saf/SafJournalpostServiceTest.kt +++ b/src/test/kotlin/no/nav/sykdig/saf/SafJournalpostServiceTest.kt @@ -2,6 +2,7 @@ package no.nav.sykdig.saf import io.mockk.every import io.mockk.mockk +import no.nav.sykdig.digitalisering.exceptions.MissingJournalpostException import no.nav.sykdig.digitalisering.saf.SafJournalpostGraphQlClient import no.nav.sykdig.digitalisering.saf.SafJournalpostService import no.nav.sykdig.digitalisering.saf.graphql.DokumentInfo @@ -9,11 +10,12 @@ import no.nav.sykdig.digitalisering.saf.graphql.Dokumentvariant import no.nav.sykdig.digitalisering.saf.graphql.Journalstatus import no.nav.sykdig.digitalisering.saf.graphql.SafJournalpost import no.nav.sykdig.digitalisering.saf.graphql.SafQueryJournalpost +import org.amshove.kluent.assertionError import org.amshove.kluent.internal.assertFailsWith -import org.junit.jupiter.api.Assertions.assertEquals -import org.junit.jupiter.api.Assertions.assertNotNull -import org.junit.jupiter.api.Assertions.assertNull +import org.junit.jupiter.api.Assertions +import org.junit.jupiter.api.Assertions.* import org.junit.jupiter.api.Test +import org.junit.jupiter.api.assertThrows class SafJournalpostServiceTest { private val safJournalpostGraphQlClient: SafJournalpostGraphQlClient = mockk() @@ -116,35 +118,61 @@ class SafJournalpostServiceTest { } @Test - fun ``() { + fun `er ikke journalført fordi status er mottatt`() { val journalpostId = "123" - val sykmeldingId = "syk-456" - val source = "rina" every { safJournalpostGraphQlClient.getJournalpostM2m(journalpostId) } returns - SafQueryJournalpost( - SafJournalpost( - journalstatus = Journalstatus.MOTTATT, - dokumenter = - listOf( - DokumentInfo( - dokumentInfoId = "dok1", - tittel = "Dokument 1", - dokumentvarianter = listOf(Dokumentvariant(variantformat = "NON-ARKIV")), - brevkode = "1", + SafQueryJournalpost( + SafJournalpost( + journalstatus = Journalstatus.MOTTATT, + dokumenter = + listOf( + DokumentInfo( + dokumentInfoId = "dok1", + tittel = "Dokument 1", + dokumentvarianter = listOf(Dokumentvariant(variantformat = "NON-ARKIV")), + brevkode = "1", + ), ), - ), - kanal = "EESSI", - avsenderMottaker = null, - bruker = null, - tema = null, - ), - ) + kanal = "EESSI", + avsenderMottaker = null, + bruker = null, + tema = null, + ), + ) - val exception = - assertFailsWith { - safJournalpostService.getDokumenterM2m(journalpostId, sykmeldingId, source) - } - assertEquals("Journalpost mangler PDF, $sykmeldingId", exception.message) + val erIkkeJournalfort = safJournalpostService.erIkkeJournalfort(journalpostId) + assertTrue(erIkkeJournalfort) + } + @Test + fun `er ikke journalført fordi safjournalpost er null`() { + val journalpostId = "123" + every { safJournalpostGraphQlClient.getJournalpostM2m(journalpostId) } returns SafQueryJournalpost(null) + assertThrows{safJournalpostService.erIkkeJournalfort(journalpostId)} + } + @Test + fun `er journalført fordi status er ukjent`() { + val journalpostId = "123" + every { safJournalpostGraphQlClient.getJournalpostM2m(journalpostId) } returns + SafQueryJournalpost( + SafJournalpost( + journalstatus = Journalstatus.UKJENT, + dokumenter = + listOf( + DokumentInfo( + dokumentInfoId = "dok1", + tittel = "Dokument 1", + dokumentvarianter = listOf(Dokumentvariant(variantformat = "NON-ARKIV")), + brevkode = "1", + ), + ), + kanal = "EESSI", + avsenderMottaker = null, + bruker = null, + tema = null, + ), + ) + val erIkkeJournalfort = safJournalpostService.erIkkeJournalfort(journalpostId) + assertFalse(erIkkeJournalfort) } } diff --git a/src/test/resources/application.yaml b/src/test/resources/application.yaml index b79403de..9f3f5e03 100644 --- a/src/test/resources/application.yaml +++ b/src/test/resources/application.yaml @@ -104,6 +104,14 @@ no.nav.security.jwt: client-id: client-id client-secret: secretzz client-auth-method: client_secret_basic + onbehalfof-smtss: + token-endpoint-url: http://localhost:${mock-oauth2-server.port}/azureator/token + grant-type: urn:ietf:params:oauth:grant-type:jwt-bearer + scope: smtss-client + authentication: + client-id: client-id + client-secret: secretzz + client-auth-method: client_secret_basic AZURE_APP_PRE_AUTHORIZED_APPS: "[{\"name\":\"dev-gcp:teamsykmelding:syk-dig\",\"clientId\":\"syk-dig-client-id\"}]"