Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Publish symbols for Microsoft.PowerShell.PSResourceGet package #1421

Closed
wants to merge 27 commits into from
Closed
Show file tree
Hide file tree
Changes from 25 commits
Commits
Show all changes
27 commits
Select commit Hold shift + click to select a range
bef1f09
add stage to publish symbols to symbol server
anamnavi Sep 19, 2023
21e2ba1
add newline
anamnavi Sep 19, 2023
2443cf5
add logging command to upload pdb file
anamnavi Sep 20, 2023
df55b07
reference symbol file name
anamnavi Sep 24, 2023
53784f6
remove code from ci_release
anamnavi Sep 24, 2023
981801c
use Microsoft.Powershell.PSResourceGet in CI as we released a new Pow…
anamnavi Sep 24, 2023
fa6fd10
debug test.yml
anamnavi Sep 24, 2023
f774aec
debug config name
anamnavi Sep 24, 2023
af62a22
check what local repo contains
anamnavi Sep 24, 2023
4999fd4
add recurse
anamnavi Sep 24, 2023
7822717
perform find
anamnavi Sep 24, 2023
36a95ba
add prerelease param
anamnavi Sep 24, 2023
b463dad
add verbose statements
anamnavi Sep 25, 2023
e644b63
PackagePath is a URI
anamnavi Sep 25, 2023
9f9dfce
rmeove verbose statements
anamnavi Sep 25, 2023
bd46ade
add verbose to find
anamnavi Sep 25, 2023
f4dd62e
add verbose to find
anamnavi Sep 25, 2023
3a583e9
add debug and try nupkg folder
anamnavi Sep 25, 2023
4a3d9a5
specify nupkg folder in repo URI
anamnavi Sep 25, 2023
5e331ef
remove find code
anamnavi Sep 25, 2023
d1687f1
add TrustRepository
anamnavi Sep 25, 2023
c2f24b0
add code to upload pdb
anamnavi Sep 25, 2023
6dfb572
update ADO error code
anamnavi Sep 25, 2023
080907f
fix publish symbols job
anamnavi Sep 25, 2023
c14f33b
fix publish symbols job
anamnavi Sep 25, 2023
4cd325c
Merge branch 'master' of https://github.com/anamnavi/PowerShellGet in…
anamnavi Sep 26, 2023
2c37f42
remove ToString() call
anamnavi Sep 26, 2023
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
4 changes: 2 additions & 2 deletions .ci/ci.yml
Original file line number Diff line number Diff line change
Expand Up @@ -51,8 +51,8 @@ stages:
- pwsh: |
$modulePath = Join-Path -Path $env:AGENT_TEMPDIRECTORY -ChildPath 'TempModules'
Write-Verbose -Verbose "Install PSResourceGet to temp module path"
Save-Module -Name PowerShellGet -MinimumVersion 3.0.18-beta18 -Path $modulePath -AllowPrerelease -Force
displayName: Install PowerShellGet v3
Save-Module -Name Microsoft.PowerShell.PSResourceGet -MinimumVersion 0.9.0-rc1 -Path $modulePath -AllowPrerelease -Force
displayName: Install Microsoft.PowerShell.PSResourceGet v3
anamnavi marked this conversation as resolved.
Show resolved Hide resolved

- pwsh: |
Get-ChildItem -Path $(Build.SourcesDirectory)/src/code -Recurse
Expand Down
4 changes: 2 additions & 2 deletions .ci/ci_auto.yml
Original file line number Diff line number Diff line change
Expand Up @@ -59,8 +59,8 @@ stages:
- pwsh: |
$modulePath = Join-Path -Path $env:AGENT_TEMPDIRECTORY -ChildPath 'TempModules'
Write-Verbose -Verbose "Install PSResourceGet to temp module path"
Save-Module -Name PowerShellGet -MinimumVersion 3.0.18-beta18 -Path $modulePath -AllowPrerelease -Force
displayName: Install PowerShellGet v3
Save-Module -Name Microsoft.PowerShell.PSResourceGet -MinimumVersion 0.9.0-rc1 -Path $modulePath -AllowPrerelease -Force
displayName: Install Microsoft.PowerShell.PSResourceGet v3

- pwsh: |
$modulePath = Join-Path -Path $env:AGENT_TEMPDIRECTORY -ChildPath 'TempModules'
Expand Down
16 changes: 14 additions & 2 deletions .ci/ci_release.yml
Original file line number Diff line number Diff line change
Expand Up @@ -49,8 +49,8 @@ stages:
- pwsh: |
$modulePath = Join-Path -Path $env:AGENT_TEMPDIRECTORY -ChildPath 'TempModules'
Write-Verbose -Verbose "Install PSResourceGet to temp module path"
Save-Module -Name PowerShellGet -MinimumVersion 3.0.18-beta18 -Path $modulePath -AllowPrerelease -Force
displayName: Install PowerShellGet v3
Save-Module -Name Microsoft.PowerShell.PSResourceGet -MinimumVersion 0.9.0-rc1 -Path $modulePath -AllowPrerelease -Force
displayName: Install Microsoft.PowerShell.PSResourceGet v3

- pwsh: |
$modulePath = Join-Path -Path $env:AGENT_TEMPDIRECTORY -ChildPath 'TempModules'
Expand Down Expand Up @@ -235,6 +235,12 @@ stages:
$vstsCommandString = "vso[task.setvariable variable=signOutPathCreated]${signOutPath}"
Write-Host "sending " + $vstsCommandString
Write-Host "##$vstsCommandString"

# Upload symbol pdb file
$moduleName = "$($config.ModuleName)"
$symbolFileName = "$moduleName.pdb"
$symbolFilePath = Join-Path -Path $srcPath -ChildPath $symbolFileName
Write-Host "##vso[artifact.upload containerfolder=$moduleName;artifactname=$symbolFileName]$symbolFilePath"
displayName: Set up for module created files code signing
condition: and(and(succeeded(), eq(variables['Build.Reason'], 'Manual')), ne(variables['SkipSigning'], 'True'))

Expand Down Expand Up @@ -407,6 +413,12 @@ stages:
displayName: PowerShell Core on macOS
imageName: macOS-latest

- stage: PublishSymbols
displayName: Publish Symbols
condition: and(and(succeeded(), eq(variables['Build.Reason'], 'Manual')), eq(variables['Publish'], 'True'))
jobs:
- template: publishsymbols.yml

- stage: Release
displayName: Publish Package to PSGallery
condition: and(and(succeeded(), eq(variables['Build.Reason'], 'Manual')), eq(variables['Publish'], 'True'))
Expand Down
39 changes: 39 additions & 0 deletions .ci/publishsymbols.yml
Original file line number Diff line number Diff line change
@@ -0,0 +1,39 @@
parameters:
jobName1: publish_symbols_job
displayValidationJob1: 'Publish symbol to Microsoft symbol server'

jobs:
- job: ${{ parameters.jobName1 }}
displayName: ${{ parameters.displayValidationJob1 }}
pool:
name: 1ES
demands:
- ImageOverride -equals PSMMS2019-Secure
timeoutInMinutes: 2880 # job times out in 2 days
steps:
- task: DownloadPipelineArtifact@2
displayName: 'Download and publish symbols'
inputs:
artifact: $(Pipeline.Workspace)\Microsoft.PowerShell.PSResourceGet\Microsoft.PowerShell.PSResourceGet.pdb
path: '$(Pipeline.Workspace)\Microsoft.PowerShell.PSResourceGet'

