Skip to content

Commit

Permalink
Update commons compress
Browse files Browse the repository at this point in the history
  • Loading branch information
StepanBrychta committed Oct 7, 2024
1 parent 36346e9 commit 3849354
Show file tree
Hide file tree
Showing 4 changed files with 20 additions and 26 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -190,7 +190,7 @@ trait Unpacker[
case err: IOException
if err.getMessage == "Error detected parsing the header" =>
UnpackerUnarchiverError(UnexpectedUnarchiverError(err))
case err: IOException if err.getMessage.startsWith("unexpected EOF") =>
case err: IOException if err.getMessage.startsWith("unexpected EOF") || err.getMessage.startsWith("Truncated TAR archive") =>
UnpackerEOFError(err)
case err => UnpackerUnexpectedError(err)
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -50,7 +50,7 @@ object Unarchiver {
} yield iterator

private def createIterator(
archiveInputStream: ArchiveInputStream
archiveInputStream: ArchiveInputStream[ArchiveEntry]
): Iterator[(ArchiveEntry, InputStream)] =
new Iterator[(ArchiveEntry, InputStream)] {
private var latest: ArchiveEntry = _
Expand Down Expand Up @@ -90,13 +90,13 @@ object Unarchiver {
}
private def extract(
inputStream: InputStream
): Either[UnarchiverError, ArchiveInputStream] =
): Either[UnarchiverError, ArchiveInputStream[ArchiveEntry]] =
Try {
// We have to wrap in a BufferedInputStream because this method
// only takes InputStreams that support the `mark()` method.
new ArchiveStreamFactory()
.createArchiveInputStream(new BufferedInputStream(inputStream))
.asInstanceOf[ArchiveInputStream]
.asInstanceOf[ArchiveInputStream[ArchiveEntry]]
} match {
case Success(stream) => Right(stream)
case Failure(err: ArchiveException) => Left(ArchiveFormatError(err))
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -2,16 +2,9 @@ package weco.storage_service.bag_unpacker.fixtures

import java.io.{File, _}
import grizzled.slf4j.Logging
import org.apache.commons.compress.archivers.{
ArchiveEntry,
ArchiveOutputStream,
ArchiveStreamFactory
}
import org.apache.commons.compress.compressors.{
CompressorOutputStream,
CompressorStreamFactory
}
import org.apache.commons.io.IOUtils
import org.apache.commons.compress.archivers.{ArchiveEntry, ArchiveOutputStream, ArchiveStreamFactory}
import org.apache.commons.compress.compressors.{CompressorOutputStream, CompressorStreamFactory}
import org.scalatest.matchers.should.Matchers
import weco.fixtures.TestWith
import weco.storage_service.generators.StorageRandomGenerators
Expand Down Expand Up @@ -146,6 +139,7 @@ trait CompressFixture[BagLocation <: Location, Namespace]
def finish(): Unit = {
archiveOutputStream.flush()
archiveOutputStream.finish()
archiveOutputStream.close()
compressorOutputStream.flush()
compressorOutputStream.close()
}
Expand Down Expand Up @@ -182,7 +176,7 @@ trait CompressFixture[BagLocation <: Location, Namespace]
compressorName: String
)(
outputStream: OutputStream
): CompressorOutputStream = {
): CompressorOutputStream[BufferedOutputStream] = {

val compressorStreamFactory =
new CompressorStreamFactory()
Expand All @@ -195,13 +189,13 @@ trait CompressFixture[BagLocation <: Location, Namespace]
compressorName,
bufferedOutputStream
)
}
}.asInstanceOf[CompressorOutputStream[BufferedOutputStream]]

private def packer(
archiverName: String
)(
outputStream: OutputStream
): ArchiveOutputStream = {
): ArchiveOutputStream[ArchiveEntry] = {

val archiveStreamFactory =
new ArchiveStreamFactory()
Expand Down
20 changes: 10 additions & 10 deletions project/Dependencies.scala
Original file line number Diff line number Diff line change
Expand Up @@ -2,15 +2,15 @@ import sbt._

object WellcomeDependencies {
lazy val versions = new {
val typesafe = "32.43.1"
val fixtures = "32.43.1"
val http = "32.43.1"
val json = "32.43.1"
val messaging = "32.43.1"
val monitoring = "32.43.1"
val storage = "32.43.1"
val elasticsearch = "32.43.1"
val sierra = "32.43.1"
val typesafe = "32.44.0-SNAPSHOT"
val fixtures = "32.44.0-SNAPSHOT"
val http = "32.44.0-SNAPSHOT"
val json = "32.44.0-SNAPSHOT"
val messaging = "32.44.0-SNAPSHOT"
val monitoring = "32.44.0-SNAPSHOT"
val storage = "32.44.0-SNAPSHOT"
val elasticsearch = "32.44.0-SNAPSHOT"
val sierra = "32.44.0-SNAPSHOT"
}

val jsonLibrary: Seq[ModuleID] = Seq(
Expand Down Expand Up @@ -83,7 +83,7 @@ object ExternalDependencies {
lazy val versions = new {

val azure = "12.25.4"
val commonsCompress = "1.5"
val commonsCompress = "1.27.1"
val commonsIO = "2.17.0"
val mockito = "5.13.0"
val scalatest = "3.2.19"
Expand Down

0 comments on commit 3849354

Please sign in to comment.