Public/Get-DeploymentPreview.ps1
function Get-DeploymentPreview { <# .SYNOPSIS Returns a preview of what would be executed if the deployment would be invoked .DESCRIPTION Returns a preview of what would be executed if the deployment would be invoked. Currently only tenanted deployments are supported .EXAMPLE PS C:\> Get-DeploymentPreview -Release (Get-Release -Project 'Microsoft Dot Net Framework' -latest) -tenant XXROM001 -Environment Development Returns what step would be executed on which targets #> [CmdletBinding(SupportsShouldProcess = $false, ConfirmImpact = 'High')] param ( # property help [Parameter(Mandatory = $true, ValueFromPipeline = $true)] [Octopus.Client.Model.ReleaseResource] $Release, # property help [Parameter(Mandatory = $false)] [TenantSingleTransformation()] [Octopus.Client.Model.TenantResource] $Tenant, # property help [Parameter(Mandatory = $true)] [EnvironmentSingleTransformation()] [Octopus.Client.Model.EnvironmentResource] $Environment #[Switch] $PerTarget # has to be implemented by retrieving all targets in preview an then creating single runs for each target ) begin { try { ValidateConnection } catch { $PSCmdlet.ThrowTerminatingError($_) } } process { $project = Get-Project -ID $release.ProjectId $releaseTemplate = $repo._repository.Releases.GetTemplate($release); # ToDo: implement untenanted deployments and preview. The current code will only work with tenanted deployments #$promotion = $releaseTemplate.PromoteTo | Where ID -eq $environment.Id # check if tenant, project environment combination is valid if (! ($Tenant.ProjectEnvironments[$Project.id] -contains $Environment.Id)) { $message = "'{0}' is not connected to '{1}' in '{2}'" -f $Tenant.name, $Project.name, $Environment.name Throw $message } # tenanted deployment preview $promotion = ($releaseTemplate.TenantPromotions | Where-Object id -EQ $tenant.id).PromoteTo | Where-Object ID -EQ $environment.Id try { $preview = $repo._repository.Releases.GetPreview($promotion) } catch { Throw "Can't preview deployment. Are you sure the combination of parameters are right?" } # Go through all steps and return involved machines foreach ($step in $preview.StepsToExecute) { [PSCustomObject]@{ ActionNumber = $step.actionnumber ActionName = $step.actionname ActionID = $step.actionid Machine = @($step.Machines.name | Where-Object { $_ -notin $step.UnavailableMachines.name }) -join ", " UnavailableMachine = @($step.UnavailableMachines.name) -join ", " } } } end {} } |