- pwsh: |
Write-Verbose -Verbose "Enumerating $(Pipeline.Workspace)\Microsoft.PowerShell.PSResourceGet"
$symbolsRoot = New-Item -Path "$(Pipeline.Workspace)/symbols" -ItemType Directory -Verbose
Copy-Item -Path "$(Pipeline.Workspace)\Microsoft.PowerShell.PSResourceGet\Microsoft.PowerShell.PSResourceGet.pdb" -Destination $symbolsRoot

Write-Verbose -Verbose "Enumerating $symbolsRoot"
Get-ChildItem -Path $symbolsRoot -Recurse
$vstsCommandString = "vso[task.setvariable variable=SymbolsPath]$symbolsRoot"
Write-Verbose -Message "$vstsCommandString" -Verbose
Write-Host -Object "##$vstsCommandString"
displayName: Copy symbol file

- task: PublishSymbols@2
inputs:
symbolsFolder: '$(SymbolsPath)'
searchPattern: '*.pdb'
indexSources: false
publishSymbols: true
symbolServerType: teamServices
detailedLog: true
13 changes: 8 additions & 5 deletions .ci/test.yml
Original file line number Diff line number Diff line change
Expand Up @@ -37,28 +37,31 @@ jobs:

- ${{ parameters.powershellExecutable }}: |
$modulePath = Join-Path -Path $env:AGENT_TEMPDIRECTORY -ChildPath 'TempModules'
Write-Verbose -Verbose "Install PSResourceGet to temp module path"
Save-Module -Name PowerShellGet -MinimumVersion 3.0.18-beta18 -Path $modulePath -AllowPrerelease -Force
Write-Verbose -Verbose "Install Microsoft.PowerShell.PSResourceGet to temp module path"
Save-Module -Name Microsoft.PowerShell.PSResourceGet -MinimumVersion 0.9.0-rc1 -Path $modulePath -AllowPrerelease -Force
Write-Verbose -Verbose "Install Pester 4.X to temp module path"
Save-Module -Name "Pester" -MaximumVersion 4.99 -Path $modulePath -Force
displayName: Install PowerShellGetV3 and Pester
displayName: Install Microsoft.PowerShell.PSResourceGet and Pester

- ${{ parameters.powershellExecutable }}: |
$modulePath = Join-Path -Path $env:AGENT_TEMPDIRECTORY -ChildPath 'TempModules'
$env:PSModulePath = $modulePath + [System.IO.Path]::PathSeparator + $env:PSModulePath
Write-Verbose -Verbose "Importing build utilities (buildtools.psd1)"
Import-Module -Name (Join-Path -Path '${{ parameters.buildDirectory }}' -ChildPath 'buildtools.psd1') -Force
#
Install-ModulePackageForTest -PackagePath "$(System.ArtifactsDirectory)"
Install-ModulePackageForTest -PackagePath "$(System.ArtifactsDirectory)".ToString()
displayName: Install module for test from downloaded artifact
workingDirectory: ${{ parameters.buildDirectory }}

- ${{ parameters.powershellExecutable }}: |
$modulePath = Join-Path -Path $env:AGENT_TEMPDIRECTORY -ChildPath 'TempModules'
$env:PSModulePath = $modulePath + [System.IO.Path]::PathSeparator + $env:PSModulePath
Write-Verbose -Verbose "Importing build utilities (buildtools.psd1)"
Import-Module -Name (Join-Path -Path '${{ parameters.buildDirectory }}' -ChildPath 'buildtools.psd1') -Force
$impPath = Join-Path -Path '${{ parameters.buildDirectory }}' -ChildPath 'buildtools.psd1'
Write-Verbose -Verbose "path to improt from: $impPath"
Import-Module -Name $impPath -Force
#
Write-Verbose -Verbose "about to call Invoke-ModuleTests"
Invoke-ModuleTests -Type Functional
env:
MAPPED_GITHUB_PAT: $(github_pat)
Expand Down
2 changes: 1 addition & 1 deletion .github/ISSUE_TEMPLATE/Bug_Report.yaml
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,7 @@ body:

