From c198d5ffe9434dda2087ec2c5a9edc61e5118f28 Mon Sep 17 00:00:00 2001 From: Freddy Kristiansen Date: Tue, 24 Sep 2024 15:13:13 +0200 Subject: [PATCH] DeliverToAppSource bug found in end 2 end (#1219) Continuous Delivery To AppSource no longer worked Co-authored-by: freddydk --- .../DetermineDeliveryTargets.ps1 | 22 +++++++++++-------- 1 file changed, 13 insertions(+), 9 deletions(-) diff --git a/Actions/DetermineDeliveryTargets/DetermineDeliveryTargets.ps1 b/Actions/DetermineDeliveryTargets/DetermineDeliveryTargets.ps1 index affdc79af..628e59dfa 100644 --- a/Actions/DetermineDeliveryTargets/DetermineDeliveryTargets.ps1 +++ b/Actions/DetermineDeliveryTargets/DetermineDeliveryTargets.ps1 @@ -7,7 +7,18 @@ function ContinuousDelivery([string] $deliveryTarget) { $settingsName = "DeliverTo$deliveryTarget" - if ($settings.Contains($settingsName) -and $settings."$settingsName".Contains('ContinuousDelivery')) { + if ($deliveryTarget -eq 'AppSource' -and $settings.type -eq "AppSource App") { + # For multi-project repositories, ContinuousDelivery can be set on the projects + foreach($project in ($projectsJson | ConvertFrom-Json)) { + $projectSettings = ReadSettings -project $project + if ($projectSettings.deliverToAppSource.ContinuousDelivery -or ($projectSettings.Contains('AppSourceContinuousDelivery') -and $projectSettings.AppSourceContinuousDelivery)) { + Write-Host "Project $project is setup for Continuous Delivery to AppSource" + return $true + } + } + return $false + } + elseif ($settings.Contains($settingsName) -and $settings."$settingsName".Contains('ContinuousDelivery')) { return $settings."$settingsName".ContinuousDelivery } else { @@ -44,14 +55,7 @@ function IncludeDeliveryTarget([string] $deliveryTarget) { $settings = $env:Settings | ConvertFrom-Json | ConvertTo-HashTable -recurse $deliveryTargets = @('GitHubPackages','NuGet','Storage') if ($settings.type -eq "AppSource App") { - # For multi-project repositories, we will add deliveryTarget AppSource if any project has AppSourceContinuousDelivery set to true - ($projectsJson | ConvertFrom-Json) | ForEach-Object { - $projectSettings = ReadSettings -project $_ - if ($projectSettings.deliverToAppSource.ContinuousDelivery -or ($projectSettings.Contains('AppSourceContinuousDelivery') -and $projectSettings.AppSourceContinuousDelivery)) { - Write-Host "Project $_ is setup for Continuous Delivery to AppSource" - $deliveryTargets += @("AppSource") - } - } + $deliveryTargets += @("AppSource") } # Include custom delivery targets $namePrefix = 'DeliverTo'