Поделиться через


ShouldProcess

Уровень серьезности: предупреждение

Описание

Если командлет объявляет SupportsShouldProcess атрибут, он также должен вызываться ShouldProcess. Нарушение — это любая функция, которая объявляет SupportsShouldProcess атрибут, но не вызывает ShouldProcess или не вызывает ShouldProcess , но не объявляет SupportsShouldProcess.

Дополнительные сведения см. в следующих статьях:

Как

Чтобы устранить нарушение этого правила, вызовите ShouldProcess метод, когда командлет объявляет SupportsShouldProcess атрибут. Или добавьте SupportsShouldProcess аргумент атрибута при вызове ShouldProcess.

Пример

Неправильно

function Set-File
{
    [CmdletBinding(SupportsShouldProcess=$true)]
    Param
    (
        # Path to file
        [Parameter(Mandatory=$true)]
        $Path
    )
    'String' | Out-File -FilePath $Path
}

Правильно

function Set-File
{
    [CmdletBinding(SupportsShouldProcess=$true)]
    Param
    (
        # Path to file
        [Parameter(Mandatory=$true)]
        $Path,

        [Parameter(Mandatory=$true)]
        [string]$Content
    )

    if ($PSCmdlet.ShouldProcess($Path, ("Setting content to '{0}'" -f $Content)))
    {
        $Content | Out-File -FilePath $Path
    }
    else
    {
        # Code that should be processed if doing a WhatIf operation
        # Must NOT change anything outside of the function / script
    }
}