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

Fix rake task helpers polluting global namespace #91

Open
wants to merge 1 commit into
base: master
Choose a base branch
from

Conversation

hibachrach
Copy link

Before, the session method (for example) would be redefined in the
context of an RSpec request spec because the default definee in the
block within the namespace call would be main, the global object.

Additional context about default definees:
https://blog.yugui.jp/entry/846

Before, the `session` method (for example) would be redefined in the
context of an RSpec request spec because the default definee in the
block within the `namespace` call would be `main`, the global object.

Additional context about default definees:
https://blog.yugui.jp/entry/846
@jasonkarns
Copy link

jasonkarns commented Jul 27, 2022

Another option is to define the methods in an external file/module, and only require them from within the task defs. That way they're only included when those tasks are actually run.

@hibachrach
Copy link
Author

Would you prefer that option? Willing to edit the PR if that's the case.

@jasonkarns
Copy link

@hibachrach I'm not one of the maintainers, so I can't speak for them or the project. However, moving the module(s) into an external file that is explicitly (and only) required when needed is the approach I use and recommend on my teams. As it stands in this PR, the Graphiti::Rails::RakeHelpers modules are all being defined whether those tasks are invoked or not. (The namespace body is evaluated when rake loads the file, as that is how rake knows what tasks exist.)

What's more, then you can include Graphiti::Rails::RakeHelpers in the task body and use the methods inline (unqualified) as they were before.

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