From 9e8edc8687f0f1b8554b587454ed053f0cbf271e Mon Sep 17 00:00:00 2001 From: Vladimir Sitnikov Date: Sat, 18 Feb 2023 20:52:11 +0300 Subject: [PATCH] fix: avoid failure when index restore misses layer-..json file --- .../com/github/burrunan/gradle/cache/LayeredCache.kt | 9 ++++++++- .../main/kotlin/actions/core/ActionFailedException.kt | 5 ++--- 2 files changed, 10 insertions(+), 4 deletions(-) diff --git a/layered-cache/src/main/kotlin/com/github/burrunan/gradle/cache/LayeredCache.kt b/layered-cache/src/main/kotlin/com/github/burrunan/gradle/cache/LayeredCache.kt index e074549..b714373 100644 --- a/layered-cache/src/main/kotlin/com/github/burrunan/gradle/cache/LayeredCache.kt +++ b/layered-cache/src/main/kotlin/com/github/burrunan/gradle/cache/LayeredCache.kt @@ -19,6 +19,7 @@ import actions.cache.RestoreType import actions.core.ActionFailedException import actions.core.debug import actions.core.info +import actions.core.warning import actions.glob.removeFiles import com.github.burrunan.formatBytes import com.github.burrunan.gradle.github.stateVariable @@ -60,6 +61,9 @@ class LayeredCache( paths = listOf(layers.cachedName), ) + override fun toString(): String = + "Cache $name, primaryKey=$primaryKey, restoreKeys=$restoreKeys, " + private fun CacheLayer.toCache(stateKey: String) = DefaultCache( name = name, @@ -83,7 +87,10 @@ class LayeredCache( if (indexRestoreType == RestoreType.None) { return RestoreType.None } - val cacheIndex = layers.decode() ?: throw ActionFailedException("${layers.cachedName} is not found") + val cacheIndex = layers.decode() ?: run { + warning("Unable to restore cache $this") + return RestoreType.Unknown + } var restoreType: RestoreType = when (indexRestoreType) { is RestoreType.Exact -> RestoreType.Exact(indexRestoreType.path.removePrefix("$version-index-")) diff --git a/wrappers/actions-core/src/main/kotlin/actions/core/ActionFailedException.kt b/wrappers/actions-core/src/main/kotlin/actions/core/ActionFailedException.kt index 4c4be4e..7a02fd3 100644 --- a/wrappers/actions-core/src/main/kotlin/actions/core/ActionFailedException.kt +++ b/wrappers/actions-core/src/main/kotlin/actions/core/ActionFailedException.kt @@ -16,6 +16,5 @@ package actions.core -class ActionFailedException(override val message: String, cause: Throwable?): Throwable(message, cause) { - constructor(message: String): this(message, null) -} +class ActionFailedException(override val message: String, cause: Throwable? = null) : + Throwable(message, cause)