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

Reduce memory usage in Hanami::Action via dry-configurable and custom config_class #392

Merged
merged 9 commits into from
Oct 7, 2022

Conversation

timriley
Copy link
Member

@timriley timriley commented Sep 26, 2022

This PR takes advantage of the recent memory usage improvements in dry-configurable (see dry-rb/dry-configurable#138) by converting the previously custom Configuration class into settings defined on the Hanam::Action class.

To preserve some of the existing custom configuration methods, we provide a custom config class to Dry::Configurable and keep those methods there.

This custom config class also comes in handy as the place to keep the documentation for our settings, which I've converted into yard @!attribute macros for concision.

We also move two existing bits of state into new dry-configurable settings:

  • Convert before_callbacks and after_callbacks from class attributes, since Hanami-utils' class attributes implementation is very inefficient with memory.
  • Move accepted_formats from being an class-level ivar, since this was the only remaining class-level state and it made sense to keep all this together via the class-level config object.

As a consequence of the last change, we're also able to change Hanami::Action so it has a conventional #initialize method again, rather than having a custom .new method that has to allocate the object and assign some ivars directly, which is a big win for ease of understanding the code :)

Lastly, while we're here, we get rid of the @name ivar for actions, since it's no longer used anywhere.

Using the newly added benchmarks/memory_profile_action.rb (which creates 100 Action subclasses by default) we can see this branch allocates 0.338 MB of memory, versus 1.859 MB for the main branch.

Even putting aside the memory improvements, I'd paint this as a useful refactor, because it reduces code, better leverages a library we're already using (dry-configurable), as well as centralises all the action class-level state, making it easier for us to manage.

🙋🏼 I've tidied up the commit history here so you should be able to review things commit by commit.

@timriley timriley force-pushed the use-class-level-settings branch 4 times, most recently from 8d5e47e to 78dd1e4 Compare October 2, 2022 00:18
@timriley timriley requested review from jodosha and solnic October 2, 2022 00:23
@timriley timriley marked this pull request as ready for review October 2, 2022 00:24
@timriley timriley changed the title Use dry-configurable class level settings and custom config_class Reduce memory usage in Hanami::Action via dry-configurable and custom config_class Oct 2, 2022
@timriley timriley force-pushed the use-class-level-settings branch from 78dd1e4 to f8f7de2 Compare October 2, 2022 00:53
@timriley
Copy link
Member Author

timriley commented Oct 2, 2022

FYI, it seems we had a test failure in a previous run of this (https://github.com/hanami/controller/actions/runs/3166800527/jobs/5156785405) — I'll look into this and address it before merging.

Copy link
Member

@solnic solnic left a comment

Choose a reason for hiding this comment

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

This is wonderful 👏🏻 I'm happy to see that the new config_class feature turned out to be useful here already 🙂

spec/integration/hanami/controller/sessions_spec.rb Outdated Show resolved Hide resolved
@timriley
Copy link
Member Author

timriley commented Oct 2, 2022

@solnic It's so good! Couldn't have done it without you :)

@timriley
Copy link
Member Author

timriley commented Oct 2, 2022

FYI, it seems we had a test failure in a previous run of this (https://github.com/hanami/controller/actions/runs/3166800527/jobs/5156785405) — I'll look into this and address it before merging.

FYI, I looked at this test and couldn't replicate locally (same Ruby version, RSpec command and seed), plus it doesn't seem related to my changes here, so I'm not following it up any further at this point.

Copy link
Member

@jodosha jodosha left a comment

Choose a reason for hiding this comment

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

@timriley Great achievement! 👏 🎉

@jodosha jodosha added this to the v2.0.0 milestone Oct 3, 2022
@solnic
Copy link
Member

solnic commented Oct 3, 2022

@solnic It's so good! Couldn't have done it without you 🙂

🥹

@timriley
Copy link
Member Author

timriley commented Oct 7, 2022

@timriley timriley merged commit 2ca9af9 into main Oct 7, 2022
@timriley timriley deleted the use-class-level-settings branch October 7, 2022 01:39
timriley added a commit to hanami/hanami that referenced this pull request Oct 7, 2022
Use the config now accessible directly on the `Hanami::Action` class as `Hanami::Action.config` (changed in hanami/controller#392).

Also update usage of dry-configurable with `Undefined`: with the new `default_undefined` extension option, `Undefined` takes a special meaning inside dry-configurable. Avoid passing it in our case to make sure our existing behavior is preserved.
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Projects
None yet
Development

Successfully merging this pull request may close these issues.

3 participants