Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

Provide machine-friendly, streaming output format #2581

Open
3 tasks done
davidmatson opened this issue Nov 20, 2024 · 14 comments
Open
3 tasks done

Provide machine-friendly, streaming output format #2581

davidmatson opened this issue Nov 20, 2024 · 14 comments
Labels

Comments

@davidmatson
Copy link
Contributor

Checklist

Summary of the feature request

Our ES testing infrastructure has its own reporting mechanism, and we've previously integrated with many other test frameworks, including GoogleTest, Catch2, Boost.Test, VSTest / xUnit.Net / NUnit / MSTest. Most of these frameworks provide a built-in output format that is streamed (provides the data as the tests are running) as well as programmatically-processible (XML written to stdout for Catch2 and Boost.Test, URL-like lines written to a socket for GoogleTest). Could Pester provide such an output format as well?

This would provide a mechanism that could be used to adapt Pester test results to any other format, while the Pester tests are running. Runners such as VS Code might also make use of this format as a stable way of presenting results, rather than needing the currently-non-public add-in mechanism.

How should it work?

Invoke-Pester (or the configuration object) provides a way to specify that the output mode is machine-friendly (rather than the default of human-friendly). Perhaps a new Output.Mode on PesterConfiguration, with values of 'Human' (default) and 'Machine' (new), with machine output looking something like this (inspired by the GoogleTest machine-friendly output format):

pester_streaming_protocol_version=1.0
event=PesterStart&version=6.0.0
event=DiscoveryStart
event=Discovered&path=C:\t\Planets\Get-Planet.Tests.ps1
event=DiscoveryEnd
event=RunStart&path=C:\t\Planets\Get-Planet.Tests.ps1
event=DescribeStart&name=Get-Planet
event=ItStart&name=Given%20no%20parameters,%20it%20lists%20all%208%20planets
event=ItEnd&result=fail&duration=40ms&message=The%20term...&file=C:\t\Planets\Get-Planet.Tests.ps1&line=7
event=DescribeEnd
event=RunEnd
@davidmatson
Copy link
Contributor Author

Other options that could work for the same scenario:

XML to stdout:
Parsing streaming XML (no DOM, as the file isn't fully written yet) is harder than the format above, but Catch2 and Boost.Test use this mechanism, and it could work.

Add-in:
This requires getting the caller involved more in the execution environment than passing a switch and consuming a programmatic format from stdout. We had to use this approach for VSTest, and it was much less flexible for execution environment integration.

@davidmatson
Copy link
Contributor Author

Related to #550 and #447 - this might work for both of those cases as well as others.

@davidmatson
Copy link
Contributor Author

@nohwnd - thoughts on this feature? We'd be interested in working on an implementation draft, if there's agreement that this would be a good idea.

@nohwnd
Copy link
Member

nohwnd commented Dec 12, 2024

I can't promise anything right now, I work on v6 when I can, and my time is limited.

This does not look like a feature that would be usable to everyone. Do you see some uses for this that would allow us to support some new exciting thing, rather than just your own reporting mechanism? e.g better ide integration in vscode.

@fflaten
Copy link
Collaborator

fflaten commented Dec 13, 2024

Also related to #2021 so you could add or replace with custom output.

@davidmatson
Copy link
Contributor Author

davidmatson commented Dec 19, 2024

@nohwnd - yes, I'd imagine VSCode integration could use this rather than the currently-unsupported hook that it's currently using to show progress in the IDE as tests are executing. Thoughts?

@cdhunt
Copy link
Contributor

cdhunt commented Jan 8, 2025

@nohwnd Could you emit an Event at the end of Invoke-Block that has $block as the data? I'm looking to try and do something similar to this xUnit Otel instrumentation. That would allow a user access to subscribe to the raw object and should provide some useful functionality for IDEs - though I don't know how the VSCode Pester integrations work currently.

@cdhunt
Copy link
Contributor

cdhunt commented Jan 8, 2025

I did a crude POC.

Test

Describe "Pester Otel integration" {
    It "fake test" {
        $true | Should -BeTrue
        New-Event -SourceIdentifier Pester -Sender $____Pester.CurrentBlock.Name -MessageData $____Pester.CurrentBlock
    }
}

Data

$Events = Get-Event -SourceIdentifier Pester
$Events[-1].MessageData | select Name, Passed

Name                    Passed
----                    ------
Pester Otel integration   True

@nohwnd
Copy link
Member

nohwnd commented Jan 8, 2025 via email

@cdhunt
Copy link
Contributor

cdhunt commented Jan 8, 2025

There's a plugin subsystem?

@nohwnd
Copy link
Member

nohwnd commented Jan 8, 2025 via email

@nohwnd
Copy link
Member

nohwnd commented Jan 8, 2025 via email

@cdhunt
Copy link
Contributor

cdhunt commented Jan 8, 2025

That would be simple enough to adapt for my purposes.

@nohwnd
Copy link
Member

nohwnd commented Jan 8, 2025 via email

Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
Projects
None yet
Development

No branches or pull requests

4 participants