-
Notifications
You must be signed in to change notification settings - Fork 25
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
Human formatted Apex test report shouldn't display individual PASSING test methods #243
Comments
@mshanemc -- @k-capehart was so kind as to do the thing with PR#377 -- what is the process for getting this change considered? It could be viewed as a breaking change .. but it's been repeated a million times over that human readable output should not be relied on to remain consistent .. so I think this would qualify as a permitted change. |
This particular change in the node library is not breaking because I've defaulted the However, if we do add a |
@k-capehart and @daveespo - Improving Apex test results is something I'd like to get onto our near-term roadmap. Some of the suggestions I've seen include adding a While our stated policy is that we reserve the right to change human-readable output at any time, the importance of Apex test results in automation use cases makes me want to tread carefully. All the suggestions to improve Apex test results that I've seen would result in significant changes to human-readable output, and would be best delivered with matching changes to JSON output. So, if we're going to take a "breaking changes" hit, I'd like to solve as much as we can in the process. To that end, I plan to start a GitHub discussion to consolidate existing feature requests and solicit new ideas. The CLI team will turn that into a design proposal for final feedback. Then, we'll build the changes and put the new behavior behind an environment variable for a period of time while the old behavior is deprecated. FYI: @mshanemc |
@VivekMChawla Thanks for the reply. I appreciate the transparency as always. I'll keep an eye out for that discussion post and for ways to help so we can get this out sooner rather than later. |
@daveespo Just updating you. This is just pending the following PR: salesforcecli/plugin-apex#504 Once its approved then this should be good to go! |
Linking to forcedotcom/cli#2872 for reference |
Yep, I've been watching .. fingers-crossed on quick approval and merge ;-) |
salesforcecli/plugin-apex#553 was merged to main, which contains the commits from my PR. Should be good to go in the next week or two for the next release! 🚀 |
@k-capehart I haven't used yet |
Hey @avesolovksyy , I completely agree. I would recommend opening an Issue in forcedotcom/cli to request this feature be added to |
This issue has been fixed in release 2.56.7 (August 28, 2024). |
Some of our projects have upwards of 2000 test methods. When we run
force:apex:test:run -w 50 -r human
in our CI/CI scripts and there is a single failed test method, we see 1999 lines of "Pass" and we have to painfully try to hunt down the single test method with the Fail status.In a prior version of the CLI, it would only report test failures which meant that for a 100% successful test run, it would only print the summary block with the outcome of the test run -- there's no need to print 2000 lines of noise in the log file telling me that each test method was successful
Something changed at some point within the past few months (basically at the point where passing
-r human
was required in order to see the detail of the test failures)Solution 1 - silence test methods that Pass by default
Pros: This is the way it should be and the way just about every other test reporter I've ever seen in my life has worked. Users that want all Passing test methods to be enumerated can use the
--verbose
existing command line argument to enable.Cons: This will change existing behavior
Solution 2 - Add a command line argument (eg.
--not-so-verbose
) to silence Pass test methods from the outputPros: Preserves existing behavior
Cons: Requires updating existing CI/CD scripts to pass this new flag. Also, documenting and naming the flag to make it somehow compatible with the
--verbose
documentation could be challenging.Additional context
Also, it should be noted that in the Summary table, the "Pass rate" is a whole number (presumably using half-up rounding logic) which results in incongruous outcome:
Which is it? A failure or 100% pass? What actually happened is one test method failed but that still resulted in the "99.9%" getting rounded up to 100%
Version that I'm running
The text was updated successfully, but these errors were encountered: