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

chore: Remove startup dependency on Sipi, remove checking iiif server available on startup #3218

Merged
merged 4 commits into from
Apr 26, 2024
Merged
Show file tree
Hide file tree
Changes from all 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 @@ -12,7 +12,6 @@ import zio.nio.file.Path

import org.knora.webapi.config.AppConfig
import org.knora.webapi.messages.store.sipimessages.DeleteTemporaryFileRequest
import org.knora.webapi.messages.store.sipimessages.IIIFServiceStatusResponse
import org.knora.webapi.messages.store.sipimessages.MoveTemporaryFileToPermanentStorageRequest
import org.knora.webapi.messages.store.sipimessages.SipiGetTextFileRequest
import org.knora.webapi.messages.store.sipimessages.SipiGetTextFileResponse
Expand Down Expand Up @@ -99,12 +98,6 @@ case class SipiServiceTestDelegator(
override def getTextFileRequest(textFileRequest: SipiGetTextFileRequest): Task[SipiGetTextFileResponse] =
sipiService.getTextFileRequest(textFileRequest)

/**
* Tries to access the IIIF Service.
*/
override def getStatus(): Task[IIIFServiceStatusResponse] =
sipiService.getStatus()

/**
* Downloads an asset from Sipi.
*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -101,14 +101,8 @@ abstract class CoreSpec
/* Here we start our app and initialize the repository before each suit runs */
Unsafe.unsafe { implicit u =>
runtime.unsafe
.run(
(for {
_ <- AppServer.testWithoutSipi
_ <- prepareRepository(rdfDataObjects) @@ LogAspect.logSpan("prepare-repo")
} yield ()),
)
.run(AppServer.test *> prepareRepository(rdfDataObjects) @@ LogAspect.logSpan("prepare-repo"))
.getOrThrow()

}

final override def afterAll(): Unit =
Expand Down
11 changes: 4 additions & 7 deletions integration/src/test/scala/org/knora/webapi/E2ESpec.scala
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ package org.knora.webapi

import com.typesafe.scalalogging._
import org.apache.pekko
import org.apache.pekko.http.scaladsl.client.RequestBuilding
import org.apache.pekko.http.scaladsl.model._
import org.apache.pekko.testkit.TestKitBase
import org.scalatest.BeforeAndAfterAll
import org.scalatest.concurrent.ScalaFutures
import org.scalatest.matchers.should.Matchers
Expand Down Expand Up @@ -38,10 +41,6 @@ import org.knora.webapi.testservices.TestClientService
import org.knora.webapi.util.FileUtil
import org.knora.webapi.util.LogAspect

import pekko.http.scaladsl.client.RequestBuilding
import pekko.http.scaladsl.model._
import pekko.testkit.TestKitBase

/**
* This class can be used in End-to-End testing. It starts the DSP stack
* and provides access to settings and logging.
Expand Down Expand Up @@ -110,9 +109,7 @@ abstract class E2ESpec

final override def beforeAll(): Unit =
/* Here we start our app and initialize the repository before each suit runs */
UnsafeZioRun.runOrThrow(
AppServer.testWithoutSipi *> (prepareRepository(rdfDataObjects) @@ LogAspect.logSpan("prepare-repo")),
)
UnsafeZioRun.runOrThrow(AppServer.test *> (prepareRepository(rdfDataObjects) @@ LogAspect.logSpan("prepare-repo")))

final override def afterAll(): Unit =
/* Stop ZIO runtime and release resources (e.g., running docker containers) */
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -28,7 +28,7 @@ abstract class E2EZSpec extends ZIOSpecDefault with TestStartupUtils {

private def prepare: ZIO[AppServer.AppServerEnvironment, Throwable, AppServer] = for {
appServer <- AppServer.init()
_ <- appServer.start(requiresAdditionalRepositoryChecks = false, requiresIIIFService = false).orDie
_ <- appServer.start(requiresAdditionalRepositoryChecks = false).orDie
_ <- prepareRepository(rdfDataObjects)
} yield appServer

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -104,7 +104,7 @@ abstract class ITKnoraLiveSpec
runtime.unsafe
.run(
for {
_ <- AppServer.testWithSipi
_ <- AppServer.test
_ <- prepareRepository(rdfDataObjects) @@ LogAspect.logSpan("prepare-repo")
} yield (),
)
Expand Down
7 changes: 1 addition & 6 deletions integration/src/test/scala/org/knora/webapi/R2RSpec.scala
Original file line number Diff line number Diff line change
Expand Up @@ -83,12 +83,7 @@ abstract class R2RSpec
/* Here we start our app and initialize the repository before each suit runs */
Unsafe.unsafe { implicit u =>
runtime.unsafe
.run(
for {
_ <- AppServer.testWithoutSipi
_ <- prepareRepository(rdfDataObjects) @@ LogAspect.logSpan("prepare-repo")
} yield (),
)
.run(AppServer.test *> prepareRepository(rdfDataObjects) @@ LogAspect.logSpan("prepare-repo"))
.getOrThrow()
}

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -61,8 +61,6 @@ case class SipiServiceMock() extends SipiService {

override def getTextFileRequest(textFileRequest: SipiGetTextFileRequest): Task[SipiGetTextFileResponse] = ???

override def getStatus(): Task[IIIFServiceStatusResponse] = ZIO.succeed(IIIFServiceStatusOK)

override def downloadAsset(asset: Asset, targetDir: Path, user: User): Task[Option[Path]] = ???

override def getFileMetadataFromDspIngest(
Expand Down
43 changes: 4 additions & 39 deletions webapi/src/main/scala/org/knora/webapi/core/AppServer.scala
Original file line number Diff line number Diff line change
Expand Up @@ -10,8 +10,6 @@ import zio._

import org.knora.webapi.config.AppConfig
import org.knora.webapi.core.domain.AppState
import org.knora.webapi.messages.store.sipimessages.IIIFServiceStatusNOK
import org.knora.webapi.messages.store.sipimessages.IIIFServiceStatusOK
import org.knora.webapi.messages.util.KnoraSystemInstances
import org.knora.webapi.slice.ontology.repo.service.OntologyCache
import org.knora.webapi.store.iiif.api.SipiService
Expand Down Expand Up @@ -74,27 +72,6 @@ final case class AppServer(
_ <- state.set(AppState.OntologiesReady)
} yield ()

/**
* Checks if the IIIF service is running
*
* @param requiresIIIFService If `true`, checks the status of the IIIFService instance, otherwise returns ()
*/
private def checkIIIFService(requiresIIIFService: Boolean): UIO[Unit] =
for {
_ <- state.set(AppState.WaitingForIIIFService)
_ <- sipiService
.getStatus()
.flatMap {
case IIIFServiceStatusOK =>
ZIO.logInfo("IIIF service running")
case IIIFServiceStatusNOK =>
ZIO.logError("IIIF service not running") *> ZIO.die(new Exception("IIIF service not running"))
}
.when(requiresIIIFService)
.orDie
_ <- state.set(AppState.IIIFServiceReady)
} yield ()

/**
* Initiates the startup of the DSP-API server.
*
Expand All @@ -104,14 +81,12 @@ final case class AppServer(
*/
def start(
requiresAdditionalRepositoryChecks: Boolean,
requiresIIIFService: Boolean,
): Task[Unit] =
for {
_ <- ZIO.logInfo("=> Startup checks initiated")
_ <- checkTriplestoreService
_ <- upgradeRepository(requiresAdditionalRepositoryChecks)
_ <- populateOntologyCaches(requiresAdditionalRepositoryChecks)
_ <- checkIIIFService(requiresIIIFService)
_ <- ZIO.logInfo("=> Startup checks finished")
_ <- ZIO.logInfo(s"DSP-API Server started: ${appConfig.knoraApi.internalKnoraApiBaseUrl}")
_ <- ZIO.logWarning("Resetting DB over HTTP is turned ON").when(appConfig.allowReloadOverHttp)
Expand Down Expand Up @@ -146,26 +121,16 @@ object AppServer {
val make: URIO[AppServerEnvironment, Unit] =
for {
appServer <- AppServer.init()
_ <- appServer.start(requiresAdditionalRepositoryChecks = true, requiresIIIFService = true).orDie
} yield ()

/**
* The test AppServer with Sipi, which initiates the startup checks. Before this effect does what it does,
* the complete server should have already been started.
*/
val testWithSipi: ZIO[AppServerEnvironment, Nothing, Unit] =
for {
appServer <- AppServer.init()
_ <- appServer.start(requiresAdditionalRepositoryChecks = false, requiresIIIFService = true).orDie
_ <- appServer.start(requiresAdditionalRepositoryChecks = true).orDie
} yield ()

/**
* The test AppServer without Sipi, which initiates the startup checks. Before this effect does what it does,
* The test AppServer with or without Sipi, which initiates the startup checks. Before this effect does what it does,
* the complete server should have already been started.
*/
val testWithoutSipi: ZIO[AppServerEnvironment, Nothing, Unit] =
val test: ZIO[AppServerEnvironment, Nothing, Unit] =
for {
appServer <- AppServer.init()
_ <- appServer.start(requiresAdditionalRepositoryChecks = false, requiresIIIFService = false).orDie
_ <- appServer.start(requiresAdditionalRepositoryChecks = false).orDie
} yield ()
}
Original file line number Diff line number Diff line change
Expand Up @@ -17,8 +17,6 @@ object AppState {
case object RepositoryUpToDate extends AppState
case object LoadingOntologies extends AppState
case object OntologiesReady extends AppState
case object WaitingForIIIFService extends AppState
case object IIIFServiceReady extends AppState
case object MaintenanceMode extends AppState
case object Running extends AppState
}
Original file line number Diff line number Diff line change
Expand Up @@ -57,31 +57,6 @@ case class SipiGetTextFileRequest(fileUrl: String, requestingUser: User, senderN
*/
case class SipiGetTextFileResponse(content: String)

//////////////////////////////////////////////////////////////////////////////////////////////////////////////////
// IIIF Request ADM

sealed trait IIIFRequestADM extends IIIFRequest

/**
* Queries IIIF Service status.
*/
case object IIIFServiceGetStatus extends IIIFRequestADM

/**
* Represents a response for [[IIIFServiceGetStatus]].
*/
sealed trait IIIFServiceStatusResponse

/**
* Represents a positive response for [[IIIFServiceGetStatus]].
*/
case object IIIFServiceStatusOK extends IIIFServiceStatusResponse

/**
* Represents a negative response for [[IIIFServiceGetStatus]].
*/
case object IIIFServiceStatusNOK extends IIIFServiceStatusResponse

/**
* Represents the information that Sipi returns about each file that has been uploaded.
*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -67,8 +67,6 @@ object HealthResponse {
case AppState.RepositoryUpToDate => unhealthy("Repository up to date. Please retry later.")
case AppState.LoadingOntologies => unhealthy("Loading ontologies. Please retry later.")
case AppState.OntologiesReady => unhealthy("Ontologies ready. Please retry later.")
case AppState.WaitingForIIIFService => unhealthy("Waiting for IIIF service. Please retry later.")
case AppState.IIIFServiceReady => unhealthy("IIIF service ready. Please retry later.")
case AppState.MaintenanceMode => unhealthy("Application is in maintenance mode. Please retry later.")
case AppState.Running => healthy
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -12,7 +12,6 @@ import org.knora.webapi.core.MessageRelay
import org.knora.webapi.messages.ResponderRequest
import org.knora.webapi.messages.store.sipimessages.DeleteTemporaryFileRequest
import org.knora.webapi.messages.store.sipimessages.IIIFRequest
import org.knora.webapi.messages.store.sipimessages.IIIFServiceGetStatus
import org.knora.webapi.messages.store.sipimessages.MoveTemporaryFileToPermanentStorageRequest
import org.knora.webapi.messages.store.sipimessages.SipiGetTextFileRequest
import org.knora.webapi.store.iiif.api.SipiService
Expand All @@ -28,7 +27,6 @@ final case class IIIFRequestMessageHandlerLive(iiifService: SipiService) extends
case req: MoveTemporaryFileToPermanentStorageRequest => iiifService.moveTemporaryFileToPermanentStorage(req)
case req: DeleteTemporaryFileRequest => iiifService.deleteTemporaryFile(req)
case req: SipiGetTextFileRequest => iiifService.getTextFileRequest(req)
case IIIFServiceGetStatus => iiifService.getStatus()
case other => ZIO.logError(s"IIIFServiceManager received an unexpected message: $other")
}
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -103,11 +103,6 @@ trait SipiService {
*/
def getTextFileRequest(textFileRequest: SipiGetTextFileRequest): Task[SipiGetTextFileResponse]

/**
* Tries to access the IIIF Service.
*/
def getStatus(): Task[IIIFServiceStatusResponse]

/**
* Downloads an asset from Sipi.
*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -234,15 +234,6 @@ final case class SipiServiceLive(
} yield SipiGetTextFileResponse(responseStr)
}

/**
* Tries to access the IIIF Service to check if Sipi is running.
*/
def getStatus(): Task[IIIFServiceStatusResponse] =
for {
request <- ZIO.succeed(new HttpGet(sipiConfig.internalBaseUrl + "/server/test.html"))
response <- doSipiRequest(request).fold(_ => IIIFServiceStatusNOK, _ => IIIFServiceStatusOK)
} yield response

/**
* Makes an HTTP request to Sipi and returns the response.
*
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -17,7 +17,6 @@ import zio.test.assertTrue

import dsp.errors.AssertionException
import org.knora.webapi.messages.store.sipimessages.DeleteTemporaryFileRequest
import org.knora.webapi.messages.store.sipimessages.IIIFServiceStatusResponse
import org.knora.webapi.messages.store.sipimessages.MoveTemporaryFileToPermanentStorageRequest
import org.knora.webapi.messages.store.sipimessages.SipiGetTextFileRequest
import org.knora.webapi.messages.store.sipimessages.SipiGetTextFileResponse
Expand Down Expand Up @@ -95,8 +94,6 @@ object ValueContentV2Spec extends ZIOSpecDefault {
ZIO.dieMessage("unsupported operation")
def getTextFileRequest(textFileRequest: SipiGetTextFileRequest): Task[SipiGetTextFileResponse] =
ZIO.dieMessage("unsupported operation")
def getStatus(): Task[IIIFServiceStatusResponse] =
ZIO.dieMessage("unsupported operation")
def downloadAsset(asset: Asset, targetDir: Path, user: User): Task[Option[Path]] =
ZIO.dieMessage("unsupported operation")
})
Expand Down
Loading