mirror of
https://github.com/ScoopInstaller/Scoop.git
synced 2025-10-30 14:17:54 +00:00
178 lines
5.4 KiB
PowerShell
178 lines
5.4 KiB
PowerShell
$repo_dir = (Get-Item $MyInvocation.MyCommand.Path).directory.parent.FullName
|
|
|
|
describe 'Project code' {
|
|
|
|
$files = @(
|
|
Get-ChildItem $repo_dir -file -recurse -force | ? { $_.fullname -match '.(ps1|psm1)$' }
|
|
)
|
|
|
|
function Test-PowerShellSyntax {
|
|
# ref: http://powershell.org/wp/forums/topic/how-to-check-syntax-of-scripts-automatically @@ https://archive.is/xtSv6
|
|
# originally created by Alexander Petrovskiy & Dave Wyatt
|
|
[CmdletBinding()]
|
|
param (
|
|
[Parameter(Mandatory = $true, ValueFromPipeline = $true)]
|
|
[string[]]
|
|
$Path
|
|
)
|
|
|
|
process {
|
|
foreach ($scriptPath in $Path) {
|
|
$contents = Get-Content -Path $scriptPath
|
|
|
|
if ($null -eq $contents) {
|
|
continue
|
|
}
|
|
|
|
$errors = $null
|
|
$null = [System.Management.Automation.PSParser]::Tokenize($contents, [ref]$errors)
|
|
|
|
New-Object psobject -Property @{
|
|
Path = $scriptPath
|
|
SyntaxErrorsFound = ($errors.Count -gt 0)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
|
|
it 'PowerShell files do not contain syntax errors' {
|
|
$badFiles = @(
|
|
foreach ($file in $files)
|
|
{
|
|
if ( (Test-PowerShellSyntax $file.FullName).SyntaxErrorsFound )
|
|
{
|
|
$file.FullName
|
|
}
|
|
}
|
|
)
|
|
|
|
if ($badFiles.Count -gt 0)
|
|
{
|
|
throw "The following files have syntax errors: `r`n`r`n$($badFiles -join "`r`n")"
|
|
}
|
|
}
|
|
|
|
}
|
|
|
|
describe 'Project style constraints' {
|
|
|
|
$files = @(
|
|
# gather all files except '*.exe', '*.zip', or any .git repository files
|
|
Get-ChildItem $repo_dir -file -recurse -force | ? { $_.fullname -notmatch '(.git(|\\.*)|.exe|.zip)$' }
|
|
)
|
|
|
|
it 'files do not contain leading utf-8 BOM' {
|
|
# utf-8 BOM == 0xEF 0xBB 0xBF
|
|
# see http://www.powershellmagazine.com/2012/12/17/pscxtip-how-to-determine-the-byte-order-mark-of-a-text-file @@ https://archive.is/RgT42
|
|
# ref: http://poshcode.org/2153 @@ https://archive.is/sGnnu
|
|
$badFiles = @(
|
|
foreach ($file in $files)
|
|
{
|
|
$content = ([char[]](Get-Content $file.FullName -encoding byte -totalcount 3) -join '')
|
|
if ([regex]::match($content, '(?ms)^\xEF\xBB\xBF').success)
|
|
{
|
|
$file.FullName
|
|
}
|
|
}
|
|
)
|
|
|
|
if ($badFiles.Count -gt 0)
|
|
{
|
|
throw "The following files have utf-8 BOM: `r`n`r`n$($badFiles -join "`r`n")"
|
|
}
|
|
}
|
|
|
|
it 'files all have line endings which are CRLF' {
|
|
$badFiles = @(
|
|
foreach ($file in $files)
|
|
{
|
|
$content = Get-Content -raw $file.FullName
|
|
$lines = [regex]::split($content, '\r\n')
|
|
$lineCount = $lines.Count
|
|
|
|
for ($i = 0; $i -lt $lineCount; $i++)
|
|
{
|
|
if ( [regex]::match($lines[$i], '\r|\n').success )
|
|
{
|
|
$file.FullName
|
|
break
|
|
}
|
|
}
|
|
}
|
|
)
|
|
|
|
if ($badFiles.Count -gt 0)
|
|
{
|
|
throw "The following files have non-CRLF line endings: `r`n`r`n$($badFiles -join "`r`n")"
|
|
}
|
|
}
|
|
|
|
it 'files all end with a newline' {
|
|
$badFiles = @(
|
|
foreach ($file in $files)
|
|
{
|
|
$string = [System.IO.File]::ReadAllText($file.FullName)
|
|
if ($string.Length -gt 0 -and $string[-1] -ne "`n")
|
|
{
|
|
$file.FullName
|
|
}
|
|
}
|
|
)
|
|
|
|
if ($badFiles.Count -gt 0)
|
|
{
|
|
throw "The following files do not end with a newline: `r`n`r`n$($badFiles -join "`r`n")"
|
|
}
|
|
}
|
|
|
|
it 'files have leading whitespace consisting only of spaces' {
|
|
$badLines = @(
|
|
foreach ($file in $files)
|
|
{
|
|
if ($file.fullname -notmatch 'makefile$')
|
|
{
|
|
$lines = [System.IO.File]::ReadAllLines($file.FullName)
|
|
$lineCount = $lines.Count
|
|
|
|
for ($i = 0; $i -lt $lineCount; $i++)
|
|
{
|
|
if ($lines[$i] -notmatch '^[ ]*(\S|$)')
|
|
{
|
|
'File: {0}, Line: {1}' -f $file.FullName, ($i + 1)
|
|
}
|
|
}
|
|
}
|
|
}
|
|
)
|
|
|
|
if ($badLines.Count -gt 0)
|
|
{
|
|
throw "The following $($badLines.Count) lines contain TABs within leading whitespace: `r`n`r`n$($badLines -join "`r`n")"
|
|
}
|
|
}
|
|
|
|
it 'files have no lines containing trailing whitespace' {
|
|
$badLines = @(
|
|
foreach ($file in $files)
|
|
{
|
|
$lines = [System.IO.File]::ReadAllLines($file.FullName)
|
|
$lineCount = $lines.Count
|
|
|
|
for ($i = 0; $i -lt $lineCount; $i++)
|
|
{
|
|
if ($lines[$i] -match '\s+$')
|
|
{
|
|
'File: {0}, Line: {1}' -f $file.FullName, ($i + 1)
|
|
}
|
|
}
|
|
}
|
|
)
|
|
|
|
if ($badLines.Count -gt 0)
|
|
{
|
|
throw "The following $($badLines.Count) lines contain trailing whitespace: `r`n`r`n$($badLines -join "`r`n")"
|
|
}
|
|
}
|
|
|
|
}
|