diff --git a/analyzer/src/main/kotlin/Analyzer.kt b/analyzer/src/main/kotlin/Analyzer.kt index 03f447568d64b..e7fa651f8ef11 100644 --- a/analyzer/src/main/kotlin/Analyzer.kt +++ b/analyzer/src/main/kotlin/Analyzer.kt @@ -42,6 +42,7 @@ import org.ossreviewtoolkit.model.AnalyzerResult import org.ossreviewtoolkit.model.AnalyzerRun import org.ossreviewtoolkit.model.OrtResult import org.ossreviewtoolkit.model.Repository +import org.ossreviewtoolkit.model.RepositoryProvenance import org.ossreviewtoolkit.model.config.AnalyzerConfiguration import org.ossreviewtoolkit.model.config.Excludes import org.ossreviewtoolkit.model.config.RepositoryConfiguration @@ -135,11 +136,18 @@ class Analyzer(private val config: AnalyzerConfiguration, private val labels: Ma val workingTree = VersionControlSystem.forDirectory(info.absoluteProjectPath) val vcs = workingTree?.getInfo().orEmpty() + val revision = workingTree?.getRevision().orEmpty() val nestedVcs = workingTree?.getNested()?.filter { (path, _) -> // Only include nested VCS if they are part of the analyzed directory. workingTree.getRootPath().resolve(path).startsWith(info.absoluteProjectPath) }.orEmpty() - val repository = Repository(vcs = vcs, nestedRepositories = nestedVcs, config = info.repositoryConfiguration) + val repository = Repository( + provenance = RepositoryProvenance(vcs, revision), + nestedRepositories = nestedVcs.map { + it.key to RepositoryProvenance(it.value, it.value.revision) + }.toMap(), + config = info.repositoryConfiguration + ) val endTime = Instant.now() diff --git a/cli/src/funTest/assets/git-repo-expected-output.yml b/cli/src/funTest/assets/git-repo-expected-output.yml index 3b6f280282408..69bc11fed3259 100644 --- a/cli/src/funTest/assets/git-repo-expected-output.yml +++ b/cli/src/funTest/assets/git-repo-expected-output.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "GitRepo" - url: "https://github.com/oss-review-toolkit/ort-test-data-git-repo?manifest=manifest.xml" - revision: "31588aa8f8555474e1c3c66a359ec99e4cd4b1fa" - path: "" - vcs_processed: - type: "GitRepo" - url: "https://github.com/oss-review-toolkit/ort-test-data-git-repo.git?manifest=manifest.xml" - revision: "31588aa8f8555474e1c3c66a359ec99e4cd4b1fa" - path: "" + provenance: + vcsInfo: + type: "GitRepo" + url: "https://github.com/oss-review-toolkit/ort-test-data-git-repo?manifest=manifest.xml" + revision: "31588aa8f8555474e1c3c66a359ec99e4cd4b1fa" + path: "" + resolvedRevision: "31588aa8f8555474e1c3c66a359ec99e4cd4b1fa" nested_repositories: spdx-tools: type: "Git" diff --git a/cli/src/funTest/assets/gradle-all-dependencies-expected-result-with-curations.yml b/cli/src/funTest/assets/gradle-all-dependencies-expected-result-with-curations.yml index 5ead4c4f0d4e3..5e92476d47954 100644 --- a/cli/src/funTest/assets/gradle-all-dependencies-expected-result-with-curations.yml +++ b/cli/src/funTest/assets/gradle-all-dependencies-expected-result-with-curations.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "Git" - url: "" - revision: "" - path: "plugins/package-managers/gradle/src/funTest/assets/projects/synthetic/gradle" - vcs_processed: - type: "Git" - url: "" - revision: "" - path: "plugins/package-managers/gradle/src/funTest/assets/projects/synthetic/gradle" + provenance: + vcs_info: + type: "Git" + url: "" + revision: "" + path: "plugins/package-managers/gradle/src/funTest/assets/projects/synthetic/gradle" + resolved_revision: "" config: excludes: paths: diff --git a/cli/src/funTest/assets/semver4j-ort-result.yml b/cli/src/funTest/assets/semver4j-ort-result.yml index 7f06ecc1c2915..695a666fe83f4 100644 --- a/cli/src/funTest/assets/semver4j-ort-result.yml +++ b/cli/src/funTest/assets/semver4j-ort-result.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "Git" - url: "https://github.com/vdurmont/semver4j.git" - revision: "7653e418d610ffcd2811bcb55fd72d00d420950b" - path: "" - vcs_processed: - type: "Git" - url: "https://github.com/vdurmont/semver4j.git" - revision: "7653e418d610ffcd2811bcb55fd72d00d420950b" - path: "" + provenance: + vcs_info: + type: "Git" + url: "https://github.com/vdurmont/semver4j.git" + revision: "7653e418d610ffcd2811bcb55fd72d00d420950b" + path: "" + resolved_revision: "" config: excludes: scopes: diff --git a/evaluator/src/main/kotlin/ProjectSourceRule.kt b/evaluator/src/main/kotlin/ProjectSourceRule.kt index e390cb0835218..de06cd9e3a692 100644 --- a/evaluator/src/main/kotlin/ProjectSourceRule.kt +++ b/evaluator/src/main/kotlin/ProjectSourceRule.kt @@ -91,7 +91,7 @@ open class ProjectSourceRule( /** * Return the [VcsType] of the project's code repository. */ - fun projectSourceGetVcsType(): VcsType = ortResult.repository.vcsProcessed.type + fun projectSourceGetVcsType(): VcsType = ortResult.repository.vcsProcessed().type /** * Return the file paths matching any of the given [glob expressions][patterns] with its file content matching diff --git a/evaluator/src/main/kotlin/RuleSet.kt b/evaluator/src/main/kotlin/RuleSet.kt index d90f3f2991a5d..259559489840d 100644 --- a/evaluator/src/main/kotlin/RuleSet.kt +++ b/evaluator/src/main/kotlin/RuleSet.kt @@ -159,7 +159,7 @@ fun ruleSet( licenseInfoResolver: LicenseInfoResolver = ortResult.createLicenseInfoResolver(), resolutionProvider: ResolutionProvider = DefaultResolutionProvider.create(), projectSourceResolver: SourceTreeResolver = SourceTreeResolver.forRemoteRepository( - ortResult.repository.vcsProcessed + ortResult.repository.vcsProcessed() ), configure: RuleSet.() -> Unit = { } ) = RuleSet(ortResult, licenseInfoResolver, resolutionProvider, projectSourceResolver).apply(configure) diff --git a/evaluator/src/test/kotlin/ProjectSourceRuleTest.kt b/evaluator/src/test/kotlin/ProjectSourceRuleTest.kt index 7f834823f684e..80d620eb17af7 100644 --- a/evaluator/src/test/kotlin/ProjectSourceRuleTest.kt +++ b/evaluator/src/test/kotlin/ProjectSourceRuleTest.kt @@ -208,7 +208,7 @@ private fun createOrtResult( } return OrtResult.EMPTY.copy( - repository = Repository(vcsInfo), + repository = Repository(RepositoryProvenance(vcsInfo, vcsInfo.revision)), analyzer = AnalyzerRun.EMPTY.copy( result = AnalyzerResult.EMPTY.copy( projects = setOf( diff --git a/evaluator/src/test/kotlin/TestData.kt b/evaluator/src/test/kotlin/TestData.kt index 45d72b0c61b56..a9f22e0924273 100644 --- a/evaluator/src/test/kotlin/TestData.kt +++ b/evaluator/src/test/kotlin/TestData.kt @@ -37,6 +37,7 @@ import org.ossreviewtoolkit.model.Package import org.ossreviewtoolkit.model.PackageLinkage import org.ossreviewtoolkit.model.Project import org.ossreviewtoolkit.model.Repository +import org.ossreviewtoolkit.model.RepositoryProvenance import org.ossreviewtoolkit.model.ScanResult import org.ossreviewtoolkit.model.ScanSummary import org.ossreviewtoolkit.model.ScannerDetails @@ -180,7 +181,7 @@ val allProjects = setOf( val ortResult = OrtResult( repository = Repository( - vcs = VcsInfo.EMPTY, + provenance = RepositoryProvenance(VcsInfo.EMPTY, ""), config = RepositoryConfiguration( excludes = Excludes( paths = listOf( diff --git a/helper-cli/src/funTest/assets/create-analyzer-result-from-pkg-list-expected-output.yml b/helper-cli/src/funTest/assets/create-analyzer-result-from-pkg-list-expected-output.yml index 69d7709bb6a00..cdb580b567c65 100644 --- a/helper-cli/src/funTest/assets/create-analyzer-result-from-pkg-list-expected-output.yml +++ b/helper-cli/src/funTest/assets/create-analyzer-result-from-pkg-list-expected-output.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "Git" - url: "https://github.com/example/project.git" - revision: "2222222222222222222222222222222222222222" - path: "vcs-path/project" - vcs_processed: - type: "Git" - url: "https://github.com/example/project.git" - revision: "2222222222222222222222222222222222222222" - path: "vcs-path/project" + provenance: + vcs_info: + type: "Git" + url: "https://github.com/example/project.git" + revision: "2222222222222222222222222222222222222222" + path: "vcs-path/project" + resolved_revision: "2222222222222222222222222222222222222222" config: excludes: scopes: diff --git a/helper-cli/src/main/kotlin/commands/CreateAnalyzerResultFromPackageListCommand.kt b/helper-cli/src/main/kotlin/commands/CreateAnalyzerResultFromPackageListCommand.kt index 7921112313610..dd7007486e075 100644 --- a/helper-cli/src/main/kotlin/commands/CreateAnalyzerResultFromPackageListCommand.kt +++ b/helper-cli/src/main/kotlin/commands/CreateAnalyzerResultFromPackageListCommand.kt @@ -41,6 +41,7 @@ import org.ossreviewtoolkit.model.PackageReference import org.ossreviewtoolkit.model.Project import org.ossreviewtoolkit.model.RemoteArtifact import org.ossreviewtoolkit.model.Repository +import org.ossreviewtoolkit.model.RepositoryProvenance import org.ossreviewtoolkit.model.Scope import org.ossreviewtoolkit.model.VcsInfo import org.ossreviewtoolkit.model.VcsType @@ -118,7 +119,7 @@ internal class CreateAnalyzerResultFromPackageListCommand : CliktCommand( environment = Environment() ), repository = Repository( - vcs = projectVcs.normalize(), + provenance = RepositoryProvenance(projectVcs.normalize(), projectVcs.revision), config = RepositoryConfiguration( excludes = Excludes( scopes = listOf( diff --git a/helper-cli/src/main/kotlin/utils/Extensions.kt b/helper-cli/src/main/kotlin/utils/Extensions.kt index 061e3fcca4633..3a00d0257bf5d 100644 --- a/helper-cli/src/main/kotlin/utils/Extensions.kt +++ b/helper-cli/src/main/kotlin/utils/Extensions.kt @@ -38,9 +38,7 @@ import org.ossreviewtoolkit.model.OrtResult import org.ossreviewtoolkit.model.PackageCuration import org.ossreviewtoolkit.model.Project import org.ossreviewtoolkit.model.Provenance -import org.ossreviewtoolkit.model.Repository import org.ossreviewtoolkit.model.RepositoryProvenance -import org.ossreviewtoolkit.model.RuleViolation import org.ossreviewtoolkit.model.ScanResult import org.ossreviewtoolkit.model.Severity import org.ossreviewtoolkit.model.SourceCodeOrigin @@ -272,7 +270,7 @@ internal fun String.wrapAt(column: Int): String = }.trimEnd() /** - * Return a copy of this [OrtResult] with the [Repository.config] with the content of the given + * Return a copy of this [OrtResult] with the [config] with the content of the given * [repositoryConfigurationFile]. */ internal fun OrtResult.replaceConfig(repositoryConfigurationFile: File?): OrtResult = @@ -691,10 +689,12 @@ internal fun OrtResult.getScanResultFor(packageConfiguration: PackageConfigurati * tree. */ internal fun OrtResult.getRepositoryPaths(): Map> { - val result = mutableMapOf(repository.vcsProcessed.url to mutableSetOf("")) + val result = mutableMapOf(repository.vcsProcessed().url to mutableSetOf("")) - repository.nestedRepositories.mapValues { (path, vcsInfo) -> - result.getOrPut(vcsInfo.url) { mutableSetOf() } += path + repository.nestedRepositories.mapValues { (path, provenance) -> + if (provenance is RepositoryProvenance) { + result.getOrPut(provenance.vcsInfo.url) { mutableSetOf() } += path + } } // For some Git-repo projects `OrtResult.repository.nestedRepositories´ misses some nested repositories for Git diff --git a/helper-cli/src/main/kotlin/utils/Utils.kt b/helper-cli/src/main/kotlin/utils/Utils.kt index 555277d595bef..4dd3d444ef511 100644 --- a/helper-cli/src/main/kotlin/utils/Utils.kt +++ b/helper-cli/src/main/kotlin/utils/Utils.kt @@ -25,8 +25,10 @@ import java.io.File import org.ossreviewtoolkit.downloader.VersionControlSystem import org.ossreviewtoolkit.model.Identifier +import org.ossreviewtoolkit.model.KnownProvenance import org.ossreviewtoolkit.model.OrtResult import org.ossreviewtoolkit.model.PackageCuration +import org.ossreviewtoolkit.model.RepositoryProvenance import org.ossreviewtoolkit.model.VcsInfo import org.ossreviewtoolkit.model.config.LicenseFindingCuration import org.ossreviewtoolkit.model.config.PathExclude @@ -68,8 +70,10 @@ internal fun findRepositoryPaths(directory: File): Map> { val result = mutableMapOf>() - findRepositories(directory).forEach { (path, vcs) -> - result.getOrPut(vcs.url.replaceCredentialsInUri()) { mutableSetOf() } += path + findRepositories(directory).forEach { (path, provenance) -> + if (provenance is RepositoryProvenance) { + result.getOrPut(provenance.vcsInfo.url.replaceCredentialsInUri()) { mutableSetOf() } += path + } } return result @@ -79,14 +83,17 @@ internal fun findRepositoryPaths(directory: File): Map> { * Search the given [directory] for repositories and return a mapping from paths where each respective repository was * found to the corresponding [VcsInfo]. */ -internal fun findRepositories(directory: File): Map { +internal fun findRepositories(directory: File): Map { require(directory.isDirectory) val workingTree = VersionControlSystem.forDirectory(directory) - return workingTree?.getNested()?.filter { (path, _) -> + val nestedVcs = workingTree?.getNested()?.filter { (path, _) -> // Only include nested VCS if they are part of the analyzed directory. workingTree.getRootPath().resolve(path).startsWith(directory) }.orEmpty() + return nestedVcs.map { + it.key to RepositoryProvenance(it.value, it.value.revision) + }.toMap() } /** @@ -166,15 +173,17 @@ internal data class ProcessedCopyrightStatement( */ internal fun getLicenseFindingCurationsByRepository( curations: Collection, - nestedRepositories: Map + nestedRepositories: Map ): RepositoryLicenseFindingCurations { val result = mutableMapOf>() - nestedRepositories.forEach { (path, vcs) -> - val pathExcludesForRepository = result.getOrPut(vcs.url) { mutableListOf() } - curations.forEach { curation -> - curation.path.withoutPrefix("$path/")?.let { - pathExcludesForRepository += curation.copy(path = it) + nestedRepositories.forEach { (path, provenance) -> + if (provenance is RepositoryProvenance) { + val pathExcludesForRepository = result.getOrPut(provenance.vcsInfo.url) { mutableListOf() } + curations.forEach { curation -> + curation.path.withoutPrefix("$path/")?.let { + pathExcludesForRepository += curation.copy(path = it) + } } } } @@ -187,15 +196,17 @@ internal fun getLicenseFindingCurationsByRepository( */ internal fun getPathExcludesByRepository( pathExcludes: Collection, - nestedRepositories: Map + nestedRepositories: Map ): RepositoryPathExcludes { val result = mutableMapOf>() - nestedRepositories.forEach { (path, vcs) -> - val pathExcludesForRepository = result.getOrPut(vcs.url) { mutableListOf() } - pathExcludes.forEach { pathExclude -> - pathExclude.pattern.withoutPrefix("$path/")?.let { - pathExcludesForRepository += pathExclude.copy(pattern = it) + nestedRepositories.forEach { (path, provenance) -> + if (provenance is RepositoryProvenance) { + val pathExcludesForRepository = result.getOrPut(provenance.vcsInfo.url) { mutableListOf() } + pathExcludes.forEach { pathExclude -> + pathExclude.pattern.withoutPrefix("$path/")?.let { + pathExcludesForRepository += pathExclude.copy(pattern = it) + } } } } diff --git a/model/src/main/kotlin/OrtResult.kt b/model/src/main/kotlin/OrtResult.kt index 85ccd06d2e3f4..1a4d2ba47c2e7 100644 --- a/model/src/main/kotlin/OrtResult.kt +++ b/model/src/main/kotlin/OrtResult.kt @@ -194,7 +194,9 @@ data class OrtResult( } private val relativeProjectVcsPath: Map by lazy { - getProjects().associateBy({ it.id }, { repository.getRelativePath(it.vcsProcessed) }) + getProjects().associateBy({ it.id }, { + repository.getRelativePath(RepositoryProvenance(it.vcsProcessed, it.vcsProcessed.revision)) + }) } /** @@ -643,7 +645,7 @@ data class OrtResult( fun isProject(id: Identifier): Boolean = getProject(id) != null /** - * Return a copy of this [OrtResult] with the [Repository.config] replaced by [config]. The package curations + * Return a copy of this [OrtResult] with the [config] replaced by [config]. The package curations * within the given config only take effect in case the corresponding feature was enabled during the initial * creation of this [OrtResult]. */ diff --git a/model/src/main/kotlin/Repository.kt b/model/src/main/kotlin/Repository.kt index 1fcf4562b9d77..93110aac6f4b6 100644 --- a/model/src/main/kotlin/Repository.kt +++ b/model/src/main/kotlin/Repository.kt @@ -22,7 +22,6 @@ package org.ossreviewtoolkit.model import com.fasterxml.jackson.annotation.JsonInclude import org.ossreviewtoolkit.model.config.RepositoryConfiguration -import org.ossreviewtoolkit.utils.ort.ORT_REPO_CONFIG_FILENAME /** * A description of the source code repository that was used as input for ORT. @@ -31,20 +30,14 @@ data class Repository( /** * Original VCS-related information from the working tree containing the analyzer root. */ - val vcs: VcsInfo, - - /** - * Processed VCS-related information from the working tree containing the analyzer root that has e.g. common - * mistakes corrected. - */ - val vcsProcessed: VcsInfo = vcs.normalize(), + val provenance: KnownProvenance, /** * A map of nested repositories, for example Git submodules or Git-Repo modules. The key is the path to the * nested repository relative to the root of the main repository. */ @JsonInclude(JsonInclude.Include.NON_EMPTY) - val nestedRepositories: Map = emptyMap(), + val nestedRepositories: Map = emptyMap(), /** * The configuration of the repository, parsed from [ORT_REPO_CONFIG_FILENAME]. @@ -52,27 +45,36 @@ data class Repository( val config: RepositoryConfiguration = RepositoryConfiguration() ) { companion object { + const val DEFAULT_REVISION = "" + /** * A constant for a [Repository] where all properties are empty strings. */ @JvmField val EMPTY = Repository( - vcs = VcsInfo.EMPTY, - vcsProcessed = VcsInfo.EMPTY, + provenance = RepositoryProvenance(VcsInfo.EMPTY, DEFAULT_REVISION), nestedRepositories = emptyMap(), config = RepositoryConfiguration() ) } + fun vcs(): VcsInfo { + if (provenance is RepositoryProvenance) { return provenance.vcsInfo } + return VcsInfo.EMPTY + } + + fun vcsProcessed(): VcsInfo { + if (provenance is RepositoryProvenance) { return provenance.vcsInfo.normalize() } + return VcsInfo.EMPTY + } + /** - * Return the path of [vcs] relative to [Repository.vcs], or null if [vcs] is neither [Repository.vcs] nor contained - * in [nestedRepositories]. + * Return the path of [provenance] relative to [Repository.provenance], or null if [provenance] is neither + * [Repository.provenance] nor contained in [nestedRepositories]. */ - fun getRelativePath(vcs: VcsInfo): String? { - val normalizedVcs = vcs.normalize() - - if (vcsProcessed.matches(normalizedVcs)) return "" + fun getRelativePath(provenance: KnownProvenance): String? { + if (this.provenance.matches(provenance)) return "" - return nestedRepositories.entries.find { (_, nestedVcs) -> nestedVcs.normalize().matches(normalizedVcs) }?.key + return nestedRepositories.entries.find { (_, nestedProvenance) -> nestedProvenance.matches(provenance) }?.key } } diff --git a/model/src/main/kotlin/licenses/DefaultLicenseInfoProvider.kt b/model/src/main/kotlin/licenses/DefaultLicenseInfoProvider.kt index 71a72b9c36aa5..136ecc26d4c27 100644 --- a/model/src/main/kotlin/licenses/DefaultLicenseInfoProvider.kt +++ b/model/src/main/kotlin/licenses/DefaultLicenseInfoProvider.kt @@ -25,6 +25,7 @@ import java.util.concurrent.ConcurrentMap import org.ossreviewtoolkit.model.Identifier import org.ossreviewtoolkit.model.OrtResult import org.ossreviewtoolkit.model.Provenance +import org.ossreviewtoolkit.model.RepositoryProvenance import org.ossreviewtoolkit.model.config.LicenseFindingCuration import org.ossreviewtoolkit.model.config.PathExclude import org.ossreviewtoolkit.model.utils.filterByVcsPath @@ -106,7 +107,9 @@ class DefaultLicenseInfoProvider(val ortResult: OrtResult) : LicenseInfoProvider Configuration( ortResult.repository.config.curations.licenseFindings, ortResult.repository.config.excludes.paths, - ortResult.repository.getRelativePath(project.vcsProcessed).orEmpty() + ortResult.repository.getRelativePath( + RepositoryProvenance(project.vcsProcessed, project.vcsProcessed.revision) + ).orEmpty() ) } ?: ortResult.getPackageConfigurations(id, provenance).let { packageConfigurations -> Configuration( diff --git a/model/src/main/kotlin/licenses/LicenseInfo.kt b/model/src/main/kotlin/licenses/LicenseInfo.kt index 5f5b95bc70c5f..70df30b8eb3e1 100644 --- a/model/src/main/kotlin/licenses/LicenseInfo.kt +++ b/model/src/main/kotlin/licenses/LicenseInfo.kt @@ -24,10 +24,8 @@ import org.ossreviewtoolkit.model.Identifier import org.ossreviewtoolkit.model.LicenseFinding import org.ossreviewtoolkit.model.PackageCurationResult import org.ossreviewtoolkit.model.Provenance -import org.ossreviewtoolkit.model.Repository import org.ossreviewtoolkit.model.config.LicenseFindingCuration import org.ossreviewtoolkit.model.config.PathExclude -import org.ossreviewtoolkit.model.config.RepositoryConfiguration import org.ossreviewtoolkit.utils.ort.ProcessedDeclaredLicense import org.ossreviewtoolkit.utils.spdx.SpdxExpression @@ -140,7 +138,7 @@ data class Findings( * The root path of the locations of the [licenses] and [copyrights] relative to the paths used in the * [licenseFindingCurations] and [pathExcludes]. An empty string, if all refer to the same root path. * - * The roots can be different in case of projects inside nested repositories (see [Repository.nestedRepositories]), + * The roots can be different in case of projects inside nested repositories (see [nestedRepositories]), * where the license and copyright finding locations are relative to the nested repository, but the * [licenseFindingCurations] and [pathExcludes] are relative to the root repository, because they are configured in * the [RepositoryConfiguration] of the root repository. diff --git a/model/src/main/kotlin/utils/OrtResultExtensions.kt b/model/src/main/kotlin/utils/OrtResultExtensions.kt index b167908c90911..68f24dc67adc9 100644 --- a/model/src/main/kotlin/utils/OrtResultExtensions.kt +++ b/model/src/main/kotlin/utils/OrtResultExtensions.kt @@ -85,11 +85,8 @@ fun OrtResult.createLicenseInfoResolver( * Return the path where the repository given by [provenance] is linked into the source tree. */ fun OrtResult.getRepositoryPath(provenance: RepositoryProvenance): String { - repository.nestedRepositories.forEach { (path, vcsInfo) -> - if (vcsInfo.type == provenance.vcsInfo.type - && vcsInfo.url == provenance.vcsInfo.url - && vcsInfo.revision == provenance.resolvedRevision - ) { + repository.nestedRepositories.forEach { (path, nestedProvenance) -> + if (nestedProvenance is RepositoryProvenance && nestedProvenance == provenance) { return "/$path/" } } diff --git a/model/src/test/assets/analyzer-result-with-dependency-graph.yml b/model/src/test/assets/analyzer-result-with-dependency-graph.yml index 15c739d4f11c4..4e834102b83c5 100644 --- a/model/src/test/assets/analyzer-result-with-dependency-graph.yml +++ b/model/src/test/assets/analyzer-result-with-dependency-graph.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "Git" - url: "https://github.com/vdurmont/semver4j.git" - revision: "7653e418d610ffcd2811bcb55fd72d00d420950b" - path: "" - vcs_processed: - type: "Git" - url: "https://github.com/vdurmont/semver4j.git" - revision: "7653e418d610ffcd2811bcb55fd72d00d420950b" - path: "" + provenance: + vcs_info: + type: "Git" + url: "https://github.com/vdurmont/semver4j.git" + revision: "7653e418d610ffcd2811bcb55fd72d00d420950b" + path: "" + resolved_revision: "7653e418d610ffcd2811bcb55fd72d00d420950b" config: {} analyzer: start_time: "2021-04-26T05:48:05.390356Z" diff --git a/model/src/test/assets/gradle-all-dependencies-expected-result.yml b/model/src/test/assets/gradle-all-dependencies-expected-result.yml index 5812c291755e4..e963b68f268c3 100644 --- a/model/src/test/assets/gradle-all-dependencies-expected-result.yml +++ b/model/src/test/assets/gradle-all-dependencies-expected-result.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "Git" - url: "https://github.com/oss-review-toolkit/ort.git" - revision: "d27a886818b8ebba8e97e914133ec3cc650a534b" - path: "analyzer/src/funTest/assets/projects/synthetic/gradle" - vcs_processed: - type: "Git" - url: "https://github.com/oss-review-toolkit/ort.git" - revision: "d27a886818b8ebba8e97e914133ec3cc650a534b" - path: "analyzer/src/funTest/assets/projects/synthetic/gradle" + provenance: + vcs_info: + type: "Git" + url: "https://github.com/oss-review-toolkit/ort.git" + revision: "d27a886818b8ebba8e97e914133ec3cc650a534b" + path: "analyzer/src/funTest/assets/projects/synthetic/gradle" + resolved_revision: "d27a886818b8ebba8e97e914133ec3cc650a534b" config: excludes: paths: diff --git a/model/src/test/assets/result-with-issues-graph-old.yml b/model/src/test/assets/result-with-issues-graph-old.yml index 813f1a184b827..d6a8838443b02 100644 --- a/model/src/test/assets/result-with-issues-graph-old.yml +++ b/model/src/test/assets/result-with-issues-graph-old.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "Git" - url: "https://github.com/pbassiner/sbt-multi-project-example.git" - revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" - path: "" - vcs_processed: - type: "Git" - url: "https://github.com/pbassiner/sbt-multi-project-example.git" - revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" - path: "" + provenance: + vcs_info: + type: "Git" + url: "https://github.com/pbassiner/sbt-multi-project-example.git" + revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" + path: "" + resolved_revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" config: {} analyzer: start_time: "1970-01-01T00:00:00Z" diff --git a/model/src/test/assets/result-with-issues-graph.yml b/model/src/test/assets/result-with-issues-graph.yml index 383a2a8ba0cad..72c30a85caa1b 100644 --- a/model/src/test/assets/result-with-issues-graph.yml +++ b/model/src/test/assets/result-with-issues-graph.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "Git" - url: "https://github.com/pbassiner/sbt-multi-project-example.git" - revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" - path: "" - vcs_processed: - type: "Git" - url: "https://github.com/pbassiner/sbt-multi-project-example.git" - revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" - path: "" + provenance: + vcs_info: + type: "Git" + url: "https://github.com/pbassiner/sbt-multi-project-example.git" + revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" + path: "" + resolved_revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" config: {} analyzer: start_time: "1970-01-01T00:00:00Z" diff --git a/model/src/test/assets/result-with-issues-scopes.yml b/model/src/test/assets/result-with-issues-scopes.yml index e48882fd41e74..79dee3ede4e0d 100644 --- a/model/src/test/assets/result-with-issues-scopes.yml +++ b/model/src/test/assets/result-with-issues-scopes.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "Git" - url: "https://github.com/pbassiner/sbt-multi-project-example.git" - revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" - path: "" - vcs_processed: - type: "Git" - url: "https://github.com/pbassiner/sbt-multi-project-example.git" - revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" - path: "" + provenance: + vcs_info: + type: "Git" + url: "https://github.com/pbassiner/sbt-multi-project-example.git" + revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" + path: "" + resolved_revision: "31687c099ea6d645e819ef9d6ac9fc4c757a96bc" config: {} analyzer: start_time: "1970-01-01T00:00:00Z" diff --git a/model/src/test/assets/sbt-multi-project-example-expected-output.yml b/model/src/test/assets/sbt-multi-project-example-expected-output.yml index 61689dfc575bd..4cc4f7d256c3b 100644 --- a/model/src/test/assets/sbt-multi-project-example-expected-output.yml +++ b/model/src/test/assets/sbt-multi-project-example-expected-output.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "Git" - url: "https://github.com/oss-review-toolkit/sbt-multi-project-example.git" - revision: "3c4e434b241b1f1addc97794932043b86afc2548" - path: "" - vcs_processed: - type: "Git" - url: "https://github.com/oss-review-toolkit/sbt-multi-project-example.git" - revision: "3c4e434b241b1f1addc97794932043b86afc2548" - path: "" + provenance: + vcs_info: + type: "Git" + url: "https://github.com/oss-review-toolkit/sbt-multi-project-example.git" + revision: "3c4e434b241b1f1addc97794932043b86afc2548" + path: "" + resolved_revision: "3c4e434b241b1f1addc97794932043b86afc2548" config: {} analyzer: start_time: "1970-01-01T00:00:00Z" diff --git a/model/src/test/assets/sbt-multi-project-example-graph-old.yml b/model/src/test/assets/sbt-multi-project-example-graph-old.yml index 75faa6da133a5..059d8e2b571bb 100644 --- a/model/src/test/assets/sbt-multi-project-example-graph-old.yml +++ b/model/src/test/assets/sbt-multi-project-example-graph-old.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "Git" - url: "https://github.com/oss-review-toolkit/sbt-multi-project-example.git" - revision: "3c4e434b241b1f1addc97794932043b86afc2548" - path: "" - vcs_processed: - type: "Git" - url: "https://github.com/oss-review-toolkit/sbt-multi-project-example.git" - revision: "3c4e434b241b1f1addc97794932043b86afc2548" - path: "" + provenance: + vcs_info: + type: "Git" + url: "https://github.com/oss-review-toolkit/sbt-multi-project-example.git" + revision: "3c4e434b241b1f1addc97794932043b86afc2548" + path: "" + resolved_revision: "3c4e434b241b1f1addc97794932043b86afc2548" config: {} analyzer: start_time: "1970-01-01T00:00:00Z" diff --git a/model/src/test/assets/sbt-multi-project-example-graph.yml b/model/src/test/assets/sbt-multi-project-example-graph.yml index 53969a4d0d20d..270723cc2ec23 100644 --- a/model/src/test/assets/sbt-multi-project-example-graph.yml +++ b/model/src/test/assets/sbt-multi-project-example-graph.yml @@ -1,15 +1,12 @@ --- repository: - vcs: - type: "Git" - url: "https://github.com/oss-review-toolkit/sbt-multi-project-example.git" - revision: "3c4e434b241b1f1addc97794932043b86afc2548" - path: "" - vcs_processed: - type: "Git" - url: "https://github.com/oss-review-toolkit/sbt-multi-project-example.git" - revision: "3c4e434b241b1f1addc97794932043b86afc2548" - path: "" + provenance: + vcs_info: + type: "Git" + url: "https://github.com/oss-review-toolkit/sbt-multi-project-example.git" + revision: "3c4e434b241b1f1addc97794932043b86afc2548" + path: "" + resolved_revision: "3c4e434b241b1f1addc97794932043b86afc2548" config: {} analyzer: start_time: "1970-01-01T00:00:00Z" diff --git a/model/src/test/kotlin/OrtResultTest.kt b/model/src/test/kotlin/OrtResultTest.kt index a514d4e351908..aba5123b748df 100644 --- a/model/src/test/kotlin/OrtResultTest.kt +++ b/model/src/test/kotlin/OrtResultTest.kt @@ -106,10 +106,10 @@ class OrtResultTest : WordSpec({ ) val ortResult = OrtResult( Repository( - vcs = vcs, + provenance = RepositoryProvenance(vcs, vcs.revision), nestedRepositories = mapOf( - "path/1" to nestedVcs1, - "path/2" to nestedVcs2 + "path/1" to RepositoryProvenance(nestedVcs1, nestedVcs1.revision), + "path/2" to RepositoryProvenance(nestedVcs2, nestedVcs2.revision) ) ), AnalyzerRun.EMPTY.copy( @@ -134,9 +134,9 @@ class OrtResultTest : WordSpec({ ) val ortResult = OrtResult( Repository( - vcs = vcs, + provenance = RepositoryProvenance(vcs, vcs.revision), nestedRepositories = mapOf( - "path/1" to nestedVcs1 + "path/1" to RepositoryProvenance(nestedVcs1, nestedVcs1.revision) ) ), AnalyzerRun.EMPTY.copy( @@ -260,8 +260,7 @@ class OrtResultTest : WordSpec({ val ortResult = OrtResult.EMPTY.copy( repository = Repository.EMPTY.copy( - vcs = vcs, - vcsProcessed = vcs, + provenance = RepositoryProvenance(vcs, vcs.revision), config = RepositoryConfiguration( excludes = Excludes( paths = listOf( diff --git a/model/src/test/kotlin/licenses/TestData.kt b/model/src/test/kotlin/licenses/TestData.kt index ab2f144071a4b..5edd4bdfa5a2f 100644 --- a/model/src/test/kotlin/licenses/TestData.kt +++ b/model/src/test/kotlin/licenses/TestData.kt @@ -27,6 +27,7 @@ import org.ossreviewtoolkit.model.OrtResult import org.ossreviewtoolkit.model.Package import org.ossreviewtoolkit.model.Project import org.ossreviewtoolkit.model.Repository +import org.ossreviewtoolkit.model.RepositoryProvenance import org.ossreviewtoolkit.model.ScanResult import org.ossreviewtoolkit.model.ScanSummary import org.ossreviewtoolkit.model.ScannerDetails @@ -151,7 +152,7 @@ val scanResults = listOf( val ortResult = OrtResult( repository = Repository( - vcs = VcsInfo.EMPTY, + provenance = RepositoryProvenance(VcsInfo.EMPTY, ""), config = RepositoryConfiguration( excludes = Excludes( paths = listOf( diff --git a/plugins/reporters/cyclonedx/src/main/kotlin/CycloneDxReporter.kt b/plugins/reporters/cyclonedx/src/main/kotlin/CycloneDxReporter.kt index 575262be12551..c98d7332bf601 100644 --- a/plugins/reporters/cyclonedx/src/main/kotlin/CycloneDxReporter.kt +++ b/plugins/reporters/cyclonedx/src/main/kotlin/CycloneDxReporter.kt @@ -186,7 +186,7 @@ class CycloneDxReporter : Reporter { // distributable), just create a single BOM for all projects in that case for now. As there also is no // single correct project to pick for adding external references in that case, simply only use the global // repository VCS information here. - val vcs = input.ortResult.repository.vcsProcessed + val vcs = input.ortResult.repository.vcsProcessed() bom.addExternalReference( ExternalReference.Type.VCS, vcs.url, diff --git a/plugins/reporters/evaluated-model/src/main/kotlin/EvaluatedModelMapper.kt b/plugins/reporters/evaluated-model/src/main/kotlin/EvaluatedModelMapper.kt index e0f4843811e8b..495ac15725282 100644 --- a/plugins/reporters/evaluated-model/src/main/kotlin/EvaluatedModelMapper.kt +++ b/plugins/reporters/evaluated-model/src/main/kotlin/EvaluatedModelMapper.kt @@ -30,17 +30,13 @@ import org.ossreviewtoolkit.model.Project import org.ossreviewtoolkit.model.Provenance import org.ossreviewtoolkit.model.RemoteArtifact import org.ossreviewtoolkit.model.Repository -import org.ossreviewtoolkit.model.ResolvedConfiguration import org.ossreviewtoolkit.model.RuleViolation import org.ossreviewtoolkit.model.ScanResult import org.ossreviewtoolkit.model.TextLocation import org.ossreviewtoolkit.model.VcsInfo -import org.ossreviewtoolkit.model.config.Excludes import org.ossreviewtoolkit.model.config.IssueResolution import org.ossreviewtoolkit.model.config.LicenseFindingCuration import org.ossreviewtoolkit.model.config.PathExclude -import org.ossreviewtoolkit.model.config.RepositoryConfiguration -import org.ossreviewtoolkit.model.config.Resolutions import org.ossreviewtoolkit.model.config.RuleViolationResolution import org.ossreviewtoolkit.model.config.ScopeExclude import org.ossreviewtoolkit.model.config.VulnerabilityResolution diff --git a/plugins/reporters/fossid/src/test/kotlin/FossIdReporterTest.kt b/plugins/reporters/fossid/src/test/kotlin/FossIdReporterTest.kt index 99daf6e814e73..c4c322f8c0a64 100644 --- a/plugins/reporters/fossid/src/test/kotlin/FossIdReporterTest.kt +++ b/plugins/reporters/fossid/src/test/kotlin/FossIdReporterTest.kt @@ -299,6 +299,7 @@ private fun createReporterInput(vararg scanCodes: String): ReporterInput { return ReporterInput( OrtResult( repository = Repository( + provenance = analyzedVcs, config = RepositoryConfiguration( excludes = Excludes( scopes = listOf( @@ -309,9 +310,7 @@ private fun createReporterInput(vararg scanCodes: String): ReporterInput { ) ) ) - ), - vcs = analyzedVcs, - vcsProcessed = analyzedVcs + ) ), scanner = scannerRunOf(*results.toList().toTypedArray()) ) diff --git a/plugins/reporters/freemarker/src/test/kotlin/FreeMarkerTemplateProcessorTest.kt b/plugins/reporters/freemarker/src/test/kotlin/FreeMarkerTemplateProcessorTest.kt index ec1b097ff68cf..1311d7bdbaf77 100644 --- a/plugins/reporters/freemarker/src/test/kotlin/FreeMarkerTemplateProcessorTest.kt +++ b/plugins/reporters/freemarker/src/test/kotlin/FreeMarkerTemplateProcessorTest.kt @@ -108,8 +108,7 @@ private val idNestedProject = Identifier("SpdxDocumentFile:@ort:project-in-neste private val ORT_RESULT = OrtResult( repository = Repository( - vcs = PROJECT_VCS_INFO, - config = RepositoryConfiguration(), + provenance = PROJECT_VCS_INFO, nestedRepositories = mapOf("nested-vcs-dir" to NESTED_VCS_INFO) ), analyzer = AnalyzerRun.EMPTY.copy( diff --git a/plugins/reporters/opossum/src/main/kotlin/OpossumReporter.kt b/plugins/reporters/opossum/src/main/kotlin/OpossumReporter.kt index a89dfc699f5ca..d3b1521827e79 100644 --- a/plugins/reporters/opossum/src/main/kotlin/OpossumReporter.kt +++ b/plugins/reporters/opossum/src/main/kotlin/OpossumReporter.kt @@ -499,7 +499,7 @@ class OpossumReporter : Reporter { internal fun generateOpossumInput(input: ReporterInput, maxDepth: Int = Int.MAX_VALUE): OpossumInput { val opossumInput = OpossumInput() - opossumInput.addBaseUrl("/", input.ortResult.repository.vcs) + opossumInput.addBaseUrl("/", input.ortResult.repository.vcs()) SpdxLicense.entries.forEach { val licenseText = input.licenseTextProvider.getLicenseText(it.id) diff --git a/plugins/reporters/opossum/src/test/kotlin/OpossumReporterTest.kt b/plugins/reporters/opossum/src/test/kotlin/OpossumReporterTest.kt index 2ef18843f3596..4cdff4673bda9 100644 --- a/plugins/reporters/opossum/src/test/kotlin/OpossumReporterTest.kt +++ b/plugins/reporters/opossum/src/test/kotlin/OpossumReporterTest.kt @@ -254,8 +254,7 @@ private fun createOrtResult(): OrtResult { return OrtResult( repository = Repository( - vcs = analyzedVcs, - vcsProcessed = analyzedVcs + provenance = analyzedVcs ), analyzer = AnalyzerRun.EMPTY.copy( config = AnalyzerConfiguration(allowDynamicVersions = true), diff --git a/plugins/reporters/spdx/src/funTest/kotlin/SpdxDocumentReporterFunTest.kt b/plugins/reporters/spdx/src/funTest/kotlin/SpdxDocumentReporterFunTest.kt index 7de4ab07a5287..9fdd0274abca4 100644 --- a/plugins/reporters/spdx/src/funTest/kotlin/SpdxDocumentReporterFunTest.kt +++ b/plugins/reporters/spdx/src/funTest/kotlin/SpdxDocumentReporterFunTest.kt @@ -160,6 +160,7 @@ private val analyzedVcs = VcsInfo( private val ortResult = OrtResult( repository = Repository( + provenance = analyzedVcs, config = RepositoryConfiguration( excludes = Excludes( scopes = listOf( @@ -170,9 +171,7 @@ private val ortResult = OrtResult( ) ) ) - ), - vcs = analyzedVcs, - vcsProcessed = analyzedVcs + ) ), analyzer = AnalyzerRun.EMPTY.copy( result = AnalyzerResult( diff --git a/plugins/reporters/static-html/src/main/kotlin/TablesReportModelMapper.kt b/plugins/reporters/static-html/src/main/kotlin/TablesReportModelMapper.kt index bcb13dc0c0b7a..da98cdb496203 100644 --- a/plugins/reporters/static-html/src/main/kotlin/TablesReportModelMapper.kt +++ b/plugins/reporters/static-html/src/main/kotlin/TablesReportModelMapper.kt @@ -48,7 +48,7 @@ internal object TablesReportModelMapper { .sortedBy { it.id } return TablesReport( - input.ortResult.repository.vcsProcessed, + input.ortResult.repository.vcsProcessed(), input.ortResult.repository.config, ruleViolations, getAnalyzerIssueSummaryTable(input), diff --git a/reporter/src/main/kotlin/StatisticsCalculator.kt b/reporter/src/main/kotlin/StatisticsCalculator.kt index 700d08f39c24b..b37efc9cf0c29 100644 --- a/reporter/src/main/kotlin/StatisticsCalculator.kt +++ b/reporter/src/main/kotlin/StatisticsCalculator.kt @@ -27,9 +27,7 @@ import kotlin.time.toKotlinDuration import org.ossreviewtoolkit.model.Identifier import org.ossreviewtoolkit.model.OrtResult import org.ossreviewtoolkit.model.Severity -import org.ossreviewtoolkit.model.config.IssueResolution import org.ossreviewtoolkit.model.config.OrtConfiguration -import org.ossreviewtoolkit.model.config.RuleViolationResolution import org.ossreviewtoolkit.model.licenses.LicenseInfoResolver import org.ossreviewtoolkit.model.licenses.LicenseView import org.ossreviewtoolkit.model.licenses.ResolvedLicenseInfo diff --git a/reporter/src/testFixtures/kotlin/TestData.kt b/reporter/src/testFixtures/kotlin/TestData.kt index 52fea88318446..34c91bff2b0ff 100644 --- a/reporter/src/testFixtures/kotlin/TestData.kt +++ b/reporter/src/testFixtures/kotlin/TestData.kt @@ -42,6 +42,7 @@ import org.ossreviewtoolkit.model.PackageReference import org.ossreviewtoolkit.model.Project import org.ossreviewtoolkit.model.RemoteArtifact import org.ossreviewtoolkit.model.Repository +import org.ossreviewtoolkit.model.RepositoryProvenance import org.ossreviewtoolkit.model.ScanResult import org.ossreviewtoolkit.model.ScanSummary import org.ossreviewtoolkit.model.ScannerDetails @@ -66,7 +67,7 @@ import org.ossreviewtoolkit.utils.test.scannerRunOf // TODO: Create a way to reduce the code required to prepare an OrtResult for testing. val ORT_RESULT = OrtResult( repository = Repository( - vcs = VcsInfo.EMPTY, + provenance = RepositoryProvenance(VcsInfo.EMPTY, ""), config = RepositoryConfiguration( excludes = Excludes( paths = listOf(