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

Correctly support Ruby 2.7+ keyword arguments. #426

Closed
ioquatix opened this issue Apr 1, 2022 · 10 comments · Fixed by #498
Closed

Correctly support Ruby 2.7+ keyword arguments. #426

ioquatix opened this issue Apr 1, 2022 · 10 comments · Fixed by #498

Comments

@ioquatix
Copy link
Contributor

ioquatix commented Apr 1, 2022

def notify(exception_or_opts, opts = {})

Should probably be def notify(exception_or_opts, **opts).

@joshuap
Copy link
Member

joshuap commented Apr 1, 2022

Thanks @ioquatix! I think we could support this once we drop support for Ruby 2.6 (which officially ended yesterday, I see. 😁)

Related: #427

@joshuap joshuap mentioned this issue Apr 1, 2022
@halfbyte
Copy link
Contributor

halfbyte commented Oct 19, 2023

@joshuap I've started to take a look at this and obviously this is not a super trivial change. The signature that would most likely work is notify(exception = nil, **opts) and I can get a ton of tests to work with that.

What I am more worried about is people using explicit hashes ala notify({error_message: "yeah"}) and I wonder if we should make this a breaking change or if the code needs to somehow take care of these "legacy calls".

What's your thoughts on this?

EDIT: I think I can make it work with a signature like this (which unfortunately makes it a bit more complicated than before): notice(exception_or_opts=nil, opts = {}, **kwopts). This should catch all cases where explicit hashes are given it and at the same time work with kwargs just fine.

joshuap added a commit that referenced this issue Oct 19, 2023
* FIX: Make notify work with proper ruby keyword arguments

Fixes #426

* Add tests for the various permutations of hashes and kwargs

* Fix docs

Removed the hash braces in the second example to clarify that kwargs are fine

* Merge kwargs earlier

---------

Co-authored-by: Joshua Wood <[email protected]>
@joshuap
Copy link
Member

joshuap commented Oct 19, 2023

@joshuap I've started to take a look at this and obviously this is not a super trivial change. The signature that would most likely work is notify(exception = nil, **opts) and I can get a ton of tests to work with that.

What I am more worried about is people using explicit hashes ala notify({error_message: "yeah"}) and I wonder if we should make this a breaking change or if the code needs to somehow take care of these "legacy calls".

What's your thoughts on this?

EDIT: I think I can make it work with a signature like this (which unfortunately makes it a bit more complicated than before): notice(exception_or_opts=nil, opts = {}, **kwopts). This should catch all cases where explicit hashes are given it and at the same time work with kwargs just fine.

I think this is OK for now, although I may think about it a bit before releasing. My gut says your approach is best (albeit more complicated) until the next major/breaking release, when we should plan to remove the second opts argument and move to keyword arguments exclusively. What do you think @subzero10?

@subzero10
Copy link
Member

@joshuap To clarify:

I think that's a good approach, though I admit I can't size "complexity" here since my ruby skills are limited.

And if I'm not adding a lot to the complexity of the temporary signature, I would suggest logging a warning when the method is called with "legacy" params, something like: Passing params as an object is deprecated and will not work in future releases. Please click here to read more.

@joshuap
Copy link
Member

joshuap commented Oct 20, 2023

@joshuap To clarify:

I think that's a good approach, though I admit I can't size "complexity" here since my ruby skills are limited.

And if I'm not adding a lot to the complexity of the temporary signature, I would suggest logging a warning when the method is called with "legacy" params, something like: Passing params as an object is deprecated and will not work in future releases. Please click here to read more.

The other option is to merge #499 and do a major release (6.0). Or, if we're not quite ready for 6.0, we could also revert e4a006c and plan to fix it for real in the next major release (without the interim step). I think I prefer the latter.

@joshuap
Copy link
Member

joshuap commented Oct 20, 2023

I'm also fine with a deprecation warning if we decide to keep the temporary signature and do a minor release.

@ioquatix
Copy link
Contributor Author

This looks great, nice work team.

@subzero10
Copy link
Member

I have no strong opinion about either approach.
We haven't released the ruby gem since March 2023, which could be +1 for a major release 🤷 .
Or you could argue the same for the opposite: let's make a release for the fixes that haven't been released since some time and plan the major release.

Actually, the more I think about it, I'm leaning towards the major release: no real winner, so I'd go for the simpler solution.
Would you be OK with that @joshuap and @JanStevens ?

@joshuap
Copy link
Member

joshuap commented Oct 23, 2023

I have no strong opinion about either approach. We haven't released the ruby gem since March 2023, which could be +1 for a major release 🤷 . Or you could argue the same for the opposite: let's make a release for the fixes that haven't been released since some time and plan the major release.

Actually, the more I think about it, I'm leaning towards the major release: no real winner, so I'd go for the simpler solution. Would you be OK with that @joshuap and @JanStevens ?

One thing to consider is that we'll need to do a release once we finish the logging/insights work—will that also need to be a major release, or can it be a minor one? I'd prefer not to release two major versions back-to-back.

@subzero10
Copy link
Member

a release once we finish the logging/insights work

If it won't introduce breaking changes, it can be a minor release. If it has breaking changes, then I guess we can skip the major release for this one.

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 a pull request may close this issue.

4 participants