Mailman usually participates in Summer of Code under the banner of the Python Software Foundation, so you may want to read up on expectations for PSF students:
Mailman has been split into three pieces:
- Mailman core (the part that delivers the messages, manages users, etc.)
- Postorius (the web front-end)
HyperKitty (the archiver)
All three projects are working together, so you'll notice we often just say "Mailman" rather than specifying Mailman/Postorius/HyperKitty.
Mailman is looking for students who...
- are able to contribute useful features to Mailman
- are able to communicate well with existing developers
So if you're wondering how to impress us, keep those in mind!
To demonstrate your ability to contribute useful features, here's a few things you can do:
- Set up your development environment
Fix a bug
- each project has a tag for easy or beginner bugs; you probably want to start there but feel free to work your way up
- Don't forget to publish your code and submit a merge request!
Try to duplicate bugs that haven't been fixed
- You may be able to help diagnose the problem or close bugs that cannot be duplicated
- Don't forget to comment on the bug to say if you duplicated it or add any information you found that might help
- Try to create new automated regression tests
- Even if you know you want to work with a specific piece of Mailman, try out Mailman core, Postorius and Hyperkitty so you know what to expect from all of them
- Take a look at required skills on the idea page and practice with anything you haven't used recently
To demonstrate your ability to communicate with us, here's some things you can do:
Sign up for the mailman-developers mailing list and introduce yourself, ask questions and participate in discussions
- Remember to do things like use good subject lines, etiquette, etc.
Show up on IRC and talk to us
- we can most often be found on #mailman on irc.freenode.org
- Remember to be patient if you do not get a response right away; many of us are on IRC from work and may not be able to answer immediately
Contribute to the wiki
- We can always use more information to help beginners get set up, so even documenting how you got set up could be useful!
File bug reports
- You may find things when you're setting yourself up, or feel free to just experiment and see what works and doesn't work
Help other people
- Sometimes all you need to do is search the FAQ on the wiki and help them find relevant entries
- Sometimes just asking questions about their problem can help a lot, even if you don't know the answer
- This includes other prospective gsoc students -- we can be very swamped with questions as application time approaches and you'll especially impress us if you can make the mentoring process easier for us!
Other tips:
- Don't forget that you can suggest your own project, but make sure you talk to us to help you refine your proposal
- Do choose a project you're confident you can finish, but add some "stretch goals" for things you'd love to do if things go well
- Don't aim too low: we only have a limited number of slots and mentors, so we're more likely to choose projects that maximize what we get out of the summer
- Do ask lots of questions: we know it can be difficult to get started
- But on the other hand... try demonstrate that you're able to solve some problems on your own: do google searches, experiment, etc. if you get stuck
- Do be patient
Do use the mailing lists whenever possible: because our mentors are busy folk, it's better to ask *everyone* than to talk to one person privately. You're much more likely to get a response.