-
Notifications
You must be signed in to change notification settings - Fork 842
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
Avoid hiding output due only to parallelism #642
Comments
I think this is the same as #426 (which, strangely enough, has the same digits as this issue number). Can you confirm that that's the same goal as what you have here? |
Ah, yes! Same goal. Interesting though how many different policies/algorithms there are in this area. You weren't happy with the algorithm described on #426. Do you have a preferred option of those above. Perhaps (4)? |
It's not so much the algorithm as the complexity in implementation. I think it's fair to say that I'm just concerned about introducing lots of code, especially code that has the potential to exhaust memory with log output. For me personally, this outweighs the benefits of putting all output on the console, but I can understand others feeling differently. If you're OK with it: let's close out this issue and continue the conversation on #426. If it's not too disruptive to the codebase and can be turned on and off, I'll be OK with most implementation approaches. |
Relevant PR: #4097 |
In a mailing list post, it was mentioned that
stack test
hides output from parallel tests to prevent interleaving.Indeed, this was the traditional behavior of cabal -- to link parallelism to output verbosity. But this always annoyed me; rather, I argue that these are orthogonal configuration options that should be controlled by separate flags. In particular there are good ways to handle the concurrent output that do not require ugly interleaving.
[tag]
, and possibly buffer it for a second or more so that it gets grouped into "chunks" rather than interleaved lines or characters. This option offers an upper-bound on delay to any individual output line.io-streams
package.I see that
stack
already depends on conduit. This seems like the kind of issue that could be solved generally, once and for all, at the conduit level. But, that presumes that stdout/stderr are captured and routed in all the right places.I haven't read much of the code, but having a look at Execute.hs, it looks like the notion of parallel actions includes exception handling but not output streams.
On the other hand,
Read.hs
contains machinery for capturing output of sub-processes, andtry/readProcessStdout
are called in various places. But actions like running tests are handled by the underlyingCabal
library, right? Does that mean their output can't be managed easily without changing Cabal?Anyway, if a capability for generally handling output stream muxing/demuxing would be a desired feature I'd like to lend a hand with this.
The text was updated successfully, but these errors were encountered: