From 3d2a03ca22c63c7ce9f3a690a46a4213c04808d9 Mon Sep 17 00:00:00 2001 From: Damien Coraboeuf Date: Sat, 7 Dec 2024 08:31:48 +0100 Subject: [PATCH 1/3] #1365 Fixing some issues in the stability chart --- ontrack-web-core/components/charts/CountChart.js | 14 ++++++++------ .../components/charts/PercentageChart.js | 4 +++- 2 files changed, 11 insertions(+), 7 deletions(-) diff --git a/ontrack-web-core/components/charts/CountChart.js b/ontrack-web-core/components/charts/CountChart.js index 79f194488e..bf2737a60f 100644 --- a/ontrack-web-core/components/charts/CountChart.js +++ b/ontrack-web-core/components/charts/CountChart.js @@ -3,7 +3,13 @@ import {useEffect, useState} from "react"; import {Bar, CartesianGrid, ComposedChart, Legend, Tooltip, XAxis, YAxis} from "recharts"; import ChartContainer from "@components/charts/ChartContainer"; -export default function CountChart({query, variables, yTickFormatter}) { +export default function CountChart({ + query, + variables, + yTickFormatter, + legendFormatter = () => "Count ", + domain, + }) { const client = useGraphQLClient() @@ -40,10 +46,6 @@ export default function CountChart({query, variables, yTickFormatter}) { } }, [client, query, variables]); - const legendFormatter = (value, entry, index) => { - return "Count" - } - const [inactiveSeries, setInactiveSeries] = useState([]) const legendClick = ({dataKey}) => { @@ -62,7 +64,7 @@ export default function CountChart({query, variables, yTickFormatter}) { > - + diff --git a/ontrack-web-core/components/charts/PercentageChart.js b/ontrack-web-core/components/charts/PercentageChart.js index 24c829a2be..32374dcca3 100644 --- a/ontrack-web-core/components/charts/PercentageChart.js +++ b/ontrack-web-core/components/charts/PercentageChart.js @@ -8,7 +8,9 @@ export default function PercentageChart({query, variables}) { "%"} + domain={[0, 100]} /> ) From e75c1ff35f1096247df0a07b8c8cb107630c197c Mon Sep 17 00:00:00 2001 From: Damien Coraboeuf Date: Sat, 7 Dec 2024 08:32:55 +0100 Subject: [PATCH 2/3] #1364 Auto-versioning problem when updating same file --- .../AutoVersioningProcessingServiceImpl.kt | 42 ++++++++++---- .../av/ACCAutoVersioningMultiplePaths.kt | 56 +++++++++++++++++++ 2 files changed, 86 insertions(+), 12 deletions(-) diff --git a/ontrack-extension-auto-versioning/src/main/java/net/nemerosa/ontrack/extension/av/processing/AutoVersioningProcessingServiceImpl.kt b/ontrack-extension-auto-versioning/src/main/java/net/nemerosa/ontrack/extension/av/processing/AutoVersioningProcessingServiceImpl.kt index 21a076a2e4..c58ca847e1 100644 --- a/ontrack-extension-auto-versioning/src/main/java/net/nemerosa/ontrack/extension/av/processing/AutoVersioningProcessingServiceImpl.kt +++ b/ontrack-extension-auto-versioning/src/main/java/net/nemerosa/ontrack/extension/av/processing/AutoVersioningProcessingServiceImpl.kt @@ -96,6 +96,8 @@ class AutoVersioningProcessingServiceImpl( } // Map of current versions per path val currentVersions = mutableMapOf() + // Caching the updated content of each path + val updatedContent = mutableMapOf>() // For each target path val targetPathUpdated: List = try { order.allPaths.flatMap { configPath -> @@ -118,10 +120,12 @@ class AutoVersioningProcessingServiceImpl( } configPath.paths.map { targetPath -> // Gets the content of the target file - val lines = scm.download(scmBranch, targetPath, retryOnNotFound = true) - ?.toString(Charsets.UTF_8) - ?.lines() - ?: throw AutoVersioningNoContentException(scmBranch, targetPath) + val lines = updatedContent.getOrPut(targetPath) { + scm.download(scmBranch, targetPath, retryOnNotFound = true) + ?.toString(Charsets.UTF_8) + ?.lines() + ?: throw AutoVersioningNoContentException(scmBranch, targetPath) + } // Gets the current version in this file val currentVersion: String = autoVersioningTargetFileService.readVersion(configPath, lines) ?: throw AutoVersioningVersionNotFoundException(targetPath) @@ -133,14 +137,8 @@ class AutoVersioningProcessingServiceImpl( val updatedLines = configPath.replaceVersion(lines, targetVersion) // Audit autoVersioningAuditService.onProcessingUpdatingFile(order, upgradeBranch, targetPath) - // Uploads of the file content - scm.uploadLines( - upgradeBranch, - commitId, - targetPath, - updatedLines, - message = order.getCommitMessage() - ) + // Updating the cache + updatedContent[targetPath] = updatedLines // Changed true } else { @@ -160,6 +158,26 @@ class AutoVersioningProcessingServiceImpl( // At least one path was changed if (targetPathUpdated.any { it }) { + // Uploading the file contents + try { + updatedContent.forEach { (targetPath, updatedLines) -> + scm.uploadLines( + upgradeBranch, + commitId, + targetPath, + updatedLines, + message = order.getCommitMessage() + ) + } + } catch (e: Exception) { + autoVersioningEventService.sendError( + order, + e.message?.takeIf { it.isNotBlank() } ?: "Issue while uploading the change", + e + ) + throw e + } + // Templating renderer val avRenderer = autoVersioningTemplatingService.createAutoVersioningTemplateRenderer( order = order, diff --git a/ontrack-kdsl-acceptance/src/test/java/net/nemerosa/ontrack/kdsl/acceptance/tests/av/ACCAutoVersioningMultiplePaths.kt b/ontrack-kdsl-acceptance/src/test/java/net/nemerosa/ontrack/kdsl/acceptance/tests/av/ACCAutoVersioningMultiplePaths.kt index 82a7190f06..3183b02545 100644 --- a/ontrack-kdsl-acceptance/src/test/java/net/nemerosa/ontrack/kdsl/acceptance/tests/av/ACCAutoVersioningMultiplePaths.kt +++ b/ontrack-kdsl-acceptance/src/test/java/net/nemerosa/ontrack/kdsl/acceptance/tests/av/ACCAutoVersioningMultiplePaths.kt @@ -73,6 +73,62 @@ class ACCAutoVersioningMultiplePaths : AbstractACCAutoVersioningTestSupport() { } } + @Test + fun `Auto versioning with additional paths using the same path`() { + withMockScmRepository(ontrack) { + withAutoVersioning { + repositoryFile("gradle.properties") { + """ + one-version = 1.0.0 + another-version = 1.0.0 + """.trimIndent() + } + val dependency = branchWithPromotion(promotion = "IRON") + project { + branch { + configuredForMockRepository() + setAutoVersioningConfig( + listOf( + AutoVersioningSourceConfig( + sourceProject = dependency.project.name, + sourceBranch = dependency.name, + sourcePromotion = "IRON", + targetPath = "gradle.properties", + targetProperty = "one-version", + additionalPaths = listOf( + AutoVersioningSourceConfigPath( + path = "gradle.properties", + property = "another-version", + ) + ) + ) + ) + ) + + dependency.apply { + build(name = "2.0.0") { + setMetaInfoProperty("toml", "2.0.0-toml") + promote("IRON") + } + } + + waitForAutoVersioningCompletion() + + assertThatMockScmRepository { + fileContains("gradle.properties") { + """ + one-version = 2.0.0 + another-version = 2.0.0 + """.trimIndent() + } + } + + } + } + } + } + } + @Test fun `Auto versioning on multiple paths`() { withMockScmRepository(ontrack) { From 1a4c0c400981401d40abfd6d9dad3a0b209414ab Mon Sep 17 00:00:00 2001 From: Damien Coraboeuf Date: Sat, 7 Dec 2024 08:38:37 +0100 Subject: [PATCH 3/3] #1362 Disable the OK button when starting a promotion --- ontrack-web-core/components/form/FormDialog.js | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/ontrack-web-core/components/form/FormDialog.js b/ontrack-web-core/components/form/FormDialog.js index 5cd03e0bbb..238e89d41a 100644 --- a/ontrack-web-core/components/form/FormDialog.js +++ b/ontrack-web-core/components/form/FormDialog.js @@ -142,7 +142,7 @@ export default function FormDialog({dialog, onValuesChange, children, hasOk = tr { hasOk && - }