Due to business requirements, Youzan made many wheels by himself, especially many component libraries, React, Vue, small programs are involved, other open source projects include Zan-Proxy proxy, ZANPHP framework of PHP, etc. One might wonder, why did Yousan build so many wheels? In fact, the reason is really simple, because the existing substitutes can not meet the needs of our own business, maybe not meet our customized needs, or maybe the function does not meet our requirements. Based on business needs, we have developed a set of routines and specifications that are appropriate for us and turned them into tools, component libraries, or frameworks.
That’s probably why Youzan started these projects internally. Later, as these projects evolved, the natural thought was to open source them, and maybe others had similar needs.
Gradually, there are many open source projects on the awesome Github site. Some of the lessons we learned while maintaining these open source projects are shared here.
Awesome Github postures
Github has a certain social nature. In addition to writing good code, there are also some gestures that are important to maintaining an open source project. We have summarized some of them to share with you.
1. A good README is important
The README file is the first impression of a project, and it is important for open source projects to have a good face, especially if the project is a front-end project. Here are some suggestions for README files:
- Uniform README format for the same organization
- It’s better to have a README in English
- Plus links to development guides
The advantage of a uniform README format is that it makes it easy for others to recognize the project as belonging to the company or person. The template content is simple, but it ensures a certain level of identification for our project.
The English README is not meant to be pretentious. if you are sure your users are in China, then the Chinese README is all you need. But in most cases, project maintainers want their code to help as many people as possible, including users in foreign countries, where the English README is valuable.
It’s easy to overlook the development guide, which exists to help developers who want to get involved in a project get started. As developers working on open source projects, what do they expect from the development guide? I think there are a few things:
- How to set up the development environment?
- What unresolved issues do you need help with?
- How do I submit code?
If the development guide can answer these questions, experienced developers can get involved faster.
2. Use the Github Issue and PR templates
I’m sure many of you have encountered such an embarrassing situation: someone mentioned an Issue on Github, but you can’t understand the description of the Issue, and you don’t know how to reproduce the Issue.
Github provides a mechanism for project maintainers to pre-write an Issue or PR template, which can be modified when other people come in to propose an Issue or PR. The template can specifically tell the proposer who needs to fill in the information, which can avoid the embarrassing situation mentioned above most of the time.
Creating these templates is also simple, and a common way is to create the corresponding template Markdown file in the repository’s.github hidden directory. Github just updated the template mechanism to allow multiple Issue/PR templates to be created at the same time.
For example, the Issue template in the Babel repository has multiple templates, each of which corresponds to a different Issue type. The specific configuration documents can be found here.
3. Labels
Github Labels function is mainly used to classify issues/PR for easy indexing and searching. The main point I want to say here is that the Labels set by default on Github are actually not useful. We recommend dividing Labels into several orthogonal Labels, and each dimension corresponds to several different Labels. Please refer to this article.
Many novices tend to ignore the function of Label. With appropriate Label classification, each Issue can have a very intuitive status display.
Continuous integration system
Github and CI system integration is very close, I think the experience is done very well. CI systems can be used for unit testing, code style checking, etc. Many of the code coverage data on README files in the repository are generated and submitted in CI systems.
CI can be used to do other necessary code checks in addition to running one side. For example, there is a script in the Zent repository that checks on the CI to see if the submitted code is properly written. If the format is not correct, the developer may not have installed our Git hooks locally. In this case, we will prompt the developer to install the hooks locally, format the code and resubmit.
#! /bin/bash
# Ensure everyone installs the git hook.
# The result is a guess, but false positive
# is not an issue here.
RED='\033[0;31m'
basepath=$(dirname $0)
fail () {
printf "${RED}$@\nAborting\n"
exit1}pushd $basepath/.. >/dev/null 2>&1
yarn prettify
git diff-index --quiet HEAD --
rv=$?
popd >/dev/null 2>&1
if [ $rv -ne0];then
git diff-index HEAD --
fail 'Git hooks not installed. Follow these instructions on your local machine:\n1. yarn install\n2. yarn prettify\n3. Commit your changes and push.'
fi
Copy the code
Here are two commonly used CI systems on Github:
- The Travis service is stable, and the Travis PR build runs on the result of the merge between the source branch and the current PR branch
- CircleCI performance is good, but relatively poor stability, occasionally pumping
Github recently added a new feature, the Checks API, which can be seen as an updated version of the original PR and CI integration, with more detailed tests and Lint reports.
5. Project schedule control
GitHub has two Project management tools, Milestone and Project. Project displays a kanban-like feature, while Milestone is a more lightweight location, similar to a deadline management tool for task collections. For most open source projects, maybe Milestone is more appropriate.
Second, skills sharing
I’ve covered some tips for using Github, and here are some tips for developing, publishing, and maintaining projects. An open source project is more than a string of code, it is a technical product, which requires us to look at the problem in terms of product requirements.
1. Release follows ecosystem specifications
For example, most packages in the NPM ecosystem use Semantic Versioning, so if our packages don’t follow this rule, it’s easy to give users a “surprise”. Don’t be afraid of the version number getting bigger and bigger, it’s just a number.
Code specification
Every mature project will have its own code specification. Some projects may have documentation that tells contributors how to code and reviews to make sure the code is compliant. However, if it is only a code style specification, we recommend tools to ensure that the specification is in place. We do not provide documentation of coding specifications, but we do have scripts to format all submitted code. The effect is that you can write whatever code you want, but it’s always going to be written in the same specification when it’s submitted to the Master branch.
There are many such formatting processes, such as Prettier, which is often used in the front-end field, Gofmt, which comes with Go language, and Refmt of Reason, etc. Take the time to Google and find a formatting tool that works for your project.
3. Squash Merging
Github provides three merge options for PR. Squash Merge is recommended. Squash Merge is a squash merge that merges all commits on the PR branch into a new commit, and then merges the commit into the target branch in a fast-forward manner. We think this is the best method for PR projects. Of course, if you want to keep every single submission on PR, rebase is recommended, either via Github or rebase locally.
4. Update logs
In order to reduce the workload of each release, our previous update log was automatically generated by the script based on Github issues and PR records. However, we gradually found that the readability of the update log became poor due to the poor standardization of Isssue and PR titles. Another problem with machine-generated update logs is that they don’t manage to group changes from the same component together, which is another reason for poor readability.
Our current update log is a “rough draft” of the script, which is then distilled by the package publisher into an easy-to-read update log. This approach increases the workload of some publishers, but the readability of the update logs is improved and the input-output ratio is acceptable.
5. After-sales service of technical products
“After-sales service” is the most easily neglected point when doing open source projects. If we maintain an open source project according to the requirements of technical products, then we have the responsibility to provide necessary support to users. These support include: complete product documentation, q&A groups, and some product technical blogs. With these “after-sales services”, we can form a complete closed loop of technical products, and constantly improve through the feedback of users.
Third, summary
From the perspective of Github, this article shares what we think is the right way to maintain open source projects in terms of development, publishing, maintenance, and documentation. We always keep an open mind and welcome suggestions to improve the way we manage open source projects.
The appendix
Some links to tools that might be useful:
- Lerna: Mono Repository management tool
- Github-changelog-generator: Change log automatically generates tools
- Conventional – Changelog: Another Change log generation tool
- Git-labelmaker: Automatically creates Github Labels