-
Notifications
You must be signed in to change notification settings - Fork 409
Description
Before submitting a bug report:
- Make sure you are able to repro it on the latest released version
- Perform a quick search for existing issues to check if this bug has already been reported
Steps to reproduce
Create a file called Write-Log.psm1 in your home directory and populate it with an empty function called Write-Log:
function Write-Log {
}Install and run PSScriptAnalyzer against the file:
> Install-Module PSScriptAnalyzer
> Invoke-ScriptAnalyzer -Path ~\Write-Log.psm1Expected behavior
PSScriptAnalyzer returns no findings because Write-Log is not a built-in cmdlet.
Actual behavior
RuleName Severity ScriptName Line Message
-------- -------- ---------- ---- -------
PSAvoidOverwritingBuiltInCmdlets Warning Write-Log.psm1 1 'Write-Log' is a cmdlet that is included with PowerShell (version core-6.1.0-windows) whose definition should not be overriddenThis behaviour should be reproducible cross-platform.
Troubleshooting
Write-Log was never shipped with any version of PowerShell, but it is erroneously defined as a built-in cmdlet:
PSScriptAnalyzer/Engine/Settings/core-6.1.0-linux-arm.json
Lines 1391 to 1395 in e280479
| { | |
| "Name": "Write-Log", | |
| "CommandType": "Function", | |
| "ParameterSets": "[-message] <string> [-WhatIf] [-Confirm] [<CommonParameters>]" | |
| }, |
PSScriptAnalyzer/Engine/Settings/core-6.1.0-linux.json
Lines 1391 to 1395 in e280479
| { | |
| "Name": "Write-Log", | |
| "CommandType": "Function", | |
| "ParameterSets": "[-message] <string> [-WhatIf] [-Confirm] [<CommonParameters>]" | |
| }, |
PSScriptAnalyzer/Engine/Settings/core-6.1.0-macos.json
Lines 1391 to 1395 in e280479
| { | |
| "Name": "Write-Log", | |
| "CommandType": "Function", | |
| "ParameterSets": "[-message] <string> [-WhatIf] [-Confirm] [<CommonParameters>]" | |
| }, |
PSScriptAnalyzer/Engine/Settings/core-6.1.0-windows.json
Lines 1692 to 1696 in e280479
| { | |
| "Name": "Write-Log", | |
| "CommandType": "Function", | |
| "ParameterSets": "[-message] <string> [-WhatIf] [-Confirm] [<CommonParameters>]" | |
| }, |
Probable cause is described in PowerShell/PowerShell#7209 as an upstream issue in PSDesiredStateConfiguration that was reportedly fixed in 2020. However, the PSScriptAnalyzer files affected by that issue were never rebuilt afterwards.
The module that may have caused this problem at the time is https://github.com/microsoft/PowerShellForGitHub, which defines Write-Log and then suppresses PSScriptAnalyzer reports in Helper.ps1#L128. The PR to suppress that finding is recorded in microsoft/PowerShellForGitHub#180. If this module was present in the build environment, then PSScriptAnalyzer would have added Write-Log and possibly other cmdlets to the list of built-in cmdlets even though they do not ship with PowerShell.
As a result, default installations of PSScriptAnalyzer return a false warning for PSAvoidOverwritingBuiltInCmdlets against cmdlets named Write-Log.
It is possible that there may be other cmdlets erroneously included in these files for the same reason.
Environment data
> $PSVersionTable
Name Value
---- -----
PSVersion 7.5.4
PSEdition Core
GitCommitId 7.5.4
OS Microsoft Windows 10.0.22631
Platform Win32NT
PSCompatibleVersions {1.0, 2.0, 3.0, 4.0…}
PSRemotingProtocolVersion 2.3
SerializationVersion 1.1.0.1
WSManStackVersion 3.0
> (Get-Module -ListAvailable PSScriptAnalyzer).Version | ForEach-Object { $_.ToString() }
1.24.0