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

Refactor error handling to use exceptions #1719

Merged
merged 13 commits into from
Jun 10, 2024
Merged

Refactor error handling to use exceptions #1719

merged 13 commits into from
Jun 10, 2024

Conversation

joerick
Copy link
Contributor

@joerick joerick commented Jan 6, 2024

cibuildwheel has up until now handled most errors by printing an error message to sys.stderr and calling sys.exit. Others were handled using Logger.error, depending on the context. We also had return codes, but these weren't explicitly defined anywhere.

This makes that convention more explicit and codified. Now to halt the program, the correct thing to do is to throw a cibuildwheel.errors.FatalError exception - that is caught in main() and printed before exiting. The existing behaviour was kept - if an error occurs within a build step (probably something to do with the build itself), the Logger.error() method is used. Outside of a build step (e.g. a misconfiguration), the behaviour is still to print 'cibuildwheel: '

I also took the opportunity to add a debugging option --debug-traceback (and CIBW_DEBUG_TRACEBACK), which you can enable to see a full traceback on errors.

(I've deactivated the flake8-errmsg lint rule, as it was throwing loads of errors and these error messages aren't generally seen in a traceback context)

cibuildwheel has up until now handled most errors by printing an error message to sys.stderr and calling sys.exit. Others were handled using Logger.error, depending on the context. We also had return codes, but these weren't explicitly defined anywhere.

This makes that convention more explicit and codified. Now to halt the program, the correct thing to do is to throw a cibuildwheel.errors.FatalError exception - that is caught in main() and printed before exiting. The existing behaviour was kept - if an error occurs within a build step (probably something to do with the build itself), the Logger.error() method is used. Outside of a build step (e.g. a misconfiguration), the behaviour is still to print 'cibuildwheel: <message>'

I also took the opportunity to add a debugging option `--debug-traceback` (and `CIBW_DEBUG_TRACEBACK`), which you can enable to see a full traceback on errors.

(I've deactivated the flake8-errmsg lint rule, as it was throwing loads of errors and these error messages aren't generally seen in a traceback context)
cibuildwheel/windows.py Outdated Show resolved Hide resolved
cibuildwheel/util.py Outdated Show resolved Hide resolved
cibuildwheel/options.py Outdated Show resolved Hide resolved
cibuildwheel/linux.py Outdated Show resolved Hide resolved
@@ -0,0 +1,20 @@
class FatalError(SystemExit):
Copy link
Contributor Author

Choose a reason for hiding this comment

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

Btw, I couldn't decide whether to subclass SystemExit or Exception here, any strong opinions?

Copy link
Contributor Author

Choose a reason for hiding this comment

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

On reflection, I'll change it to Exception to avoid the confusion around SystemExit's code attribute.

Suggested change
class FatalError(SystemExit):
class FatalError(Exception):

Copy link
Member

Choose a reason for hiding this comment

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

If it needs to behave like SystemExit, I'd inherit from BaseException. Have you considered this?

Copy link
Member

Choose a reason for hiding this comment

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

(since it's raised in places where sys.exit() used to be, I'd expect this, I think)

@joerick
Copy link
Contributor Author

joerick commented Mar 2, 2024

A review here would be good too. It's not critical, maybe just a little code quality improvement. I'm not too attached to it though, we could drop the idea if the existing convention approach is preferred.

cibuildwheel/options.py Outdated Show resolved Hide resolved
@mayeut mayeut requested a review from henryiii June 9, 2024 16:11
cibuildwheel/errors.py Outdated Show resolved Hide resolved
@henryiii
Copy link
Contributor

Let's release after this. I've been trying out macOS free threading and build[uv] in some draft PR's,, and have been happy with the results.

@henryiii henryiii merged commit bf817c6 into main Jun 10, 2024
22 of 24 checks passed
@henryiii henryiii deleted the error-exceptions branch June 10, 2024 14:36
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.

4 participants