2078 lines of code across 24 PRs were changed in Wasp repo during HacktoberFest 2022 - the most prominent online event for promoting and celebrating OSS culture. October has been a blast, to say the least, and the most active month in the repo's history.
This is the story of our journey along with the tips on leveraging HacktoberFest to get your repo buzzing! šš
How it went: the stats
Let's take a quick look at the charts below (data obtained from OSS Insight platform) š
24 contributor PRs in Oct, an all-time high!
On the other hand, number of changed LoC isn't that huge
While the number of PRs is at an all-time high, the number of updated lines of code is fewer than usual. If we take a look at the distribution of PR sizes in the first chart, we can see that "xs" and "s" PRs are in the majority (20 out of 24).
This brings us to our first conclusion: first-time contributors start with small steps! The main benefit here is getting potential contributors interested and familiar with the project, rather than expecting them to jump in and immediately start implementing the next major feature. Efforts like that require investing time to understand and digest codebase architecture, design decisions and the development process.
On the other hand, being able to implement and merge any feature, no matter the size, from beginning to the end, and to get your name on the list of contributors of your favourite project is an amazing feeling! That will make your contributors feel like superheroes and motivate them to keep taking on larger and larger chunks, and maybe eventually even join the core team!
Thus, the second conclusion would be: donāt underestimate the significance of small PRs! It's not about reducing your backlog, but rather encouraging developers to get engaged with your project in a friendly way.
To make it easier for your new contributors, you can prepare in advance good issues to get started with - e.g. smaller bugs, docs improvements, fun but isolated problems, etc.
We added
good-first-issue
label to such issues in Wasp repo, and even added extra context such asno-haskell
,webdev
,example
,docs
.
With your repo being set, the next question is "How do I get people to pick my project to work on"? Relying solely on putting "HacktoberFest" topic on your GitHub repo won't do the trick, not with thousands of other repos doing the same.
If you want to get noticed, you need to do marketing. A lot of it. The name of the game here is what you put in is what you get back. Let's talk about this in more detail.
A thin line between genuine interactions and annoying self-promotion
First and foremost, you'll need to create an entry point with all the necessary information for the participants. We opted for a GitHub issue where we categorized HacktoberFest issues by type, complexity, etc, but it can be anything - a dedicated landing page, Medium/Dev.to article, or whatever works for you. Once you have that, you can start promoting it.
Our entry point for HacktoberFest
Our marketing strategy consisted of the following:
- Tweeting regularly - what's new, interesting issues, ...
- Writing meaningful Reddit posts about your achievements
- Hanging out in HacktoberFest Discord server, chatting with others and answering their questions
- Checking posts with appropriate tags on different blogging websites like Medium, Dev.to, Hashnode, etc. and participating in conversations.
There are plenty of other ways to advertise your project, like joining events or writing articles. Even meme contests. The activities mentioned above worked the best for us. Letās dive a bit deeper.
Tweets are pretty obvious - as mentioned, you can share updates on how stuff is going. Tag contributors, inform your followers about available issues and mention those who might be a good fit for tackling them.
Reddit is a much more complex beast. You need to avoid clickbait post titles, comply with subreddit rules on self-promotion and try to give meaningful info to the community simultaneously. Take less than you give, and youāre good.
The Discord server marketing was pretty straightforward. Thereās even a dedicated channel for self-promotion. In case you're not talkative much, dropping a link to your project is OK, and thatās it. On the other hand, the server is an excellent platform for discussing HacktoberFest-related issues, approaches, and ideas. The more you chat, the higher your chances of drawing attention to your project.
The most engaging but also time consuming activity was commenting on blog posts of other HacktoberFest participants. Pretending that youāre interested in the topic only to leave a self-promoting comment will not bring you anywhere - it can only result in your comment being removed. Make sure to provide value: add more information on the topic of the article, address specific points the author may have missed, or mention how youāve dealt with the related issue in your project.
Be consistent and dedicate time to regularly to check new articles and jump into discussions. Share a link to your repo only if it fits into the flow of the conversation.
Was it worth it?
Before joining HacktoberFest as maintainers, we werenāt sure it would be worth the time investment. Our skepticism was reinforced by the following:
- Mentions of people submitting trivial PRs just to win the award
- The fact that we're making a relatively complex project (DSL for developing React + Node.js full-stack web apps with less code) and it might be hard for people to get into it
- The compiler is written is Haskell, with templates in JavaScript - again, not the very common project setup
Fortunately, none of this turned out to be a problem! We've got 24 valid PRs, both Haskell and non-Haskell, a ton of valuable feedback, and several dozen new users and community members.
Wrap up
Donāt expect magic to happen. HacktoberFest is all about smaller changes and getting community introduced to your project. Be ready to promote your repo genuinely and donāt be afraid to take part in the contest. We hope that helps and wish you the best of luck!
Remember, HacktoberFest is all about the celebration of open source. Stick to that principle, and youāll get the results you could only wish for!
P.S. - Thanks to our contributors!
Massive shout out to our contributors: @ussgarci, @h4r1337, @d0m96, @EmmanuelCoder, @gautier_difolco, @vaishnav_mk1, @NeoLight1010, @abscubix, @JFarayola, @Shahx95 and everyone else for making it possible. You rock! š¤
Top comments (3)
Contributing to Wasp was an amazing experience! I was a bit reluctant at first, due to the complexity project and the fact that I'd never contributed to a Haskell project before, but I was really encouraged when I saw the Hacktoberfest issue list, all of the documentation for developers (project structure, tools, standards, compiling, etc), and the activity on Discord; When I submitted my PR, all of the great feedback and attention from the maintainers made my experience even better.
Thank you for this amazing project! I look forward to contributing in the future. Keep up the great work! :D
Thanks so much for all your contributions, the whole team was impressed with how quickly you got into the codebase :) Looking forward to what's next!
Wow, thanks for your warm words! Beta is coming, there will be a ton of cool stuff to work on :)