functions/Set-ModuleAsPreRelease.ps1
<#
.SYNOPSIS Determines if a module should be marked as PreRelease based on the value of $branch .DESCRIPTION Set-ModuleAsPreRelease determines if a module should be marked as PreRelease. This is determined by doing a case insensitive comparison of $branch to $ReleaseBranch (which defaults to master) .EXAMPLE Example of usage from TFS Set-ModuleAsPreRelease.ps1 -PreReleaseTag "dev$(Build.BuildId)" -ManifestFilePath "$(Build.SourcesDirectory)\$(ModuleName)\$(ModuleName).psd1" -Branch $(Build.SourceBranchName) .PARAMETER ManifestFilePath string path to the modules psd1 to be marked as PreRelease .PARAMETER PreReleaseTag string to be added to end of module name marking it as PreRelease. - is added automatically. Example PreReleaseTag dev$(Build.BuildId) .PARAMETER Branch name of branch being built. When called from TFS, the value passed in will probably be $(Build.SourceBranchName) .PARAMETER ReleaseBranch name of branch module is released from, PreRelease does not need to be set when building from this branch. Default value is master #> function Set-ModuleAsPreRelease { [CmdletBinding()] param( [Parameter(Mandatory)] [String] $PreReleaseTag, [Parameter(Mandatory)] [String] $ManifestFilePath, [Parameter(Mandatory)] [String] $Branch, $ReleaseBranch = @("Master","Main") ) begin {} process { if ($ReleaseBranch -contains $Branch) { Write-Host "Branch $Branch for build is the same as the ReleaseBranch $ReleaseBranch. Module NOT marked as PreRelease" } else { $tag = $PreReleaseTag.Trim("-") Update-ModuleManifest -Path $ManifestFilePath -PreRelease $tag -Verbose Write-Host "Branch $Branch for build is different to ReleaseBranch $ReleaseBranch. Module marked as PreRelease $tag" } } end {} } |