From 71c5b036e83780568332e0d9219852845d2cc9de Mon Sep 17 00:00:00 2001 From: Oscar Calvo Date: Tue, 3 Dec 2024 11:12:24 -0800 Subject: [PATCH] Fix a bug where Pester fails to produce report if an error message contains VT sequences --- src/functions/TestResults.NUnit3.ps1 | 16 +++++++++++----- 1 file changed, 11 insertions(+), 5 deletions(-) diff --git a/src/functions/TestResults.NUnit3.ps1 b/src/functions/TestResults.NUnit3.ps1 index 75db6f9cc..e5476b5f4 100644 --- a/src/functions/TestResults.NUnit3.ps1 +++ b/src/functions/TestResults.NUnit3.ps1 @@ -538,7 +538,8 @@ function Write-NUnit3TestCaseAttributes { $XmlWriter.WriteAttributeString('asserts', '1') # required attr, so hardcoding 1:1 per testcase } -function Write-NUnit3OutputElement ($Output, [System.Xml.XmlWriter] $XmlWriter) { +function Format-CDataString ($Output) { + # The characters in the range 0x01 to 0x20 are invalid for CData # (with the exception of the characters 0x09, 0x0A and 0x0D) # We convert each of these using the unicode printable version, @@ -572,8 +573,13 @@ function Write-NUnit3OutputElement ($Output, [System.Xml.XmlWriter] $XmlWriter) } $outputString = $o -join [Environment]::NewLine + return $outputString +} + + +function Write-NUnit3OutputElement ($Output, [System.Xml.XmlWriter] $XmlWriter) { $XmlWriter.WriteStartElement('output') - $XmlWriter.WriteCData($outputString) + $XmlWriter.WriteCData((Format-CDataString $output)) $XmlWriter.WriteEndElement() } @@ -585,12 +591,12 @@ function Write-NUnit3FailureElement ($TestResult, [System.Xml.XmlWriter] $XmlWri $XmlWriter.WriteStartElement('failure') $XmlWriter.WriteStartElement('message') - $XmlWriter.WriteCData($result.FailureMessage) + $XmlWriter.WriteCData((Format-CDataString $result.FailureMessage)) $XmlWriter.WriteEndElement() # Close message if ($result.StackTrace) { $XmlWriter.WriteStartElement('stack-trace') - $XmlWriter.WriteCData($result.StackTrace) + $XmlWriter.WriteCData((Format-CDataString $result.StackTrace)) $XmlWriter.WriteEndElement() # Close stack-trace } @@ -604,7 +610,7 @@ function Write-NUnitReasonElement ($TestResult, [System.Xml.XmlWriter] $XmlWrite if ($result.FailureMessage) { $XmlWriter.WriteStartElement('reason') $XmlWriter.WriteStartElement('message') - $XmlWriter.WriteCData($result.FailureMessage) + $XmlWriter.WriteCData((Format-CDataString $result.FailureMessage)) $XmlWriter.WriteEndElement() # Close message $XmlWriter.WriteEndElement() # Close reason }