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

Improve gpg subprocess timeout and stop using custom process module #502

Merged
merged 5 commits into from
Feb 10, 2023

Conversation

lukpueh
Copy link
Member

@lukpueh lukpueh commented Feb 9, 2023

Description of the changes being introduced by the pull request:

gpg interface function to sign and export public keys now have an optional subprocess timeout. This means, users no longer need to patch a global in order to configure this value. Moreover, the default timeout is now defined inside the gpg subpackage, and increased to 10.
--> The should reduce test failures on slow runners, and makes it more intuitive to override the default.

Internally the gpg subpackage now no longer uses the custom subprocess wrapper, which provides very little benefit over calling directly into stdlib subprocess.
--> This is in preparation for deprecation of the process module

see commit message for details

Please verify and check that the pull request fulfils the following requirements:

  • The code follows the Code Style Guidelines
  • Tests have been added for the bug fix or new feature
  • Docs have been added for the bug fix or new feature

@lukpueh lukpueh force-pushed the gpg-subprocess-timeout branch from 5845eba to 6199f46 Compare February 9, 2023 13:22
Copy link
Collaborator

@jku jku left a comment

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

The process of building strings just to then split them with shlex seems a little unusual... but I can see how some of the option handling would need more refactoring if you wanted to fix that. LGTM.

Comment on lines 37 to 38
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
Copy link
Collaborator

Choose a reason for hiding this comment

The reason will be displayed to describe this comment to others. Learn more.

Suggested change
stdout=subprocess.PIPE,
stderr=subprocess.PIPE,
capture_output=True,

This nit might not get you back to a one liner, but it is shorter... I think this applies to all subprocess.run() calls in the pr

@lukpueh
Copy link
Member Author

lukpueh commented Feb 10, 2023

The process of building strings just to then split them with shlex seems a little unusual... but I can see how some of the option handling would need more refactoring if you wanted to fix that.

Exactly. I'd have to refactor how keyarg and homearg are passed, e.g.:

f"{gpg_command()} --detach-sign --digest-algo SHA256 {keyarg} {homearg}"

Also, I wasn't sure how we want to treat gpg commands specified in an environment variable. Maybe they include some custom flag, which would behave differently if we stopped using shlex. But maybe that's okay. 🤷

I mentioned in the commit message that I'm just trying to replicate the original behavior. I can also add a comment in the code.

@jku
Copy link
Collaborator

jku commented Feb 10, 2023

I can also add a comment in the code.

Not strictly needed IMO, I think the option and env var handling issues should be pretty obvious to anyone who does try to improve this

Prior to this commit, settings.SUBPROCESS_TIMEOUT=3 (seconds) was
used as default and also to configure timeouts for any subprocess
spawned via the securesystemslib process interface, including
running the gpg command to sign, export keys and check version.

The small timeout regularly lead to test failures on slow test
runners. Furthermore, configuring the timeout via global is bad
practice and error-prone (see secure-systems-lab#219, secure-systems-lab#345).

This patch defines a custom constant, to be used only for gpg
subprocesses and increases its value to 10 seconds.

To override this default, an optional timeout argument will be
added to relevant gpg interfaces in a subsequent commit.

Signed-off-by: Lukas Puehringer <[email protected]>
Prior to this change, configuring timeouts for gpg required
patching the default-specifying global. This is bad practice and
error-prone (see secure-systems-lab#219, secure-systems-lab#345).

To allow overriding default timeout in an intuitive way, this commit
adds optional arguments to the relevant gpg interface functions.

Signed-off-by: Lukas Puehringer <[email protected]>
@lukpueh lukpueh force-pushed the gpg-subprocess-timeout branch from 6199f46 to f23d800 Compare February 10, 2023 08:35
This commit replaces calls to the custom process.run function, in
favor of the stdlib subprocess.run.

The former is a very thin wrapper around the latter, which was more
useful when we still needed Py2/3 case-handling. Which is not the
case anymore.

NOTE: This commit replicates the prior behavior, most notably the
following subprocess.run arguments:
- *popenargs: we still use shlex.split to turn the full command
              string into a list
- check

Signed-off-by: Lukas Puehringer <[email protected]>
@lukpueh lukpueh force-pushed the gpg-subprocess-timeout branch from f23d800 to ac413ba Compare February 10, 2023 08:40
@lukpueh
Copy link
Member Author

lukpueh commented Feb 10, 2023

CI passes. Merging...

@lukpueh lukpueh merged commit e5f2296 into secure-systems-lab:master Feb 10, 2023
lukpueh added a commit to lukpueh/securesystemslib that referenced this pull request Feb 10, 2023
This module was originally developed in in-toto and transferred to
securesystemslib in secure-systems-lab#174, primarily as Py2/Py3-agnostic wrapper
around stdlib's `subprocess.run`, to to execute `gpg`.
In secure-systems-lab#502 we switched to using `subprocess.run` directly.

Another wrapper around `subprocess.run`, provided by the module,
allows capturing standard streams but still write them to a
terminal. It was developed as specific `in-toto-run` feature and
does not need to be public API in sslib.  in-toto/in-toto#544 moves
the function back to in-toto.

closes secure-systems-lab#345,
transfers secure-systems-lab#337 (to in-toto)

Signed-off-by: Lukas Puehringer <[email protected]>
lukpueh added a commit to lukpueh/securesystemslib that referenced this pull request Feb 10, 2023
This module was originally developed in in-toto and transferred to
securesystemslib in secure-systems-lab#174, primarily as Py2/Py3-agnostic wrapper
around stdlib's `subprocess.run`, to run the `gpg` command. In secure-systems-lab#502
we switched to using `subprocess.run` directly.

Another wrapper around `subprocess.run`, provided by the module,
allows capturing standard streams AND write them to a terminal. It
was developed as specific `in-toto-run` feature and does not need
to be public API in sslib. in-toto/in-toto#544 moves the function
back to in-toto.

closes secure-systems-lab#345,
transfers secure-systems-lab#337 (to in-toto)

Signed-off-by: Lukas Puehringer <[email protected]>
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

2 participants