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

chore: autoload JWT classes #499

Merged
merged 4 commits into from
Apr 3, 2020
Merged

Conversation

philnash
Copy link
Contributor

Works towards fixing #396.

Others are reporting that twilio-ruby takes a lot of memory. My belief is that this is because it is a large library that covers an ever increasing API surface. The issue is not necessarily in that the library is so large, but that the entire thing is loaded in one go with requires for days.

I am going to send a few PRs that update our use of require to autoload where appropriate. autoload only loads the file when the constant (class/module) is used.

This is the second PR, after #498, for those who include the library but don't use Access Tokens. The files governing Access Token and JWT creation will not be loaded into memory. For those that do use Access Tokens the behaviour will be unchanged. Notably this also moves requiring jwt to the JWT files too.

This PR will not significantly reduce the memory usage, but it is a further movement towards autoloading the whole library, and smaller PRs are easier to review.

Checklist

  • I acknowledge that all my contributions will be made under the project's license
  • I have made a material change to the repo (functionality, testing, spelling, grammar)
  • I have read the Contribution Guidelines and my PR follows them
  • I have titled the PR appropriately
  • I have updated my branch with the master branch
  • I have added tests that prove my fix is effective or that my feature works (all existing tests pass)
  • I have added necessary documentation about the functionality in the appropriate .md file
  • I have added inline documentation to the code I modified

@childish-sambino childish-sambino added the status: waiting for feedback waiting for feedback from the submitter label Mar 12, 2020
Copy link
Contributor

@childish-sambino childish-sambino left a comment

Choose a reason for hiding this comment

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

LGTM

@childish-sambino childish-sambino merged commit c1eedc3 into twilio:master Apr 3, 2020
@childish-sambino childish-sambino removed the status: waiting for feedback waiting for feedback from the submitter label Apr 3, 2020
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