For PowerShellGet v2 issues, please use [PowerShellGetv2 repo](https://github.com/PowerShell/PowerShellGetv2).

This repository is **ONLY** for PSResourceGet issues.
This repository is **ONLY** for Microsoft.PowerShell.PSResourceGet issues.
- type: checkboxes
attributes:
label: Prerequisites
Expand Down
13 changes: 8 additions & 5 deletions buildtools.psm1
Original file line number Diff line number Diff line change
Expand Up @@ -2,7 +2,7 @@
# Licensed under the MIT License.

$ConfigurationFileName = 'package.config.json'
Import-Module -Name PowerShellGet -MinimumVersion 3.0.18
Import-Module -Name Microsoft.PowerShell.PSResourceGet -MinimumVersion 0.9.0

function Get-BuildConfiguration {
[CmdletBinding()]
Expand Down Expand Up @@ -109,16 +109,18 @@ function Install-ModulePackageForTest {
$config = Get-BuildConfiguration

$localRepoName = 'packagebuild-local-repo'
Write-Verbose -Verbose -Message "Registering local package repo: $localRepoName to path: $PackagePath"
Register-PSResourceRepository -Name $localRepoName -Uri $PackagePath -Trusted -Force
$packagePathWithNupkg = Join-Path -Path $PackagePath -ChildPath "nupkg"
Write-Verbose -Verbose -Message "Registering local package repo: $localRepoName to path: $packagePathWithNupkg"
Register-PSResourceRepository -Name $localRepoName -Uri $packagePathWithNupkg -Trusted -Force

$installationPath = $config.BuildOutputPath
if ( !(Test-Path $installationPath)) {
Write-Verbose -Verbose -Message "Creating module directory location for tests: $installationPath"
$null = New-Item -Path $installationPath -ItemType Directory -Verbose
}

Write-Verbose -Verbose -Message "Installing module $($config.ModuleName) to build output path $installationPath"
Save-PSResource -Name $config.ModuleName -Repository $localRepoName -Path $installationPath -SkipDependencyCheck -Prerelease -Confirm:$false
Save-PSResource -Name $config.ModuleName -Repository $localRepoName -Path $installationPath -SkipDependencyCheck -Prerelease -Confirm:$false -TrustRepository

Write-Verbose -Verbose -Message "Unregistering local package repo: $localRepoName"
Unregister-PSResourceRepository -Name $localRepoName -Confirm:$false
Expand All @@ -139,7 +141,8 @@ function Invoke-ModuleTests {
$excludeTag = 'ManualValidationOnly'
$testResultFileName = 'result.pester.xml'
$testPath = $config.TestPath
$moduleToTest = Join-Path -Path $config.BuildOutputPath -ChildPath $config.ModuleName
Write-Verbose -Verbose $config.ModuleName
$moduleToTest = Join-Path -Path $config.BuildOutputPath -ChildPath "Microsoft.PowerShell.PSResourceGet"
$command = "Import-Module -Name ${moduleToTest} -Force -Verbose; Set-Location -Path ${testPath}; Invoke-Pester -Path . -OutputFile ${testResultFileName} -Tags '${tags}' -ExcludeTag '${excludeTag}'"
$pwshExePath = (Get-Process -Id $pid).Path

Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -97,7 +97,7 @@ Describe "Test Publish-PSResource" -tags 'CI' {

Publish-PSResource -Path $script:PublishModuleBase -Repository $ADOPublicRepoName -Credential $correctPublicRepoCred -ErrorAction SilentlyContinue

$Error[0].FullyQualifiedErrorId | Should -be "400ApiKeyError,Microsoft.PowerShell.PSResourceGet.Cmdlets.PublishPSResource"
$Error[0].FullyQualifiedErrorId | Should -be "401Error,Microsoft.PowerShell.PSResourceGet.Cmdlets.PublishPSResource"
}

It "Should not publish module to ADO repository feed (private) when Credentials are incorrect" {
Expand Down