How to Write-Verbose from Invoke-Command?

George Mauer picture George Mauer · Apr 24, 2013 · Viewed 8.2k times · Source

In powershell

Write-Verbose and the -Verbose flag are used to provide verbose information when commands are run in verbose mode. I am running some scripts remotely and would like to capture the verbose output output. However, Invoke-Command seems to not capture the verbose channel.

PS:> Invoke-Command -ComputerName MY-COMPUTERNAME -Verbose { Write-Verbose "blah" }
PS:>

How do I capture verbose output when running remote scripts?

Answer

Andy picture Andy · Aug 7, 2013

Best thing I think you could do is create a function that has [CmdletBinding()] so it supports the -verbose switch. Then you would be able to capture the verbose state of the local function using the local $VerbosePreference and pass it along in the invoke command. This will only work in Powershell 3.0 and higher, since you will need to use the $Using scope modifier.

Function write-blah{
[CmdletBinding()]
Param()
Invoke-Command -ComputerName MY-COMPUTERNAME  {$VerbosePreference=$Using:VerbosePreference; Write-Verbose "blah" }
}

Then you would call your function like this.

Write-Blah -verbose

In testing this has worked for me. I believe your function must support parameters, hence the empty Param() block.