-
Notifications
You must be signed in to change notification settings - Fork 235
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
BXL: get stdout/stderr of actions.run()
#760
Comments
You should think of BXL a bit like a thing that writes a temporary .bzl + BUCK file pair, and immediately executes a build on it. There is no such thing in BUCK / bzl files as reading the output files, and so there is no such thing in BXL either. (A nice analogy is a control plane for a networking device. You never get to read the packets. You only get to write routing rules, and your rules are submitted to a big box that runs them at its leisure. In Buck that big box is Buck driving a potentially remote executor. Stdout is less simple when it could be halfway across the world, so you have to describe to Buck how it's going to get that stdout back.) Wrapper scripts are pretty much the way to go every time. It's mildly inconvenient that you have to write your wrapper in a separate file / language, but the alternative would be for Buck to add a bunch of Python-esque IO tools to the starlark context, which would be a huge waste of time. I guess being able to dump a file to stdout would be neat (and it would mean BXL could emulate In any case, typing out a |
What do you mean for "output" here? The stdout of a |
@cormacrelf
But Buck2 already captures that stdout and prints it in the case of failures, so it already supports a subset of this functionality.
Can you elaborate? I don't immediately see why we would need a lot of IO tools, or what would be so challenging about exposing stdout/stderr to the user. At least, having a convenient way of forwarding stdout upon success (like it is already the case when an action fails) seems perfectly doable, and returning a struct with
But in this case, we do not have a way of routing stdout/stderr to the user, which is the core problem that I have. Being able to inspect them would be nice and helpful in some cases, but that's not the main focus here (especially if there are technical limitations that I do not understand). Regarding wrapper scripts, I am really hoping that #86 will get some traction. I would love for
I have already warned some of my users that we might need to do this (and probably will have to at least at first), and the reaction was strongly negative. Buck2 can already print the stdout of actions when they fail, this seems like an arbitrary limitation, and we expect the use case of "use Buck2 to drive some underlying tools and forward their output" to be very common. Besides, BXL has nice handling of command line arguments by default, it would be a shame to have to essentially not take advantage of that by having to overlay command line parsing and generation, for every script. Another argument against wrapper scripts is that they are not hermetic, so past a certain size, we need to rely on non-hermetic scripts that call a hermetic build system, and need to solve the exact problems why we wanted to use @Nero5023 I mean the stdout/stderr of |
stdout/stderr are considered as the side effects here and relying on stdout/stderr of an action is not recommened. Each action is like pure function. Args are inputs, output are output artifacts. Each action can be cached, cache keys are the inputs and the cached outputs are the output artifacts. stdout/stderr can not be cached. We often have a wrapper for the bxl script internally. We always have a buck2 target wrap that script, so that we can call it by |
Sort of, if I redirect them to an output file, they become an artifact like any other, and Buck could handle them the same way. But I'm willing to concede that this would add complexity.
This is interesting, I briefly considered that, but it seemed overengineered to me, and it seems like it would have bad ergonomics (having to handle argument management at various levels instead of one). I'm not thrilled about it, but I'll consider it again if it ends up being a better user experience. Do we agree that it is not ideal though? In your experience, what kind of issues do you get (if any) for this "buck within buck" setup? I have experienced (temporary) lock ups when running commands in parallel, so nesting them sounds scary to me. |
It's not buck within buck. |
Yeah, of course it is not ideal. I am also frustrated that at last I need have a wrapper for the bxl script I wrote. And handling args converting is tedious. We don't have a plan for now to solve this issue, but I will consider it in next half. Yeah, as @cormacrelf said. It is not buck within buck.
You can different isolation dir in this case
|
Thanks for the clarification about buck within buck and |
Is it possible to get the output of an action to print it out via
ctx.output.print()
?The best I could do was redirect stdout to a declared output and print out its path, but since there is no way to read that file from BXL (that I know of anyway), this requires the user to
cat
out this file (potentially via a wrapper script), which is a poor UX.The text was updated successfully, but these errors were encountered: