From 5bcd67e912d8134de59447d1927166b90f848cc0 Mon Sep 17 00:00:00 2001 From: sima-zhu Date: Tue, 23 Nov 2021 11:55:45 -0800 Subject: [PATCH 1/5] Use the latest get-codeowner scripts --- .../templates/steps/get-pr-owners.yml | 54 ------------------- eng/common/scripts/Update-DocsMsMetadata.ps1 | 18 +++++-- eng/common/scripts/get-codeowners.ps1 | 6 +-- tools/code-owners-parser/ci.yml | 1 + 4 files changed, 19 insertions(+), 60 deletions(-) delete mode 100644 eng/common/pipelines/templates/steps/get-pr-owners.yml diff --git a/eng/common/pipelines/templates/steps/get-pr-owners.yml b/eng/common/pipelines/templates/steps/get-pr-owners.yml deleted file mode 100644 index 1ea87e85680..00000000000 --- a/eng/common/pipelines/templates/steps/get-pr-owners.yml +++ /dev/null @@ -1,54 +0,0 @@ -parameters: - TargetVariable: '' - TargetUserVariable: 'notspecified' - TargetTeamVariable: 'notspecified' - TargetLabelVariable: 'notspecified' - ServiceDirectory: '' - DevOpsFeed: "https://pkgs.dev.azure.com/azure-sdk/public/_packaging/azure-sdk-for-net/nuget/v3/index.json" - -steps: - - task: DotNetCoreCLI@2 - displayName: 'Install Identity Resolver' - inputs: - command: custom - custom: 'tool' - arguments: 'install --global --add-source "${{ parameters.DevOpsFeed }}" --version "1.0.0-dev.20211018.1" "Azure.Sdk.Tools.IdentityResolver"' - workingDirectory: '$(Agent.BuildDirectory)' - - - task: DotNetCoreCLI@2 - displayName: 'Install CodeOwners Retriever' - inputs: - command: custom - custom: 'tool' - arguments: 'install --global --add-source "${{ parameters.DevOpsFeed }}" --version "1.0.0-dev.20211019.1" "Azure.Sdk.Tools.RetrieveCodeOwners"' - workingDirectory: '$(Agent.BuildDirectory)' - - - pwsh: | - identity-resolver ` - --aad-app-id-var APP_ID ` - --aad-app-secret-var APP_SECRET ` - --aad-tenant-var AAD_TENANT ` - --kusto-url-var KUSTO_URL ` - --kusto-database-var KUSTO_DB ` - --kusto-table-var KUSTO_TABLE ` - --identity-name "$(Build.QueuedBy)" ` - --identity-email "$(Build.RequestedForEmail)" ` - --targetvar "${{ coalesce(parameters.TargetVariable, parameters.TargetUserVariable) }}" - displayName: 'Resolving Queuing User' - continueOnError: true - env: - APP_ID: $(notification-aad-app-id) - APP_SECRET: $(notification-aad-secret) - AAD_TENANT: $(notification-aad-tenant) - KUSTO_URL: $(notification-kusto-url) - KUSTO_DB: $(notification-kusto-db) - KUSTO_TABLE: $(notification-kusto-table) - - - pwsh: | - retrieve-codeowners ` - --target-directory "/sdk/${{ parameters.ServiceDirectory }}/" ` - --root-directory "$(Build.SourcesDirectory)" ` - --vso-owning-users "${{ coalesce(parameters.TargetVariable, parameters.TargetUserVariable) }}" ` - --vso-owning-teams "${{ parameters.TargetTeamVariable }}" ` - --vso-owning-labels "${{ parameters.TargetLabelVariable }}" - displayName: 'Add CodeOwners if Present' \ No newline at end of file diff --git a/eng/common/scripts/Update-DocsMsMetadata.ps1 b/eng/common/scripts/Update-DocsMsMetadata.ps1 index 774d2b0a606..007f087a503 100644 --- a/eng/common/scripts/Update-DocsMsMetadata.ps1 +++ b/eng/common/scripts/Update-DocsMsMetadata.ps1 @@ -33,7 +33,7 @@ GitHub repository ID of the SDK. Typically of the form: 'Azure/azure-sdk-for-js' param( [Parameter(Mandatory = $true)] [array]$PackageInfoJsonLocations, - + [Parameter(Mandatory = $true)] [string]$DocRepoLocation, @@ -78,12 +78,24 @@ function GetAdjustedReadmeContent($ReadmeContent, $PackageInfo, $PackageMetadata $ReadmeContent = $ReadmeContent -replace $releaseReplaceRegex, $replacementPattern } + # Get the first code owners of the package. + $author = "ramya-rao-a" + $msauthor = "ramyar" + $codeOwnerArray = ."$PSScriptRoot/get-codeowners.ps1" ` + -TargetDirectory "sd" + #-TargetDirectory $PackageInfo.DirectoryPath + if ($codeOwnerArray) { + $author = $codeOwnerArray[0] + $msauthor = $author # This is a placeholder for now. Will change to the right ms alias. + } + Write-Host "The author of package: $author" + Write-Host "The ms author of package: $msauthor" $header = @" --- title: $foundTitle keywords: Azure, $Language, SDK, API, $($PackageInfo.Name), $service -author: maggiepint -ms.author: magpint +author: $author +ms.author: $msauthor ms.date: $date ms.topic: reference ms.prod: azure diff --git a/eng/common/scripts/get-codeowners.ps1 b/eng/common/scripts/get-codeowners.ps1 index dff01ecab60..488586b8d72 100644 --- a/eng/common/scripts/get-codeowners.ps1 +++ b/eng/common/scripts/get-codeowners.ps1 @@ -1,6 +1,6 @@ param ( [string]$TargetDirectory = "", # Code path to code owners. e.g sdk/core/azure-amqp - [string]$CodeOwnerFileLocation = "$PSSCriptRoot/../../../.github/CODEOWNERS", # The absolute path of CODEOWNERS file. + [string]$CodeOwnerFileLocation = (Resolve-Path $PSScriptRoot/../../../.github/CODEOWNERS), # The absolute path of CODEOWNERS file. [string]$ToolVersion = "1.0.0-dev.20211122.14", # Placeholder. Will update in next PR [string]$ToolPath = (Join-Path ([System.IO.Path]::GetTempPath()) "codeowners-tool-path"), # The place to check the tool existence. Put temp path as default [string]$DevOpsFeed = "https://pkgs.dev.azure.com/azure-sdk/public/_packaging/azure-sdk-for-net/nuget/v3/index.json", # DevOp tool feeds. @@ -34,7 +34,6 @@ function Get-CodeOwners ([string]$targetDirectory, [string]$codeOwnerFileLocatio { $command = Get-CodeOwnersTool # Filter out the non user alias from code owner list. - Write-Host "Testing on $targetDirectory..." if($includeNonUserAliases) { $codeOwnersString = & $command --target-directory $targetDirectory --code-owner-file-path $codeOwnerFileLocation 2>&1 } @@ -62,6 +61,7 @@ function Get-CodeOwners ([string]$targetDirectory, [string]$codeOwnerFileLocatio } function TestGetCodeOwner([string]$targetDirectory, [string]$codeOwnerFileLocation, [bool]$includeNonUserAliases = $false, [string[]]$expectReturn) { + Write-Host "Testing on $targetDirectory..." $actualReturn = Get-CodeOwners -targetDirectory $targetDirectory -codeOwnerFileLocation $codeOwnerFileLocation -includeNonUserAliases $IncludeNonUserAliases if ($actualReturn.Count -ne $expectReturn.Count) { @@ -77,7 +77,7 @@ function TestGetCodeOwner([string]$targetDirectory, [string]$codeOwnerFileLocati } if($Test) { - $testFile = "$PSSCriptRoot/../../../tools/code-owners-parser/Azure.Sdk.Tools.RetrieveCodeOwners.Tests/CODEOWNERS" + $testFile = (Resolve-Path $PSScriptRoot/../../../tools/code-owners-parser/Azure.Sdk.Tools.RetrieveCodeOwners.Tests/CODEOWNERS) TestGetCodeOwner -targetDirectory "sdk" -codeOwnerFileLocation $testFile -includeNonUserAliases $true -expectReturn @("person1", "person2") TestGetCodeOwner -targetDirectory "sdk/noPath" -codeOwnerFileLocation $testFile -includeNonUserAliases $true -expectReturn @("person1", "person2") TestGetCodeOwner -targetDirectory "/sdk/azconfig" -codeOwnerFileLocation $testFile -includeNonUserAliases $true -expectReturn @("person3", "person4") diff --git a/tools/code-owners-parser/ci.yml b/tools/code-owners-parser/ci.yml index 5e23a01c7a0..0da3fd76588 100644 --- a/tools/code-owners-parser/ci.yml +++ b/tools/code-owners-parser/ci.yml @@ -20,6 +20,7 @@ pr: paths: include: - tools/code-owners-parser + - eng/common/scripts/get-codeowners.ps1 extends: template: /eng/pipelines/templates/stages/archetype-sdk-tool-dotnet.yml From 01da079a3c0589b688c00ca5bfa34f5de85b5515 Mon Sep 17 00:00:00 2001 From: Sima Zhu <48036328+sima-zhu@users.noreply.github.com> Date: Tue, 23 Nov 2021 14:03:59 -0800 Subject: [PATCH 2/5] Update Update-DocsMsMetadata.ps1 --- eng/common/scripts/Update-DocsMsMetadata.ps1 | 3 +-- 1 file changed, 1 insertion(+), 2 deletions(-) diff --git a/eng/common/scripts/Update-DocsMsMetadata.ps1 b/eng/common/scripts/Update-DocsMsMetadata.ps1 index 007f087a503..2ace8cb45bd 100644 --- a/eng/common/scripts/Update-DocsMsMetadata.ps1 +++ b/eng/common/scripts/Update-DocsMsMetadata.ps1 @@ -82,8 +82,7 @@ function GetAdjustedReadmeContent($ReadmeContent, $PackageInfo, $PackageMetadata $author = "ramya-rao-a" $msauthor = "ramyar" $codeOwnerArray = ."$PSScriptRoot/get-codeowners.ps1" ` - -TargetDirectory "sd" - #-TargetDirectory $PackageInfo.DirectoryPath + -TargetDirectory $PackageInfo.DirectoryPath if ($codeOwnerArray) { $author = $codeOwnerArray[0] $msauthor = $author # This is a placeholder for now. Will change to the right ms alias. From 47a61c5c00cbdfaa43c396035be5af81c910700d Mon Sep 17 00:00:00 2001 From: Sima Zhu <48036328+sima-zhu@users.noreply.github.com> Date: Tue, 23 Nov 2021 14:23:03 -0800 Subject: [PATCH 3/5] Update version --- eng/common/scripts/get-codeowners.ps1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eng/common/scripts/get-codeowners.ps1 b/eng/common/scripts/get-codeowners.ps1 index 488586b8d72..d36a78e6f65 100644 --- a/eng/common/scripts/get-codeowners.ps1 +++ b/eng/common/scripts/get-codeowners.ps1 @@ -1,7 +1,7 @@ param ( [string]$TargetDirectory = "", # Code path to code owners. e.g sdk/core/azure-amqp [string]$CodeOwnerFileLocation = (Resolve-Path $PSScriptRoot/../../../.github/CODEOWNERS), # The absolute path of CODEOWNERS file. - [string]$ToolVersion = "1.0.0-dev.20211122.14", # Placeholder. Will update in next PR + [string]$ToolVersion = "1.0.0-dev.20211123.13", # Placeholder. Will update in next PR [string]$ToolPath = (Join-Path ([System.IO.Path]::GetTempPath()) "codeowners-tool-path"), # The place to check the tool existence. Put temp path as default [string]$DevOpsFeed = "https://pkgs.dev.azure.com/azure-sdk/public/_packaging/azure-sdk-for-net/nuget/v3/index.json", # DevOp tool feeds. [string]$VsoVariable = "", # Option of write code owners into devop variable From 372e5c6b2215a6a52528859665c52525a792511e Mon Sep 17 00:00:00 2001 From: Sima Zhu <48036328+sima-zhu@users.noreply.github.com> Date: Tue, 23 Nov 2021 15:20:00 -0800 Subject: [PATCH 4/5] Update Update-DocsMsMetadata.ps1 --- eng/common/scripts/Update-DocsMsMetadata.ps1 | 2 ++ 1 file changed, 2 insertions(+) diff --git a/eng/common/scripts/Update-DocsMsMetadata.ps1 b/eng/common/scripts/Update-DocsMsMetadata.ps1 index 2ace8cb45bd..13209f0c22d 100644 --- a/eng/common/scripts/Update-DocsMsMetadata.ps1 +++ b/eng/common/scripts/Update-DocsMsMetadata.ps1 @@ -81,9 +81,11 @@ function GetAdjustedReadmeContent($ReadmeContent, $PackageInfo, $PackageMetadata # Get the first code owners of the package. $author = "ramya-rao-a" $msauthor = "ramyar" + Write-Host "Retrieve the code owner from $PackageInfo.DirectoryPath." $codeOwnerArray = ."$PSScriptRoot/get-codeowners.ps1" ` -TargetDirectory $PackageInfo.DirectoryPath if ($codeOwnerArray) { + Write-Host "Code Owners are $($codeOwnerArray -join ",")" $author = $codeOwnerArray[0] $msauthor = $author # This is a placeholder for now. Will change to the right ms alias. } From 9b98eb4551694fad94f88849c84cec4fa5fecfb4 Mon Sep 17 00:00:00 2001 From: Sima Zhu <48036328+sima-zhu@users.noreply.github.com> Date: Tue, 23 Nov 2021 16:05:37 -0800 Subject: [PATCH 5/5] Update Update-DocsMsMetadata.ps1 --- eng/common/scripts/Update-DocsMsMetadata.ps1 | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/eng/common/scripts/Update-DocsMsMetadata.ps1 b/eng/common/scripts/Update-DocsMsMetadata.ps1 index 13209f0c22d..fcb1756082a 100644 --- a/eng/common/scripts/Update-DocsMsMetadata.ps1 +++ b/eng/common/scripts/Update-DocsMsMetadata.ps1 @@ -81,7 +81,7 @@ function GetAdjustedReadmeContent($ReadmeContent, $PackageInfo, $PackageMetadata # Get the first code owners of the package. $author = "ramya-rao-a" $msauthor = "ramyar" - Write-Host "Retrieve the code owner from $PackageInfo.DirectoryPath." + Write-Host "Retrieve the code owner from $($PackageInfo.DirectoryPath)." $codeOwnerArray = ."$PSScriptRoot/get-codeowners.ps1" ` -TargetDirectory $PackageInfo.DirectoryPath if ($codeOwnerArray) {