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

Bundle size reduction #23968

Closed

Conversation

matthargett
Copy link
Contributor

Summary

With recent activity to extract out non-core things into separate repos, I did an audit of the package.json to see what can be removed, and what packages remain that have newer versions that result in less/smaller javascript code. The goal is to:

  1. make developer experience better by removing unneeded dependencies, and
  2. eliminate things the app bundler needs to process to make the production app bundle smaller.

Changelog

[internal] [chore] - Remove unneeded packages, bump package versions who now have smaller size

Test Plan

  1. yarn lint
  2. yarn flow
  3. yarn test
  4. yarn test-android-unit

…aves on minified bundle size (according to bundlephobia.com). yargs 9.0 to 13.2.2 saves 13kb, regenerator-runtime saves a few hundred bytes, prop-types saves ~1kb.
@facebook-github-bot facebook-github-bot added CLA Signed This label is managed by the Facebook bot. Authors need to sign the CLA before a PR can be reviewed. Partner p: Sony Partner: Sony labels Mar 15, 2019
@pull-bot
Copy link

pull-bot commented Mar 15, 2019

Warnings
⚠️ 🔒 package.json - Changes were made to package.json. This will require a manual import by a Facebook employee.
Messages
📖

📋 Changelog Format - Did you include a Changelog? A changelog entry has the following format: [CATEGORY] [TYPE] - Message.

CATEGORY may be:
  • General
  • iOS
  • Android

TYPE may be:

  • Added, for new features.
  • Changed, for changes in existing functionality.
  • Deprecated, for soon-to-be removed features.
  • Removed, for now removed features.
  • Fixed, for any bug fixes.
  • Security, in case of vulnerabilities.

MESSAGE may answer "what and why" on a feature level. Use this to briefly tell React Native users about notable changes.

Generated by 🚫 dangerJS against 073f03b

@react-native-bot react-native-bot added the Tech: Bundler 📦 This issue is related to the bundler (Metro, Haul, etc) used. label Mar 15, 2019
@sunnylqm
Copy link
Contributor

And since jsc has been upgraded, maybe we can also remove some polyfill and babel plugins?

@cpojer
Copy link
Contributor

cpojer commented Mar 18, 2019

Could you revert the changes to yargs and jest-junit for now?

How does this PR affect bundle size?

@matthargett
Copy link
Contributor Author

And since jsc has been upgraded, maybe we can also remove some polyfill and babel plugins?

I'd love to do that, but I think there are some Facebook dependencies that need to be fixed first. Ideally, we could have a CLI flag that doesn't include the polyfills so OSS users aren't being held back by Facebook's deployment constraint. It's not just the bundle size, but the global initialization code that needs to run as well.

@matthargett
Copy link
Contributor Author

Could you revert the changes to yargs and jest-junit for now?

Sure. Can you give some detail on the yargs constraint? That's probably the biggest savings in terms of bundle size (~13kb). Even updating it to 10.x (if somehow 13 is not workable for FB) would help.

How does this PR affect bundle size?

It's saving ~30kb when using haul in one of my apps. I can't seem to get consistent results when trying to compare using RNTester. There's this weird 80-100 byte variance I can't track down.

Copy link
Contributor

@cpojer cpojer left a comment

Choose a reason for hiding this comment

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

Thanks!

Copy link
Contributor

@facebook-github-bot facebook-github-bot left a comment

Choose a reason for hiding this comment

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

@cpojer is landing this pull request. If you are a Facebook employee, you can view this diff on Phabricator.

@react-native-bot
Copy link
Collaborator

This pull request was successfully merged by @matthargett in 13351e6.

When will my fix make it into a release? | Upcoming Releases

@react-native-bot react-native-bot added the Merged This PR has been merged. label Mar 21, 2019
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment
Labels
CLA Signed This label is managed by the Facebook bot. Authors need to sign the CLA before a PR can be reviewed. Merged This PR has been merged. p: Sony Partner: Sony Partner Tech: Bundler 📦 This issue is related to the bundler (Metro, Haul, etc) used.
Projects
None yet
Development

Successfully merging this pull request may close these issues.

6 participants