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

add VERBOSE log level for -v #9450

Merged
merged 2 commits into from
Jun 11, 2021
Merged

add VERBOSE log level for -v #9450

merged 2 commits into from
Jun 11, 2021

Conversation

minrk
Copy link
Contributor

@minrk minrk commented Jan 13, 2021

adds VERBOSE custom log level between DEBUG and INFO, used when -v is given. Now require -vv to enable full debug output.

The output of -vv is unchanged, but -v, previously synonymous with -vv, now includes much less:

These were mainly selected by tests that failed due to the change - some were changed to use -vv, others changed the log level of the messages. It's possible more output should be moved to the new level, but in general, it should now be easier to select different output for -v and -vv since they correspond to different log levels.

alternative to #9447 and better, I think, because it maps consistent behavior to the CLI, which suggests that -v and -vv are different verbosity levels, which was not the case (except when competing with -q also being passed).

closes #9447

@minrk minrk mentioned this pull request Jan 13, 2021
3 tasks
@BrownTruck
Copy link
Contributor

Hello!

I am an automated bot and I have noticed that this pull request is not currently able to be merged. If you are able to either merge the master branch into this pull request or rebase this pull request against master then it will be eligible for code review and hopefully merging!

@BrownTruck BrownTruck added the needs rebase or merge PR has conflicts with current master label Feb 19, 2021
@minrk minrk force-pushed the custom-log-level branch from 10b6774 to 35ae59b Compare March 1, 2021 09:11
@pypa-bot pypa-bot removed the needs rebase or merge PR has conflicts with current master label Mar 1, 2021
adds VERBOSE custom log level between DEBUG and INFO

used when `-v` is given. Now require -vv to enable full debug output.

Messages can be logged with VERBOSE level to promote them to `-v` output instead of `-vv`
@pfmoore
Copy link
Member

pfmoore commented Jun 8, 2021

Closing and reopening to re-try CI.

I'm mildly bothered by the asymmetry between VERBOSE and the other log levels - could we not add a logger.verbose() method somehow, to make verbose calls look the same as other log levels?

@pfmoore pfmoore closed this Jun 8, 2021
@pfmoore pfmoore reopened this Jun 8, 2021
@uranusjr
Copy link
Member

uranusjr commented Jun 8, 2021

could we not add a logger.verbose() method somehow, to make verbose calls look the same as other log levels?

There’s logging.setLoggerClass() for this.

@uranusjr
Copy link
Member

uranusjr commented Jun 8, 2021

I’m also thinking maybe it would be easier to change every call that’s not included here to logger.trace() instead (level set to something like 5).

Comment on lines 32 to 28
def getLogger(name: str) -> VerboseLogger:
"""Wraps logging.getLogger in an appropriate type annotation"""
return cast(VerboseLogger, logging.getLogger(name))
Copy link
Member

Choose a reason for hiding this comment

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

I wonder if there is a better way to do this… Maybe supply a custom .pyi stub instead?

Copy link
Member

@pradyunsg pradyunsg Jun 11, 2021

Choose a reason for hiding this comment

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

No .pyi files please -- this is significantly easier to maintain than a separate stub file, and is fairly clear.

Copy link
Contributor Author

Choose a reason for hiding this comment

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

If you know how to do that, let me know! I spent a couple of hours trying to do just that, and can't figure it out. I find mypy super hard to work with.

@minrk
Copy link
Contributor Author

minrk commented Jun 11, 2021

Thanks for looking at this!

There’s logging.setLoggerClass() for this.

I've updated the PR to use setLoggerClass. It's a little tricky to satisfy mypy, since this changes the return type of logging.getLogger. I went with defining our own getLogger which actually does nothing, but it adds a cast to satisfy mypy. I couldn't think of a better way.

setLoggerClass must be called before any call to getLogger to ensure it has the desired effect, so I put it in its own utils._log.py (since utils.logging is too late, as it imports other modules which call getLogger themselves).

I did not do a systematic find/replace of logging.getLogger -> utils.logging.getLogger since there are only a few verbose log statements at this point, but I can if that's preferable.

I’m also thinking maybe it would be easier to change every call that’s not included here

I think I don't quite understand what you mean here. This PR changes 6 log statements from debug->verbose, while there are 83 not here that would need to change from debug->trace, if that's what you mean. Other than increasing the number of changes by an order of magnitude, nothing else would be different, right? That seems like a strictly larger, more complex change, unless I've misunderstood.

@minrk minrk force-pushed the custom-log-level branch 5 times, most recently from e596ed2 to da48d28 Compare June 11, 2021 09:57
loaded in pip._internals.__init__

must use utils.logging.getLogger to get the right type annotation
instead of logging.getLogger, despite no actual difference in behavior
@minrk minrk force-pushed the custom-log-level branch from da48d28 to c87af08 Compare June 11, 2021 09:59
Copy link
Member

@pradyunsg pradyunsg left a comment

Choose a reason for hiding this comment

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

I like this, it's a fairly easy win!

However, I do expect to see people complaining about the change in pip's output format without warnings and stuff. None the less, I can't think of any way to transition slowly and whatever we learn from rolling this change out can also help inform how we make other sweeping output related changes in the future. :)

@uranusjr
Copy link
Member

I think most complaints to pip -v is it is way too verbose. We can slowly change some of the logging to use verbose when people mention it. So while this would make some angry, I feel it’s necessary for benefits in the long run.

@pradyunsg
Copy link
Member

Thanks for all of your work on this @minrk! Much appreciated! ^>^

@minrk
Copy link
Contributor Author

minrk commented Jun 11, 2021

Thanks! Looking forward to using it.

@s0undt3ch
Copy link

This breaks every project that makes use of logging.setLoggerClass() if pip is installed, which, these days, why wouldn't it...

Please, only call init_logging() when pip is running, not at an __init__.py file....

@pfmoore
Copy link
Member

pfmoore commented Jul 26, 2021

The only way this can affect user code is if you import pip, which you should not be doing.

s0undt3ch added a commit to s0undt3ch/salt that referenced this pull request Jul 27, 2021
s0undt3ch added a commit to s0undt3ch/salt that referenced this pull request Jul 27, 2021
Ch3LL pushed a commit to saltstack/salt that referenced this pull request Jul 29, 2021
@pradyunsg
Copy link
Member

@s0undt3ch @Ch3LL please don't mention the issue in commits. It causes unnecessary noise.

garethgreenaway added a commit to saltstack/salt that referenced this pull request Jul 29, 2021
* Also pin the ``pip`` upgrade to be ``<21.2``

* Work around pypa/pip#9450

See pypa/pip#10212

Co-authored-by: Megan Wilhite <[email protected]>
Co-authored-by: Gareth J. Greenaway <[email protected]>
truzzon pushed a commit to truzzon/salt that referenced this pull request Aug 10, 2021
* Also pin the ``pip`` upgrade to be ``<21.2``

* Work around pypa/pip#9450

See pypa/pip#10212

