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.
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.
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
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.
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.
Thanks to all of our supporters, backers, and customers! Your contributions make elementary possible. If you’d like to help build and improve elementary OS, don’t hesitate to Get Involved.