diff --git a/build.gradle b/build.gradle index c2d1ce6e..cdf248dd 100644 --- a/build.gradle +++ b/build.gradle @@ -159,6 +159,7 @@ dependencies { testImplementation 'javax.annotation:javax.annotation-api:1.3.2' testImplementation "org.junit.jupiter:junit-jupiter:$junitVersion" + testImplementation "org.junit.jupiter:junit-jupiter-params:$junitVersion" testImplementation "org.mockito.kotlin:mockito-kotlin:5.3.1" testImplementation 'org.jetbrains.kotlin:kotlin-test-junit5' testImplementation "org.testcontainers:testcontainers:1.19.8" diff --git a/src/main/kotlin/com/exactpro/th2/common/schema/factory/ExactproMetaInf.kt b/src/main/kotlin/com/exactpro/th2/common/schema/factory/ExactproMetaInf.kt index f35cad8d..919fff34 100644 --- a/src/main/kotlin/com/exactpro/th2/common/schema/factory/ExactproMetaInf.kt +++ b/src/main/kotlin/com/exactpro/th2/common/schema/factory/ExactproMetaInf.kt @@ -112,15 +112,10 @@ internal class ExactproMetaInf( } } - private fun URL.toPath(): Path = toURI().run { - // the code below are added to provide windows compatibility - when (scheme) { - "file" -> Path.of(this) - "jar" -> Path.of(schemeSpecificPart - .substringBefore("!") - .removePrefix("file:")) - else -> error("The '$scheme' schema of '$this' URI can't be handled") - } + internal fun URL.toPath(): Path = when (protocol) { + "jar" -> URL(file).toPath() // the code below are added to provide windows compatibility + "file" -> Path.of(path) + else -> error("The '$protocol' protocol of '$this' URL can't be handled") } } } diff --git a/src/test/kotlin/com/exactpro/th2/common/schema/factory/ExactproMetaInfTest.kt b/src/test/kotlin/com/exactpro/th2/common/schema/factory/ExactproMetaInfTest.kt new file mode 100644 index 00000000..f1add693 --- /dev/null +++ b/src/test/kotlin/com/exactpro/th2/common/schema/factory/ExactproMetaInfTest.kt @@ -0,0 +1,36 @@ +/* + * Copyright 2024 Exactpro (Exactpro Systems Limited) + * + * Licensed under the Apache License, Version 2.0 (the "License"); + * you may not use this file except in compliance with the License. + * You may obtain a copy of the License at + * + * http://www.apache.org/licenses/LICENSE-2.0 + * + * Unless required by applicable law or agreed to in writing, software + * distributed under the License is distributed on an "AS IS" BASIS, + * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. + * See the License for the specific language governing permissions and + * limitations under the License. + */ + +package com.exactpro.th2.common.schema.factory + +import com.exactpro.th2.common.schema.factory.ExactproMetaInf.Companion.toPath +import org.junit.jupiter.params.ParameterizedTest +import org.junit.jupiter.params.provider.CsvSource +import java.net.URL +import java.nio.file.Path +import kotlin.test.assertEquals + +class ExactproMetaInfTest { + + @ParameterizedTest + @CsvSource( + """jar:file:/C:/Users/test!user/common-0.0.0.jar!/META-INF/MANIFEST.MF,/C:/Users/test!user/common-0.0.0.jar!/META-INF/MANIFEST.MF""", + """jar:file:/home/user/common-0.0.0-dev.jar!/META-INF/MANIFEST.MF,/home/user/common-0.0.0-dev.jar!/META-INF/MANIFEST.MF""" + ) + fun `convert url to path test`(url: String, path: String) { + assertEquals(Path.of(path), URL(url).toPath()) + } +} \ No newline at end of file