Co-authored-by: Megan Wilhite <[email protected]>
Co-authored-by: Gareth J. Greenaway <[email protected]>
clrpackages pushed a commit to clearlinux-pkgs/salt that referenced this pull request Aug 18, 2021
Charles McMarrow (2):
      Delete 60571.fixed
      [3003.2] Add server alive (#60573)

Daniel A. Wozniak (22):
      Use Popen for VT
      Still allow shell True
      Drop shlex split
      Add crypto re-init
      Fix pre-commit
      Do not call close in isalive
      Skip tests not valid on windows
      Cleanup things that are not really needed
      We do not support irix
      Fix pre-commit
      Remove commented out lines
      Add changelog for #60504
      Fix pre-commit issues
      pyupgrade does not remove six imports
      Fix OSErrors in some test cases
      Remove un-needed args processing
      Make state_running test more reliable
      Address leaks in fileserver caused by git backends
      Remove un-used import
      Fix warts caused by black version
      Add changelog
      We don't need two changelogs

David Murphy (2):
      Ignore configuration for 'enable_fqdns_grains' for AIX, Solaris and Juniper
      Added changelog

Gareth J. Greenaway (4):
      Removing tmpfs from Fedora 33.
      Update the external ipaddress to the latest 3.9.5 version which has some security fixes.  Updating the compat.p to use the vendored version if the python version is below 3.9.5 and only run the test_ipaddress.py tests if below 3.9.5.
      Adding changelog
      Requested changes.

Joe Eacott (1):
      Let Mac OS Mojave run for 8 hours to avoid timeout

Pedro Algarvio (3):
      Also pin the ``pip`` upgrade to be ``<21.2``
      Work around pypa/pip#9450
      Drop six and Py2

ScriptAutomate (2):
      Changelog for 3003.2
      Man pages update for 3003.2

cmcmarrow (12):
      Add shh_timeout to ssh_kwargs
      move to with blocks
      one with block
      reight crypto
      add back test file
      add changelog
      change log file number
      add m2crypt support
      only check m2crpto
      add back log
      add newline
      add newline for log file

krionbsd (1):
      Remove FreeBSD-12.2
dwoz pushed a commit to dwoz/salt that referenced this pull request Sep 12, 2021
* Also pin the ``pip`` upgrade to be ``<21.2``

* Work around pypa/pip#9450

See pypa/pip#10212

Co-authored-by: Megan Wilhite <[email protected]>
Co-authored-by: Gareth J. Greenaway <[email protected]>
garethgreenaway added a commit to saltstack/salt that referenced this pull request Sep 23, 2021
* Merge 3002.6 bugfix changes (#59822)

* Pass `CI_RUN` as an environment variable to the test run.

This allows us to know if we're running the test suite under a CI
environment or not and adapt/adjust if needed

* Migrate `unit.setup` to PyTest

* Backport ae36b15 just for test_install.py

* Only skip tests on CI runs

* Always store git sha in _version.py during installation

* Fix PEP440 compliance.

The wheel metadata version 1.2 states that the package version MUST be
PEP440 compliant.

This means that instead of `3002.2-511-g033c53eccb`, the salt version
string should look like `3002.2+511.g033c53eccb`, a post release of
`3002.2` ahead by 511 commits with the git sha `033c53eccb`

* Fix and migrate `tests/unit/test_version.py` to PyTest

* Skip test if `easy_install` is not available

* We also need to be PEP440 compliant when there's no git history

* Allow extra_filerefs as sanitized kwargs for SSH client

* Fix regression on cmd.run when passing tuples as cmd

Co-authored-by: Alexander Graul <[email protected]>

* Add unit tests to ensure cmd.run accepts tuples

* Add unit test to check for extra_filerefs on SSH opts

* Add changelog file

* Fix comment for test case

* Fix unit test to avoid failing on Windows

* Skip failing test on windows

* Fix test to work on Windows

* Add all ssh kwargs to sanitize_kwargs method

* Run pre-commit

* Fix pylint

* Fix cmdmod loglevel and module_names tests

* Fix pre-commit

* Skip ssh tests if binary does not exist

* Use setup_loader for cmdmod test

* Prevent argument injection in restartcheck

* Add changelog for restartcheck fix

* docs_3002.6

* Add back tests removed in merge

Co-authored-by: Pedro Algarvio <[email protected]>
Co-authored-by: Megan Wilhite <[email protected]>
Co-authored-by: Bryce Larson <[email protected]>
Co-authored-by: Pablo Suárez Hernández <[email protected]>
Co-authored-by: Alexander Graul <[email protected]>
Co-authored-by: Frode Gundersen <[email protected]>

* Remove glance state module in favor of glance_image

* update wording in changelog

* bump deprecation warning to Silicon.

* Updating warnutil version to Phosphorous.

* Update salt/modules/keystone.py

Co-authored-by: Megan Wilhite <[email protected]>

* Check $HOMEBREW_PREFIX when linking against libcrypto

When loading `libcrypto`, Salt checks for a Homebrew installation of `openssl`
at Homebrew's default prefix of `/usr/local`. However, on Apple Silicon Macs,
Homebrew's default installation prefix is `/opt/homebrew`. On all platforms,
the prefix is configurable.  If Salt doesn't find one of those `libcrypto`s,
it will fall back on the un-versioned `/usr/lib/libcrypto.dylib`, which will
cause the following crash:

    Application Specific Information:
    /usr/lib/libcrypto.dylib
    abort() called
    Invalid dylib load. Clients should not load the unversioned libcrypto dylib as it does not have a stable ABI.

This commit checks $HOMEBREW_PREFIX instead of hard-coding `/usr/local`.

* Add test case

* Add changelog for 59808

* Add changelog entry

* Make _find_libcrypto fail on Big Sur if it can't find a library

Right now, if `_find_libcrypto` can't find any externally-managed versions of
libcrypto, it will fall back on the pre-Catalina un-versioned system libcrypto.
This does not exist on Big Sur and it would be better to raise an exception
here rather than crashing later when trying to open it.

* Update _find_libcrypto tests

This commit simplifies the unit tests for _find_libcrypto by mocking out the
host's filesystem and testing the common libcrypto installations (brew, ports,
etc.) on Big Sur. It simplifies the tests for falling back on system versions
of libcrypto on previous versions of macOS.

* Fix description of test_find_libcrypto_with_system_before_catalina

* Patch sys.platform for test_rsax931 tests

* modules/match: add missing "minion_id" in Pillar example

The documented Pillar example for `match.filter_by` lacks the `minion_id` parameter. Without it, the assignment won't work as expected.
- fix documentation
- add tests:
  - to prove the misbehavior of the documented example
  - to prove the proper behaviour when supplying `minion_id`
  - to ensure some misbehaviour observed with compound matchers doesn't occur

* Fix for issue #59773

- When instantiating the loader grab values of grains and pillars if
  they are NamedLoaderContext instances.
- The loader uses a copy of opts.
- Impliment deepcopy on NamedLoaderContext instances.

* Add changelog for #59773

* _get_initial_pillar function returns pillar

* Fix linter issues

* Clean up test

* Bump deprecation release for neutron

* Uncomment Sulfur release name

* Removing the _ext_nodes deprecation warning and alias.

* Adding changelog.

* Renaming changelog file.

* Update 59804.removed

* Initial pass at fips_mode config option

* Fix pre-commit

* Fix tests and add changelog

* update docs 3003

* update docs 3003 - newline

* Fix warts in changelog

* update releasenotes 3003

* add ubuntu-2004-amd64 m2crypto pycryptodome and tcp tests

* add distro_arch

* changing the cloud platforms file missed in 1a9b7be

* Update __utils__ calls to import utils in azure

* Add changelog for 59744

* Fix azure unit tests and move to pytest

* Use contextvars from site-packages for thin

If a contextvars package exists one of the site-packages locations use
it for the generated thin tarball. This overrides python's builtin
contextvars and allows salt-ssh to work with python <=3.6 even when the
master's python is >3.6 (Fixes #59942)

* Add regression test for #59942

* Add changelog for #59942

* Update filemap to include test_py_versions

* Fix broken thin tests

* Always install the `contextvars` backport, even on Py3.7+

Without this change, salt-ssh cannot target systems with Python <= 3.6

* Use salt-factories to handle the container. Don't override default roster

* Fix thin tests on windows

* No need to use warn log level here

* Fix getsitepackages for old virtualenv versions

* Add explicit pyobjc reqs

* Add back the passthrough stuff

* Remove a line so pre-commit will run

* Bugfix release docs

* Bugfix release docs

* Removing pip-compile log files

* Bump requirements to address a few security issues

* Address traceback on macOS

```
Traceback (most recent call last):
  File "setup.py", line 1448, in <module>
    setup(distclass=SaltDistribution)
  File "/Users/jenkins/setup-tests/.venv/lib/python3.7/site-packages/setuptools/__init__.py", line 153, in setup
    return distutils.core.setup(**attrs)
  File "/opt/salt/lib/python3.7/distutils/core.py", line 108, in setup
    _setup_distribution = dist = klass(attrs)
  File "setup.py", line 1068, in __init__
    self.update_metadata()
  File "setup.py", line 1074, in update_metadata
    attrvalue = getattr(self, attrname, None)
  File "setup.py", line 1182, in _property_install_requires
    install_requires += _parse_requirements_file(reqfile)
  File "setup.py", line 270, in _parse_requirements_file
    platform.python_version(), _parse_op(op), _parse_ver(ver)
  File "setup.py", line 247, in _check_ver
    return getattr(operator, "__{}__".format(op))(pyver, wanted)
  File "/opt/salt/lib/python3.7/distutils/version.py", line 46, in __eq__
    c = self._cmp(other)
  File "/opt/salt/lib/python3.7/distutils/version.py", line 337, in _cmp
    if self.version < other.version:
TypeError: '<' not supported between instances of 'str' and 'int'
```

* Replace `saltstack.com` with `saltproject.io` on URLs being tested

* Add back support to load old entrypoints by iterating instead of type checking

Fixes #59961

* Fix issue #59975

* Fix pillar serialization for jinja #60083

* Fix test

* Add changelog for #60083

* Update changelog and release for 3003.1

* Remove the changelog source refs

* Add connect to IPCMessageSubscriber's async_methods

Fixes #60049 by making sure an IPCMessageSubscriber that is wrapped by
SyncWrapper has a connect method that runs the coroutine rather than
returns a fugure.

* Add changelog for #60049

* Update 60049.fixed

* Fix coroutine spelling error

Co-authored-by: Wayne Werner <[email protected]>

* IPC on windows cannot use socket paths

Fixes #60298

* Update Jinja2 and lxml due to security related bugfix releases

Jinja2
------

CVE-2020-28493
moderate severity
Vulnerable versions: < 2.11.3
Patched version: 2.11.3

This affects the package jinja2 from 0.0.0 and before 2.11.3. The ReDOS vulnerability of the regex is mainly due to the sub-pattern [a-zA-Z0-9.-]+.[a-zA-Z0-9.-]+ This issue can be mitigated by Markdown to format user content instead of the urlize filter, or by implementing request timeouts and limiting process memory.

lxml
----

CVE-2021-28957
moderate severity
Vulnerable versions: < 4.6.3
Patched version: 4.6.3

An XSS vulnerability was discovered in the python lxml clean module versions before 4.6.3. When disabling the safe_attrs_only and forms arguments, the Cleaner class does not remove the formaction attribute allowing for JS to bypass the sanitizer. A remote attacker could exploit this flaw to run arbitrary JS code on users who interact with incorrectly sanitized HTML. This issue is patched in lxml 4.6.3.

* fix github actions jobs on branch until bullseye comes out

* Upgrade to `six==1.16.0` to avoid problems on CI runs

```
13:59:02  nox > Session invoke-pre-commit was successful.
13:59:02  nox > Running session invoke-pre-commit
13:59:02  nox > pip install --progress-bar=off -r requirements/static/ci/py3.7/invoke.txt
13:59:02  Collecting blessings==1.7
13:59:02    Using cached blessings-1.7-py3-none-any.whl (18 kB)
13:59:02  Collecting invoke==1.4.1
13:59:02    Using cached invoke-1.4.1-py3-none-any.whl (210 kB)
13:59:02  Collecting pyyaml==5.3.1
13:59:02    Using cached PyYAML-5.3.1.tar.gz (269 kB)
13:59:02  Collecting six==1.15.0
13:59:02    Using cached six-1.15.0-py2.py3-none-any.whl (10 kB)
13:59:02  Building wheels for collected packages: pyyaml
13:59:02    Building wheel for pyyaml (setup.py) ... -� �\� �|� �/� �-� �\� �|� �done
13:59:02    Created wheel for pyyaml: filename=PyYAML-5.3.1-cp37-cp37m-linux_x86_64.whl size=546391 sha256=e42e1d66cc32087f4d33ceb81268c86b59f1a97029b19459f91b8d6ad1430167
13:59:02    Stored in directory: /var/jenkins/.cache/pip/wheels/5e/03/1e/e1e954795d6f35dfc7b637fe2277bff021303bd9570ecea653
13:59:02  Successfully built pyyaml
13:59:02  Installing collected packages: six, pyyaml, invoke, blessings
13:59:02    Attempting uninstall: six
13:59:02      Found existing installation: six 1.16.0
13:59:02      Uninstalling six-1.16.0:
13:59:02  ERROR: Could not install packages due to an OSError: [Errno 2] No such file or directory: '/var/jenkins/.cache/pre-commit/repomw8oee1s/py_env-python3/lib/python3.7/site-packages/__pycache__/six.cpython-37.pyc'
13:59:02
13:59:02  nox > Command pip install --progress-bar=off -r requirements/static/ci/py3.7/invoke.txt failed with exit code 1
13:59:02  nox > Session invoke-pre-commit failed.
```

* add changelog for #59982

* Regression test for #56273

* Fix race condition in batch. #56273

* Add changelog for #56273

* Update salt/client/__init__.py

Co-authored-by: Pedro Algarvio <[email protected]>

* Update doc for salt/client

* Update changelog/56273.fixed

Thoreau said, "Simplify, Simplify"

* Update docs

* Update docs

* Update CHANGELOG.md

* Update 3003.1.rst

* Ignore configuration for 'enable_fqdns_grains' for AIX, Solaris and Juniper

* Added changelog

* Let Mac OS Mojave run for 8 hours to avoid timeout

* Remove FreeBSD-12.2

* Use Popen for VT

* Still allow shell True

* Drop shlex split

* Add crypto re-init

* Fix pre-commit

* Do not call close in isalive

* Skip tests not valid on windows

* Cleanup things that are not really needed

* We do not support irix

* Fix pre-commit

* Remove commented out lines

* Add changelog for #60504

* Fix pre-commit issues

* pyupgrade does not remove six imports

* Fix OSErrors in some test cases

* Remove un-needed args processing

* Make state_running test more reliable

* Removing tmpfs from Fedora 33.

* Address leaks in fileserver caused by git backends

At this time we do not have the ability to fix the upstream memory leaks
in the gitfs backend providers. Work around their limitations by
periodically restarting the file server update proccess. This will at
least partially address #50313

* Remove un-used import

* Fix warts caused by black version

* Add changelog

* We don't need two changelogs

* Also pin the ``pip`` upgrade to be ``<21.2``

* Update the external ipaddress to the latest 3.9.5 version which has some security fixes.  Updating the compat.p to use the vendored version if the python version is below 3.9.5 and only run the test_ipaddress.py tests if below 3.9.5.

* Adding changelog

* Requested changes.

* Add shh_timeout to ssh_kwargs

* move to with blocks

* one with block

* reight crypto

* add back test file

* add changelog

* change log file number

* add m2crypt support

* only check m2crpto

* Delete 60571.fixed

* add back log

* add newline

* add newline for log file

* Work around pypa/pip#9450

See pypa/pip#10212

* Drop six and Py2

* [3003.2] Add server alive (#60573)

* add server alive

* rename log

* change default alive time

* add requested changes

* format string

* reformat string again

* run pre

* customize

* space

* remove EOF dead space

* fix pre-commit

* run pre

Co-authored-by: Megan Wilhite <[email protected]>

* Changelog for 3003.2

* Man pages update for 3003.2

* Allow CVE entries in `changelog/`

* Add security type for towncrier changelog

* Add security type for changelog entries pre-commit check

* Pin to ``pip>=20.2.4,<21.2``

Refs pypa/pip#9450

* Drop six and Py2

* Fix bug introduced in #59648

Fixes #60046

* Add changelog

* Fix doc builds

* fix release notes about dropping ubuntu 16.04

* update file client

* add changelog file

* update changelog

* Check permissions of minion config directory

* Fix some wording in the messagebox and in comments

* Add changelog

* Fix extension for changelog

* Add missing commas. It also worked, but now is better

* docs_3003.3

* fixing version numbers in man pages.

* removing newlines.

* removing newlines.

* Fixing release notes.

* Fix changelog file for 3003.2 release

* Fix test_state test using loader.context

* Re-add test_context test

* Allow Local System account, add timestamp

* swaping the git-source for vsphere-automation-sdk-python

* Remove destroy, handled in context manager

Co-authored-by: Daniel Wozniak <[email protected]>
Co-authored-by: Pedro Algarvio <[email protected]>
Co-authored-by: Bryce Larson <[email protected]>
Co-authored-by: Pablo Suárez Hernández <[email protected]>
Co-authored-by: Alexander Graul <[email protected]>
Co-authored-by: Frode Gundersen <[email protected]>
Co-authored-by: Gareth J. Greenaway <[email protected]>
Co-authored-by: Gareth J. Greenaway <[email protected]>
Co-authored-by: Hoa-Long Tam <[email protected]>
Co-authored-by: krionbsd <[email protected]>
Co-authored-by: Elias Probst <[email protected]>
Co-authored-by: Daniel A. Wozniak <[email protected]>
Co-authored-by: Frode Gundersen <[email protected]>
Co-authored-by: twangboy <[email protected]>
Co-authored-by: twangboy <[email protected]>
Co-authored-by: ScriptAutomate <[email protected]>
Co-authored-by: Wayne Werner <[email protected]>
Co-authored-by: David Murphy < [email protected]>
Co-authored-by: Joe Eacott <[email protected]>
Co-authored-by: cmcmarrow <[email protected]>
Co-authored-by: Twangboy <[email protected]>
@github-actions github-actions bot locked as resolved and limited conversation to collaborators Sep 27, 2021
Sign up for free to subscribe to this conversation on GitHub. Already have an account? Sign in.
Labels
None yet
Projects
None yet
Development

Successfully merging this pull request may close these issues.

Option to disable capture of stdout coming from setup.py
7 participants