-
Notifications
You must be signed in to change notification settings - Fork 129
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge main into feature/amqp. (#4491)
* Add GetCredentialName() (#4428) * Add GetCredentialName() * Update * Undo accidental change * Clang-format * Call GetCredentialName() instead of using constant; Return in-place constructed name; Explicit tests for GetCredentialName() * PR feedback * constructor parameter + non-virtual GetCredentialName() * Update sdk/core/azure-core/CMakeLists.txt * Update sdk/identity/azure-identity/test/ut/client_secret_credential_test.cpp * Update sdk/identity/azure-identity/test/ut/client_certificate_credential_test.cpp * GCC and Clang warnings * Promote ThrowIfNotSafeCmdLineInput() to private member; avoid copies when calling GetCredentialName() * Spelling * Fix deprecated usage * Fix iteration * Clang-format --------- Co-authored-by: Anton Kolesnyk <[email protected]> * Sync eng/common directory with azure-sdk-tools for PR 5702 (#4453) * add healthinsights to Test-SampleMetadata script * spacing * update productSlug to azure-health-insights --------- Co-authored-by: Asaf Levi <[email protected]> * Use aka.ms link to Identity troubleshooting (#4449) * Use aka.ms link to Identity troubleshooting * Update default_azure_credential.cpp * Update default_azure_credential.cpp --------- Co-authored-by: Anton Kolesnyk <[email protected]> * Undocument ChainedCred usage by DefaultAzCred & remove friend and private ctor (#4447) * Undocument ChainedCred usage by DefaultAzCred & remove friend and private ctor * Clang warning fix --------- Co-authored-by: Anton Kolesnyk <[email protected]> * Sync eng/common directory with azure-sdk-tools for PR 5691 (#4450) * typespec renaming * add back scripts for cadl * support .cadl and .tsp * rename * add newline at the end of file --------- Co-authored-by: FAREAST\chunyu <[email protected]> * fix cspell for readme.ms in libcurl sterss test (#4441) * fix cspell * capitalize Valgrind and ubuntu * sdada * fix2 * Simpler identity logging (#4455) * Simpler identity logging * Even simpler * Remove refactoring artifact * Cosmetic change * foreach --------- Co-authored-by: Anton Kolesnyk <[email protected]> * 3rd Party Libs in Samples (#4408) Adding guidance on the proper usage of 3rd Party Libraries in our samples. * Update changelog with issue link (#4458) Co-authored-by: Anton Kolesnyk <[email protected]> * Tests: replace most `EXPECT_TRUE(a OP b)` with `EXPECT_OP(a, b)` (#4457) * Tests: replace most `EXPECT_TRUE(a OP b)` with `EXPECT_OP(a, b)` * Undo unnecessary change --------- Co-authored-by: Anton Kolesnyk <[email protected]> * Revert "[check-spelling] Temporarily pin Node 18 to 18.13.0 (#5537)" (#4456) This reverts commit 8a02e02adfc0d213509fce2764132afa74bd4ba4. Co-authored-by: Mike Harder <[email protected]> * Fix potentially high CPU usage on Windows (#4448) * Fix potentially high CPU usage on Windows * Undo unnecessary formatting * Undo unnecessary changelog * Undo unnecessary formatting * Undo unnecessary formatting * Uninclude locale * Add issue link to changelog * EXPECT_TRUE(a == b) => EXPECT_EQ(a, b) * Update second changelog with link as well --------- Co-authored-by: Anton Kolesnyk <[email protected]> * Ensure the comparison is unsigned to unsigned (#4464) * Ensure the comparison is unsigned to unsigned * Remove cast * Sync eng/common directory with azure-sdk-tools for PR 5742 (#4465) * add some default output to see about minimizing any occurrence of the task failing for no reason. perhaps having some output will allow devops to have an easier time with the invocation * update message * Update eng/common/scripts/trust-proxy-certificate.ps1 Co-authored-by: Wes Haggard <[email protected]> * Update CODEOWNERS (#4461) Fixup an invalid user * Organize applying Identity log prefix (#4459) * Organize applying Identity log prefix * logLevel * Cosmetic changes --------- Co-authored-by: Anton Kolesnyk <[email protected]> * Explicitly set PSNativeCommandArgumentPassing to Legacy for git push script (#4481) https://learn.microsoft.com/en-us/powershell/scripting/learn/experimental-features?view=powershell-7.3#psnativecommandargumentpassing Do to that breaking change in PS 7.3 we need to opt into the legacy arg parsing. Co-authored-by: Wes Haggard <[email protected]> * Fix unmatched parenthesis in doc (#4482) * fix concurrent upload failures (#4484) * Sync eng/common directory with azure-sdk-tools for PR 5726 (#4488) * rerun flag * rerun failed stress test * naming & commenting * update * function and var renaming for better readability * readability & exit on error --------- Co-authored-by: Albert Cheng <[email protected]> --------- Co-authored-by: Anton Kolesnyk <[email protected]> Co-authored-by: Anton Kolesnyk <[email protected]> Co-authored-by: Azure SDK Bot <[email protected]> Co-authored-by: Asaf Levi <[email protected]> Co-authored-by: FAREAST\chunyu <[email protected]> Co-authored-by: George Arama <[email protected]> Co-authored-by: Ronnie Geraghty <[email protected]> Co-authored-by: Mike Harder <[email protected]> Co-authored-by: Rick Winter <[email protected]> Co-authored-by: Wes Haggard <[email protected]> Co-authored-by: Wes Haggard <[email protected]> Co-authored-by: JinmingHu <[email protected]> Co-authored-by: Albert Cheng <[email protected]>
- Loading branch information
1 parent
f0a26fd
commit e23be62
Showing
63 changed files
with
1,100 additions
and
549 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,101 @@ | ||
# For details see https://github.com/Azure/azure-sdk-tools/blob/main/doc/common/TypeSpec-Project-Scripts.md | ||
|
||
[CmdletBinding()] | ||
param ( | ||
[Parameter(Position=0)] | ||
[ValidateNotNullOrEmpty()] | ||
[string] $ProjectDirectory, | ||
[Parameter(Position=1)] | ||
[string] $typespecAdditionalOptions ## addtional typespec emitter options, separated by semicolon if more than one, e.g. option1=value1;option2=value2 | ||
) | ||
|
||
$ErrorActionPreference = "Stop" | ||
. $PSScriptRoot/Helpers/PSModule-Helpers.ps1 | ||
. $PSScriptRoot/common.ps1 | ||
Install-ModuleIfNotInstalled "powershell-yaml" "0.4.1" | Import-Module | ||
|
||
function NpmInstallForProject([string]$workingDirectory) { | ||
Push-Location $workingDirectory | ||
try { | ||
$currentDur = Resolve-Path "." | ||
Write-Host "Generating from $currentDur" | ||
|
||
if (Test-Path "package.json") { | ||
Remove-Item -Path "package.json" -Force | ||
} | ||
|
||
if (Test-Path ".npmrc") { | ||
Remove-Item -Path ".npmrc" -Force | ||
} | ||
|
||
if (Test-Path "node_modules") { | ||
Remove-Item -Path "node_modules" -Force -Recurse | ||
} | ||
|
||
if (Test-Path "package-lock.json") { | ||
Remove-Item -Path "package-lock.json" -Force | ||
} | ||
|
||
#default to root/eng/emitter-package.json but you can override by writing | ||
#Get-${Language}-EmitterPackageJsonPath in your Language-Settings.ps1 | ||
$replacementPackageJson = "$PSScriptRoot/../../emitter-package.json" | ||
if (Test-Path "Function:$GetEmitterPackageJsonPathFn") { | ||
$replacementPackageJson = &$GetEmitterPackageJsonPathFn | ||
} | ||
|
||
Write-Host("Copying package.json from $replacementPackageJson") | ||
Copy-Item -Path $replacementPackageJson -Destination "package.json" -Force | ||
npm install --no-lock-file | ||
if ($LASTEXITCODE) { exit $LASTEXITCODE } | ||
} | ||
finally { | ||
Pop-Location | ||
} | ||
} | ||
|
||
$resolvedProjectDirectory = Resolve-Path $ProjectDirectory | ||
$emitterName = &$GetEmitterNameFn | ||
$typespecConfigurationFile = Resolve-Path "$ProjectDirectory/tsp-location.yaml" | ||
|
||
Write-Host "Reading configuration from $typespecConfigurationFile" | ||
$configuration = Get-Content -Path $typespecConfigurationFile -Raw | ConvertFrom-Yaml | ||
|
||
$specSubDirectory = $configuration["directory"] | ||
$innerFolder = Split-Path $specSubDirectory -Leaf | ||
|
||
$tempFolder = "$ProjectDirectory/TempTypeSpecFiles" | ||
$npmWorkingDir = Resolve-Path $tempFolder/$innerFolder | ||
$mainTypeSpecFile = If (Test-Path "$npmWorkingDir/client.*") { Resolve-Path "$npmWorkingDir/client.*" } Else { Resolve-Path "$npmWorkingDir/main.*"} | ||
|
||
try { | ||
Push-Location $npmWorkingDir | ||
NpmInstallForProject $npmWorkingDir | ||
|
||
if ($LASTEXITCODE) { exit $LASTEXITCODE } | ||
|
||
if (Test-Path "Function:$GetEmitterAdditionalOptionsFn") { | ||
$emitterAdditionalOptions = &$GetEmitterAdditionalOptionsFn $resolvedProjectDirectory | ||
if ($emitterAdditionalOptions.Length -gt 0) { | ||
$emitterAdditionalOptions = " $emitterAdditionalOptions" | ||
} | ||
} | ||
$typespecCompileCommand = "npx tsp compile $mainTypeSpecFile --emit $emitterName$emitterAdditionalOptions" | ||
if ($typespecAdditionalOptions) { | ||
$options = $typespecAdditionalOptions.Split(";"); | ||
foreach ($option in $options) { | ||
$typespecCompileCommand += " --option $emitterName.$option" | ||
} | ||
} | ||
Write-Host($typespecCompileCommand) | ||
Invoke-Expression $typespecCompileCommand | ||
|
||
if ($LASTEXITCODE) { exit $LASTEXITCODE } | ||
} | ||
finally { | ||
Pop-Location | ||
} | ||
|
||
$shouldCleanUp = $configuration["cleanup"] ?? $true | ||
if ($shouldCleanUp) { | ||
Remove-Item $tempFolder -Recurse -Force | ||
} |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,127 @@ | ||
# For details see https://github.com/Azure/azure-sdk-tools/blob/main/doc/common/TypeSpec-Project-Scripts.md | ||
|
||
[CmdletBinding()] | ||
param ( | ||
[Parameter(Position=0)] | ||
[ValidateNotNullOrEmpty()] | ||
[string] $ProjectDirectory | ||
) | ||
|
||
$ErrorActionPreference = "Stop" | ||
. $PSScriptRoot/Helpers/PSModule-Helpers.ps1 | ||
Install-ModuleIfNotInstalled "powershell-yaml" "0.4.1" | Import-Module | ||
$sparseCheckoutFile = ".git/info/sparse-checkout" | ||
|
||
function AddSparseCheckoutPath([string]$subDirectory) { | ||
if (!(Test-Path $sparseCheckoutFile) -or !((Get-Content $sparseCheckoutFile).Contains($subDirectory))) { | ||
Write-Output $subDirectory >> .git/info/sparse-checkout | ||
} | ||
} | ||
|
||
function CopySpecToProjectIfNeeded([string]$specCloneRoot, [string]$mainSpecDir, [string]$dest, [string[]]$specAdditionalSubDirectories) { | ||
$source = "$specCloneRoot/$mainSpecDir" | ||
Copy-Item -Path $source -Destination $dest -Recurse -Force | ||
Write-Host "Copying spec from $source to $dest" | ||
|
||
foreach ($additionalDir in $specAdditionalSubDirectories) { | ||
$source = "$specCloneRoot/$additionalDir" | ||
Write-Host "Copying spec from $source to $dest" | ||
Copy-Item -Path $source -Destination $dest -Recurse -Force | ||
} | ||
} | ||
|
||
function UpdateSparseCheckoutFile([string]$mainSpecDir, [string[]]$specAdditionalSubDirectories) { | ||
AddSparseCheckoutPath $mainSpecDir | ||
foreach ($subDir in $specAdditionalSubDirectories) { | ||
AddSparseCheckoutPath $subDir | ||
} | ||
} | ||
|
||
function GetGitRemoteValue([string]$repo) { | ||
Push-Location $ProjectDirectory | ||
$result = "" | ||
try { | ||
$gitRemotes = (git remote -v) | ||
foreach ($remote in $gitRemotes) { | ||
if ($remote.StartsWith("origin")) { | ||
if ($remote -match 'https://github.com/\S+') { | ||
$result = "https://github.com/$repo.git" | ||
break | ||
} elseif ($remote -match "[email protected]:\S+"){ | ||
$result = "[email protected]:$repo.git" | ||
break | ||
} else { | ||
throw "Unknown git remote format found: $remote" | ||
} | ||
} | ||
} | ||
} | ||
finally { | ||
Pop-Location | ||
} | ||
|
||
return $result | ||
} | ||
|
||
function InitializeSparseGitClone([string]$repo) { | ||
git clone --no-checkout --filter=tree:0 $repo . | ||
if ($LASTEXITCODE) { exit $LASTEXITCODE } | ||
git sparse-checkout init | ||
if ($LASTEXITCODE) { exit $LASTEXITCODE } | ||
Remove-Item $sparseCheckoutFile -Force | ||
} | ||
|
||
function GetSpecCloneDir([string]$projectName) { | ||
Push-Location $ProjectDirectory | ||
try { | ||
$root = git rev-parse --show-toplevel | ||
} | ||
finally { | ||
Pop-Location | ||
} | ||
|
||
$sparseSpecCloneDir = "$root/../sparse-spec/$projectName" | ||
New-Item $sparseSpecCloneDir -Type Directory -Force | Out-Null | ||
$createResult = Resolve-Path $sparseSpecCloneDir | ||
return $createResult | ||
} | ||
|
||
$typespecConfigurationFile = Resolve-Path "$ProjectDirectory/tsp-location.yaml" | ||
Write-Host "Reading configuration from $typespecConfigurationFile" | ||
$configuration = Get-Content -Path $typespecConfigurationFile -Raw | ConvertFrom-Yaml | ||
|
||
$pieces = $typespecConfigurationFile.Path.Replace("\","/").Split("/") | ||
$projectName = $pieces[$pieces.Count - 2] | ||
|
||
$specSubDirectory = $configuration["directory"] | ||
|
||
if ( $configuration["repo"] -and $configuration["commit"]) { | ||
$specCloneDir = GetSpecCloneDir $projectName | ||
$gitRemoteValue = GetGitRemoteValue $configuration["repo"] | ||
|
||
Write-Host "Setting up sparse clone for $projectName at $specCloneDir" | ||
|
||
Push-Location $specCloneDir.Path | ||
try { | ||
if (!(Test-Path ".git")) { | ||
InitializeSparseGitClone $gitRemoteValue | ||
UpdateSparseCheckoutFile $specSubDirectory $configuration["additionalDirectories"] | ||
} | ||
git checkout $configuration["commit"] | ||
if ($LASTEXITCODE) { exit $LASTEXITCODE } | ||
} | ||
finally { | ||
Pop-Location | ||
} | ||
} elseif ( $configuration["spec-root-dir"] ) { | ||
$specCloneDir = $configuration["spec-root-dir"] | ||
} | ||
|
||
|
||
$tempTypeSpecDir = "$ProjectDirectory/TempTypeSpecFiles" | ||
New-Item $tempTypeSpecDir -Type Directory -Force | Out-Null | ||
CopySpecToProjectIfNeeded ` | ||
-specCloneRoot $specCloneDir ` | ||
-mainSpecDir $specSubDirectory ` | ||
-dest $tempTypeSpecDir ` | ||
-specAdditionalSubDirectories $configuration["additionalDirectories"] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.