elementary + GitHub

Daniel Foré
elementary
Published in
4 min readJun 19, 2017

If you thought we’d dropped off the face of the planet, you probably missed it: we have moved away from Medium and started publishing on our faster, open source, and privacy-respecting blog at blog.elementary.io. We’ve kept this blog post unlisted here on Medium for posterity, but all recent and future posts as of November, 2019 are exclusively hosted there.

We’re excited to finally say that elementary has completed our move and now lives on GitHub! We’ve migrated over 70 repositories from Launchpad and bzr. So what does that really mean?

Lower Barrier to Entry

GitHub is fairly ubiquitous these days among developers and with good reason. It is easy to use, there’s plenty of tutorials, documentation, and other help available. It provides simple web tools so that small fixes can be submitted in a web browser. Since we started migrating to GitHub, we’ve seen an influx of small, but helpful pull requests.

Better Integrations

GitHub integration for Slack

GitHub is integrated with Slack, which means that when a new issue is filed or a pull request is submitted, our team gets a message right away. Other tools we use like Bountysource and Weblate provide badges that we can show in our README so that every app has quick and easy links readily available. Our downstreams like GitHub because it uses Git, making it easier to package our software for other Linux distributions like Fedora.

Better Code Reviews

GitHub allows us to enforce some behavior for branches. Specifically, we can disallow the ability to push to the master branch and require code reviews. We can also require that branches pass status checks, like testing and even dismiss old approvals when new commits are pushed.

Nearly all of our repositories are now running Travis CI for continuous integration testing. Whenever a branch is submitted for review, it is automatically built in a clean environment and tests are run. This helps reduce the chances for regressions and breaks during development.

Tighter controls on pull requests

We also require that branches be up to date with the latest master and GitHub’s built-in tools make it easy to resolve conflicts if they occur. That way, we can be sure that the reviews we do are being done on up-to-date code.

All of this together means that branches are reviewed faster and more thoroughly at the same time.

Richer Issue Reports

markdown, mentions, reactions, oh my!

Because GitHub uses markdown everywhere, we can get much better issue reports with embedded images and code snippets. GitHub supports issue templates, so we can help guide people how best to supply the necessary information for trickier components. And maybe best of all, both the issue report itself and comments can have reactions which cut down on “me too” comments and other noise that can hide useful information.

A New Translations Platform

In case you missed our previous blog post, all our translation are now hosted on Weblate instead of a mix of Transifex and Rosetta. More on that here.

Get Involved

If you’ve ever thought about getting involved, now is a great time! During the switch we’ve taken the time to update the README files for all of our repositories with simple build instructions and tips for debugging and testing. We’ve also updated our website to reflect the change. There are now new links for Bitesize and Bountied issues.

If you’ve never used Git or GitHub before, GitHub provides a bunch of tutorials and Codecademy offers a great beginners git course.

We’d like to say thanks again to everyone who’s bought an app on AppCenter, our supporters on Bountysource and Patreon, and those who’ve purchased a copy of elementary OS or merch from our store. Every contribution helps make all of this possible, and we wouldn’t be here without you! If you’d like to help improve elementary OS, don’t hesitate to Get Involved!

--

--