Maintaining Open Source While Maintaining Your Sanity
Simon MacDonald
simonmacdonald.com
@macdonst
May You Maintain A Popular Open Source Project
- Developer Curse
Setting Up Your Project
Include a README
- Overview
- Getting Started Instructions
- An Invitation to Contribute
Have a CONTRIBUTING doc
- How to send a Pull Request
- Style Guide
Code of Conduct
- Helps create a positive social atmosphere for your community
- Should include:
- Where it takes effect
- Whom does it apply to
- What happens when someone violates the code
- How does one report violations
- The earlier you establish one the better
Add a License
Any License
Well, Almost Any License
Decide on How to Handle
Issues vs Question
- Everything in GitHub Issues
-
OR
Bugs only in GitHub Issues,
Questions on StackOverflow
Speaking of Issues
data:image/s3,"s3://crabby-images/acf62/acf62a7f3c108f5d341cfb4d1cec8282e1c45ab5" alt=""
Create an Issue Template
data:image/s3,"s3://crabby-images/8d9a7/8d9a7b44163191c839097e763d37812236cc3b2c" alt=""
What Goes in a Good Issue Template?
- Ask if the user has searched past issue
- Expected Behaviour
- Actual Behaviour
- Reproduction Scenario
- Version
- Sample Code
- Logs
Triaging Issues
Submitter doesn't follow issue template!
data:image/s3,"s3://crabby-images/716be/716be5961168f1fa76a1e9cea75d654773db70de" alt=""
Submitter asks a question that has been answered before!!
data:image/s3,"s3://crabby-images/716be/716be5961168f1fa76a1e9cea75d654773db70de" alt=""
Requested an Update 2 Months Ago and No Reply
data:image/s3,"s3://crabby-images/716be/716be5961168f1fa76a1e9cea75d654773db70de" alt=""
Submitter Asks a Dumb/Obvious Question!!!
docs
Submitter is asking for new functionality
enhancement
Issue template filled
and it's reproducible!
Mark as a bug
People are more difficult than code
data:image/s3,"s3://crabby-images/02d74/02d74a0f9c8af0c9f310383a7e7a669587fe5b1a" alt=""
Set Boundaries
data:image/s3,"s3://crabby-images/b0fbb/b0fbb97a68a7b0ddc011d4971bb6a22184dbfce0" alt=""
Be respectful, empathic but firm
What About Pull Requests?
You Should Have a Pull Request Template
- Description
- Related Issue
- Type of Change:
- Bug fix
- New feature
- Breaking Change
- Checklist
- Follows code style
- Doc change
- Read CONTRIBUTING
- Added tests
- All tests pass
You Don't Have To Merge in Every Pull Request
Open Source
Starter Repo
Building Community
data:image/s3,"s3://crabby-images/a73d8/a73d82c7f726ef0a3653fea4862274927880ea2a" alt=""
data:image/s3,"s3://crabby-images/4c771/4c771672c48e75ce53b1c68932650b62c84615ef" alt=""
Make it easy for people to contribute
- Identify beginner bugs
- Document the heck out of things
- Give people other ways to contribute besides writing code.
Turn contributors into maintainers
Thank People For Their Efforts
data:image/s3,"s3://crabby-images/f9c0d/f9c0dfdf8725954b536aaf751838098011cb3a40" alt=""
Tests
- Gotta Have Them
- Not a Lot
- Mostly for Regression
Documentation
- Bare minimum start with a README
- Enhance with markdown docs that are linked from the README
- Graduate to docs for GitHub pages
Releasing
- Release on every commit
- Release on a time based schedule
Automate Your Release
data:image/s3,"s3://crabby-images/124d5/124d58cc47b774a13420f87cc55b9ff79313d6ba" alt=""
Remember
Resources
Further Reading
Maintaining Open Source While Maintaining Your Sanity
By Simon MacDonald
Maintaining Open Source While Maintaining Your Sanity
AEM GEMS Session
- 2,600