-
Notifications
You must be signed in to change notification settings - Fork 790
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Merge pull request #6568 from Microsoft/merges/master-to-nullness
Merge master to nullness
- Loading branch information
Showing
8 changed files
with
154 additions
and
10 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
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,134 @@ | ||
param( | ||
[Parameter(Mandatory=$true)][string] $InputPath, # Full path to directory where NuGet packages to be checked are stored | ||
[Parameter(Mandatory=$true)][string] $ExtractPath, # Full path to directory where the packages will be extracted during validation | ||
[Parameter(Mandatory=$true)][string] $SymbolToolPath # Full path to directory where dotnet symbol-tool was installed | ||
) | ||
|
||
Add-Type -AssemblyName System.IO.Compression.FileSystem | ||
|
||
function FirstMatchingSymbolDescriptionOrDefault { | ||
param( | ||
[string] $FullPath, # Full path to the module that has to be checked | ||
[string] $TargetServerParam # Parameter to pass to `Symbol Tool` indicating the server to lookup for symbols | ||
) | ||
|
||
$FileName = [System.IO.Path]::GetFileName($FullPath) | ||
$Extension = [System.IO.Path]::GetExtension($FullPath) | ||
|
||
# Those below are potential symbol files that the `dotnet symbol` might | ||
# return. Which one will be returned depend on the type of file we are | ||
# checking and which type of file was uploaded. | ||
|
||
# The file itself is returned | ||
$SymbolPath = $SymbolsPath + "\" + $FileName | ||
|
||
# PDB file for the module | ||
$PdbPath = $SymbolPath.Replace($Extension, ".pdb") | ||
|
||
# PDB file for R2R module (created by crossgen) | ||
$NGenPdb = $SymbolPath.Replace($Extension, ".ni.pdb") | ||
|
||
# DBG file for a .so library | ||
$SODbg = $SymbolPath.Replace($Extension, ".so.dbg") | ||
|
||
# DWARF file for a .dylib | ||
$DylibDwarf = $SymbolPath.Replace($Extension, ".dylib.dwarf") | ||
|
||
.\dotnet-symbol.exe --symbols --modules $TargetServerParam $FullPath -o $SymbolsPath -d | Out-Null | ||
|
||
if (Test-Path $PdbPath) { | ||
return "PDB" | ||
} | ||
elseif (Test-Path $NGenPdb) { | ||
return "NGen PDB" | ||
} | ||
elseif (Test-Path $SODbg) { | ||
return "DBG for SO" | ||
} | ||
elseif (Test-Path $DylibDwarf) { | ||
return "Dwarf for Dylib" | ||
} | ||
elseif (Test-Path $SymbolPath) { | ||
return "Module" | ||
} | ||
else { | ||
return $null | ||
} | ||
} | ||
|
||
function CountMissingSymbols { | ||
param( | ||
[string] $PackagePath # Path to a NuGet package | ||
) | ||
|
||
# Ensure input file exist | ||
if (!(Test-Path $PackagePath)) { | ||
throw "Input file does not exist: $PackagePath" | ||
} | ||
|
||
# Extensions for which we'll look for symbols | ||
$RelevantExtensions = @(".dll", ".exe", ".so", ".dylib") | ||
|
||
# How many files are missing symbol information | ||
$MissingSymbols = 0 | ||
|
||
$PackageId = [System.IO.Path]::GetFileNameWithoutExtension($PackagePath) | ||
$ExtractPath = $ExtractPath + $PackageId; | ||
$SymbolsPath = $ExtractPath + $PackageId + ".Symbols"; | ||
|
||
[System.IO.Compression.ZipFile]::ExtractToDirectory($PackagePath, $ExtractPath) | ||
|
||
# Makes easier to reference `symbol tool` | ||
Push-Location $SymbolToolPath | ||
|
||
Get-ChildItem -Recurse $ExtractPath | | ||
Where-Object {$RelevantExtensions -contains $_.Extension} | | ||
ForEach-Object { | ||
Write-Host -NoNewLine "`t Checking file" $_.FullName "... " | ||
|
||
$SymbolsOnMSDL = FirstMatchingSymbolDescriptionOrDefault $_.FullName "--microsoft-symbol-server" | ||
$SymbolsOnSymWeb = FirstMatchingSymbolDescriptionOrDefault $_.FullName "--internal-server" | ||
|
||
if ($SymbolsOnMSDL -ne $null -and $SymbolsOnSymWeb -ne $null) { | ||
Write-Host "Symbols found on MSDL (" $SymbolsOnMSDL ") and SymWeb (" $SymbolsOnSymWeb ")" | ||
} | ||
else { | ||
$MissingSymbols++ | ||
|
||
if ($SymbolsOnMSDL -eq $null -and $SymbolsOnSymWeb -eq $null) { | ||
Write-Host "No symbols found on MSDL or SymWeb!" | ||
} | ||
else { | ||
if ($SymbolsOnMSDL -eq $null) { | ||
Write-Host "No symbols found on MSDL!" | ||
} | ||
else { | ||
Write-Host "No symbols found on SymWeb!" | ||
} | ||
} | ||
} | ||
} | ||
|
||
Pop-Location | ||
|
||
return $MissingSymbols | ||
} | ||
|
||
function CheckSymbolsAvailable { | ||
if (Test-Path $ExtractPath) { | ||
Remove-Item -recurse $ExtractPath | ||
} | ||
|
||
Get-ChildItem "$InputPath\*.nupkg" | | ||
ForEach-Object { | ||
$FileName = $_.Name | ||
Write-Host "Validating $FileName " | ||
$Status = CountMissingSymbols "$InputPath\$FileName" | ||
|
||
if ($Status -ne 0) { | ||
Write-Error "Missing symbols for $Status modules in the package $FileName" | ||
} | ||
} | ||
} | ||
|
||
CheckSymbolsAvailable |
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,8 @@ | ||
<Project> | ||
|
||
<Import Project="$([MSBuild]::GetPathOfFileAbove('Directory.Build.targets', '$(MSBuildThisFileDirectory)../'))" /> | ||
|
||
<Target Name="GetVSGeneralVersion" Returns="$(VSGeneralVersion)"> | ||
</Target> | ||
|
||
</Project> |
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