👋 Emberistas! 🐹
Meet Ember 3.17 🆕, tell us about your EmberConf experience ❤️, read about testing best practices on the Ember Testing Guide 📗, comment on the co-located test RFC ⛓, embrace easier release management for your apps 📦🙌, learn how to add CI with GitHub Actions ✅, and respect the underscore 🙇.
On March 16—just in time for EmberConf!—Ember 3.17 was officially announced. This release marked Ember 3.16 as an LTS and kicked off the 3.18 beta cycle.
Ember 3.17 introduced these changes:
- Significantly updated the Glimmer rendering engine
- Ember CLI
- Removed internal usage of
RSVPin favor of native promises
ember-cli-template-lintin favor of
- Ensured that
yarn testfails when
- Ensured that
yarn testin an addon fails if
- Removed a number of older experiments (module unification and delayed transpilation)
- Removed internal usage of
To learn more about upgrading to Ember 3.17, please visit the Ember Blog. We encourage you to help test 3.17 and 3.18 beta and report any bugs. Thank you!
Check out all the related resources for the talks in the conference notes by Alex DiLiberto (@alexdiliberto). Also, stay tuned and follow the EmberConf Twitter account to not miss out on the exclusive BonusConf sessions, which will be released over the next couple of days!
Last, but not least, we have one request for those of you who attended EmberConf 2020:
Tell us about someone new that you got to chat with at the virtual conf!
Let us know about your answer to this question either by tweeting us via Twitter using the hashtag #EmberConFriends or as a message on the Ember Discord in the #support-ember-times channel. We will raffle an exclusive EmberConf retro sticker set among all story writers by April 6, 2020. We're looking forward to hear from you and happy catching up on virtual EmberConf!
Dawid Pośliński (@PoslinskiNet) wrote about testing best practices and which addons to use in the newly released Ember Testing Guide v1. The testing guide goes through why we need tests to begin with. What benefits does testing give us and what gaps are still present.
Following that, the testing guide discusses best practices in how we architect our testing code. It also goes through how to use the right kind of test. Should the test be unit, integration, acceptance, visual regression, or even manual? These principles are the building blocks to constructing effective tests.
Finally the guide goes through all the best addons available today and how to use them in testing your application with examples from qunit-dom, ember-test-selectors, ember-cli-timecop, ember-a11y-testing, ember-percy and many more!
The conventional file layout of Ember apps has undergone a few changes throughout the years.
Besides the classic file layout, users have also been able to opt-in to the pods layout for a while. And while pre-v3.13 Ember users were modifying component templates and
.js files in two different directories, they recently got the chance to work on component files side-by-side after the implementation of the component template co-location RFC.
Another, recent RFC wants to take the principle of co-location even a step further: it proposes that test files, e.g. those for rendering tests of a component, should be co-located right next to the respective component class and template files. Beyond that, the proposal suggests a similar co-location pattern for unit tests of related routes and controllers, too - with the motivation to improve the discoverability of tests for application developers.
Who doesn't dream of easy-peasy releases? Let straightforward publishing workflows become your new reality with create-rwjblue-release-it-setup. Leveraging the tools from the popular library release-it, it allows you to setup your project swiftly for automated versioning and package publishing.
Make your dream of easier release management come true with one single npm command:
npm init rwjblue-release-it-setup
...or a yarn command for that matter:
yarn create rwjblue-release-it-setup
Check out the v2 release page to learn more about all the latest features and improvements and happy publishing!
Continuous integration (CI) and continuous deployment may be skills that you get to practice maybe once on a production app, depending on your job title. But the truth is, you can practice them (ahem) continuously at an early stage for any app, no matter who you are. 💗
You might then ask, where can I learn how to add CI to my Ember app? Are there cool things that I can do because I have an Ember app?
- Cache dependencies (avoid
- Lint files and dependencies
- Run tests separately from linting
- Split tests and run in parallel
- Take Percy snapshots in parallel
If you wanted to solve these problems or needed a reference code, look no further! Feedback is always welcome (you can DM
@ijlee2 on Discord).
Steven Elberger (@StevenElberger)'s blog post, "Respect the Underscore," is a fantastic example of what you can practice as a developer: Document your bug for posterity, especially if it failed your app or test suite in a catastrophic manner.
Here are some questions that you and your team can address:
- When did you first notice the bug?
- Which features or upgrades were recently worked on?
- What did you think caused the bug?
- How did you eliminate some of the possibilities?
- What did you do to fix the bug?
Because Steven's writing excellently builds suspense, we won't dare spoil the twists and ending here. Instead, we encourage you to check out the post!
This week we'd like to thank @kratiahuja, @bobisjan, @nummi, @rwwagner90, @rwjblue, @Gaurav0, @Aswathprabhu, @skaterdav85, @jenweber and @laurmurclar for their contributions to Ember and related repositories! 💖
Wondering about something related to Ember, Ember Data, Glimmer, or addons in the Ember ecosystem, but don't know where to ask? Readers’ Questions are just for you!
Submit your own short and sweet question under bit.ly/ask-ember-core. And don’t worry, there are no silly questions, we appreciate them all - promise! 🤞
That's another wrap! ✨
Chris Ng, Jessica Jordan, Isaac Lee, Amy Lam and the Learning Team