第48节 Contributing to {name}


❤️💕💕记录sealosopen in new window开源项目的学习过程。k8s,docker和云原生的学习open in new window。Myblog:http://nsddd.topopen in new window


[TOC]


name: CONTRIBUTING.md
**替换:**

{name} -> log

{github} -> kubecub/log

{blog} -> 博客

{slack} -> 链接

{email} -> [3293172751nss@gmail.com](mailto:3293172751nss@gmail.com)

{wechat} -> 替换为图片连接地址

{twitter} -> 

Google docs:

Contributing to {name}

So, you want to hack on {name}? Yay!

First of all, thank you for considering contributing to our project! We appreciate your time and effort, and we value any contribution, whether it's reporting a bug, suggesting a new feature, or submitting a pull request.

This document provides guidelines and best practices to help you contribute effectively.

📇Topics

What we expect of you

We hope that anyone can join {name} , even if you are a student, writer, translator

Please meet the minimum version of the Go language published in go.mod. If you want to manage the Go language version, we provide tools to install gvmopen in new window in our Makefile

You'd better use Linux as the development environment, Linux with Makefile can help you quickly build and test {name} project.

The Makefile is for every developer, even if you don't know how to use the Makefile tool, don't worry, we provide two great commands to get you up to speed with the Makefile architecture, make help and make help-all, it can reduce problems of the developing environment.

If you are familiar with Makefile , you can easily see the clever design of the {name} Makefile. Storing the necessary tools such as golangci in the /tools directory can avoid some tool version issues.

Code of Conduct

Code and doc contribution

Every action to make project {name} better is encouraged. On GitHub, every improvement for {name} could be via a PRopen in new window (short for pull request).

  • If you find a typo, try to fix it!
  • If you find a bug, try to fix it!
  • If you find some redundant codes, try to remove them!
  • If you find some test cases missing, try to add them!
  • If you could enhance a feature, please DO NOT hesitate!
  • If you find code implicit, try to add comments to make it clear!
  • If you find code ugly, try to refactor that!
  • If you can help to improve documents, it could not be better!
  • If you find document incorrect, just do it and fix that!
  • ...

Where should I start?

Getting good at GitHub is the first step, we have a list of labesopen in new window and reading some of the common tagsopen in new window helps us get involved in the community quickly.GitHub allows you to filter out types of issues and pull requests, which helps you discover items in need of triaging. This table includes some predetermined searches for convenience:

SearchWhat it sorts
created-ascopen in new windowUntriaged issues by age
needs-triageopen in new windowIssues that need to be assigned to a Labels
is:open is:issueopen in new windowNewest incoming issues
comments-descopen in new windowBusiest untriaged issues, sorted by # of comments
comments-ascopen in new windowIssues that need more attention, based on # of comments

We suggest preparing your triage by filtering out the oldest, unlabelled issues and pull requests first.

  1. If you are new to the project, don't know how to contribute {name}, please check out the good first issueopen in new window label and help wantedopen in new window.
  2. You should be good at filtering the {name} issue tags and finding the ones you like, such as RFCopen in new window for big initiatives, features for featureopen in new window proposals, and bugopen in new window fixes.
  3. If you are looking for something to work on, check out our open issuesopen in new window.
  4. If you have an idea for a new feature, please open an issueopen in new window, and we can discuss it.

Note Reply to /assign or /assign @yourself with a question you wish to resolve, and we'll assign the question to you and your name will be listed under Assignees

Design documents

For any substantial design, there should be a well-crafted design document. This document is not just a simple record, but also a detailed description and manifestation, which can help team members better understand the design thinking and grasp the design direction. In the process of writing the design document, we can choose to use tools such as Google Docs or Notion, and even mark RFC in issuesopen in new window or discussionsopen in new window for better collaboration. Of course, after completing the design document, we should also add it to our Shared Driveopen in new window and notify the appropriate working group to let everyone know of its existence. Only by doing so can we maximize the effectiveness of the design document and provide strong support for the smooth progress of the project.

Anybody can access the shared Drive for reading. To get access to comment. Once you've done that, head to the shared Driveopen in new window and behold all the docs.

In addition to that, we'd love to invite you to Join Our Slack where you can play with your imagination, tell us what you're working on, and get a quick response.

When documenting a new design, we recommend a 2-step approach:

  1. Use the short-form RFC template to outline your ideas and get early feedback.
  2. Once you have received sufficient feedback and consensus, you may use the longer-form design doc template to specify and discuss your design in more details.

In order to contribute a feature to {name} you'll need to go through the following steps:

  • Discuss your idea with the appropriate working groups on the working group's Slack channel.
  • Once there is general agreement that the feature is useful, create a GitHub issue to track the discussion. The issue should include information about the requirements and use cases that it is trying to address.
  • Include a discussion of the proposed design and technical details of the implementation in the issue.

But keep in mind that there is no guarantee of it being accepted and so it is usually best to get agreement on the idea/design before time is spent coding it. However, sometimes seeing the exact code change can help focus discussions, so the choice is up to you.

Getting Started

Note

A simple example allows you to quickly contribute your first PR to {name}. To propose PR for the {name} item, we assume you have registered a GitHub ID. Then you could finish the preparation in the following steps:

  1. Fork the repository({name})

  2. CLONE your own repository to master locally. Use git clone https://github.com/<your-username>/{name}.git to clone repository to your local machine. Then you can create new branches to finish the change you wish to make.

  3. Set Remote upstream to be https://github.com/{github}.git using the following two commands:

    git remote add upstream https://github.com/{github}.git
    ❯ git remote set-url --push upstream no-pushing
    

    With this remote setting, you can check your git remote configuration like this:

    ❯ git remote -v
    origin     https://github.com/<your-username>/{name}.git (fetch)
    origin     https://github.com/<your-username>/{name}.git (push)
    upstream   https://github.com/{github}.git (fetch)
    upstream   no-pushing (push)
    

    Adding this, we can easily synchronize local branches with upstream branches.

  4. Create a new branch for your changes (use a descriptive name, such as fix/bug-123 or feature/add-new-xxx and release/xxx).

    cd {name}git fetch upstream
    ❯ git checkout upstream/main
    

    Note

    Please don't use git pull instead of the above fetch and rebase. Since git pull executes a merge, it creates merge commits. These make the commit history messy and violate the principle that commits ought to be individually understandable and useful.

    You might also consider changing your .git/config file via git config branch.autoSetupRebase always to change the behavior of git pull, or another non-merge option such as git pull --rebase.

    Create a new branch:

    git checkout -b <new-branch>
    

    Make any change on the new-branch then use Makefile build and test your codes.

  5. Commit your changes to your local branch, lint before committing and commit with sign-off

    git rebase upstream/main
    ❯ make lint	  # golangci-lint run -c .golangci.ymlgit add -A  # add changes to staginggit commit -a -s -m "fix: message for your changes" # -s adds a Signed-off-by trailer
    
  6. Push your branch to your forked repository, it is recommended to have only one commit for a PR.

    # sync up with upstreamgit fetch upstream
    ❯ git rebase upstream/main
    ❯ git rebase -i	<commit-id> # rebase with interactive mode to `squash` your commits into a single onegit push # push to the remote repository, if it's a first time push, run git push --set-upstream origin <new-branch>
    

    You can also use git commit -s --amend && git push -f to update modifications on the previous commit.

    If you have developed multiple features in the same branch, you should create PR separately by rebasing to the main branch between each push:

    # create new branch, for example git checkout -b feature/infragit checkout -b <new branch>
    # update some code, feature1git add -Agit commit -m -s "feat: feature one"git push # if it's first time push, run git push --set-upstream origin <new-branch>
    # then create pull request, and merge
    # update some new feature, feature2, rebase main branch first.git rebase upstream/main # rebase the current branch to upstream/main branchgit add -Agit commit -m -s "feat: feature two"
    # then create pull request, and merge
    
  7. Open a pull request to {github}:main

    It is recommended to review your changes before filing a pull request. Check if your code doesn't conflict with the main branch and no redundant code is included.

Style and Specification

We divide the problem into security and general problems:

Reporting security issues

Security issues are always treated seriously. As our usual principle, we discourage anyone to spread security issues. If you find a security issue of {name}, please do not discuss it in public and even do not open a public issue.

Instead we encourage you to send us a private email to 📧Gmail:{email}. to report this.

Reporting general issues

To be honest, we regard every user of {name}as a very kind contributor. After experiencing {name}, you may have some feedback for the project. Then feel free to open an issue via NEW ISSUEopen in new window.

Since we collaborate project {name} in a distributed way, we appreciate WELL-WRITTEN, DETAILED, EXPLICIT issue reports. To make the communication more efficient, we wish everyone could search if your issue is an existing one in the searching list. If you find it existing, please add your details in comments under the existing issue instead of opening a brand new one.

To make the issue details as standard as possible, we setup an ISSUE TEMPLATEopen in new window for issue reporters. You can find three kinds of issue templates there: question, bug report and feature request. Please BE SURE to follow the instructions to fill fields in template.

There are a lot of cases when you could open an issue:

  • bug report
  • feature request
  • {name} performance issues
  • feature proposal
  • feature design
  • help wanted
  • doc incomplete
  • test improvement
  • any questions on {name} project
  • and so on

Also, we must be reminded when submitting a new question about {name}, please remember to remove the sensitive data from your post. Sensitive data could be password, secret key, network locations, private business data and so on.

Note We have requirements for Commits, PR, Docs, and good standards help us collaborate better and understand what you're doing.

Commit Rules

Actually in {name}, we take two rules serious when committing:

🥇 Commit Message:

Commit message could help reviewers better understand what the purpose of submitted PR is. It could help accelerate the code review procedure as well. We encourage contributors to use EXPLICIT commit message rather than ambiguous message. In general, we advocate the following commit message type:

We use Semantic Commitsopen in new window to make it easier to understand what a commit does and to build pretty changelogs. Please use the following prefixes for your commits:

  • docs: xxxx. For example, "docs: add docs about storage installation".
  • feature: xxxx.For example, "feature: make result show in sorted order".
  • bugfix: xxxx. For example, "bugfix: fix panic when input nil parameter".
  • style: xxxx. For example, "style: format the code style of Constants.java".
  • refactor: xxxx. For example, "refactor: simplify to make codes more readable".
  • test: xxx. For example, "test: add unit test case for func InsertIntoArray".
  • chore: xxx. For example, "chore: integrate travis-ci". It's the type of mantainance change.
  • other readable and explicit expression ways.

On the other side, we discourage contributors from committing message like the following ways:

  • fix bug
  • update
  • add doc

🥈 Commit Content:

Commit content represents all content changes included in one commit. We had better include things in one single commit which could support reviewer's complete review without any other commits' help.

In another word, contents in one single commit can pass the CI to avoid code mess. In brief, there are two minor rules for us to keep in mind:

  1. avoid very large change in a commit.
  2. complete and reviewable for each commit.
  3. words are written in lowercase English, not uppercase English or other languages such as Chinese.

No matter what the commit message, or commit content is, we do take more emphasis on code review.

An example for this could be:

git commit -a -s -m "docs: add a new section to the readme"

PR Description

PR is the only way to make change to {name} project files. To help reviewers better get your purpose, PR description could not be too detailed. We encourage contributors to follow the PR templateopen in new window to finish the pull request.

You can find some very formal PR in RFCopen in new window issues and learn about them.

📖 Opening PRs:

  • As long as you are working on your PR, please mark it as a draft.
  • Please make sure that your PR is up-to-date with the latest changes in main
  • Mention the issue that your PR is addressing. For example, Fixes: #{ID_1}, #{ID_2}
  • Make sure that your PR passes all checks.

🈴 Reviewing PRs:

  • Be respectful and constructive.
  • Assign yourself to the PR.
  • Check if all checks are passing.
  • Suggest changes instead of simply commenting on found issues.
  • If you are unsure about something, ask the author.
  • If you are not sure if the changes work, try them out.
  • Reach out to other reviewers if you are unsure about something.
  • If you are happy with the changes, approve the PR.
  • Merge the PR once it has all approvals and the checks are passing.

⚠️ DCO check:

We have a DCO checkopen in new window which runs on every PR to verify that the commit has been signed off.

Once installedopen in new window, this integration will set the statusopen in new window to failed if commits in a Pull Request do not contain a valid Signed-off-by line.

To sign off the last commit you made, you can use:

git commit --amend --signoff

Contributors sign-off that they adhere to these requirements by adding a Signed-off-by line to commit messages.

Git even has a -s command line option to append this automatically to your commit message:

git commit -s -m "docs: this is my commit message"

You can also automate signing off your commits by adding the following to your .zshrc or .bashrc:

cat ~/.bashrc || cat ~/.zshrc
git() {
  if [ $# -gt 0 ] && [[ "$1" == "commit" ]] ; then
     shift
     command git commit --signoff "$@"
  else
     command git "$@"
  fi
}

CI actions

We host CI on GitHub Actionsopen in new window, we will make sure PR pass tests before we can merge it.

These two kind of tests: lint and unit test

lint tests if your code matches our code conventions, please consult golangci-lintopen in new window and lint configopen in new window

Note

You can use the Makefile to run Lint with the command make lint.

unit test runs all the test in code, and the code coverage should not less than 60 percent, record us in codeclimateopen in new window {name} the unit test coverage data.

Note

We use the Makefile utility, make tese to run the unit tests, and the make cover utility to check the unit test coverage.

Try your best to keep every function has been tested, it keeps the function behaves as intended.

Docs Contribution

The documentation for {name} includes:

  • README.mdopen in new window: This file includes the basic information and instructions for getting started with {name}.
  • README_zh.mdopen in new window: This file includes the basic information and instructions for getting started with {name}in Chinese.
  • CONTRIBUTING.mdopen in new window: This file contains guidelines for contributing to {name}'s codebase, such as how to submit issues, pull requests, and code reviews.
  • Official Documentation: This is the official documentation for {name}, which includes comprehensive information on all of its features, configuration options, and troubleshooting tips.

Please obey the following rules to better format the docs, which would greatly improve the reading experience.

  1. Please do not use Chinese punctuations in English docs, and vice versa.
  2. Please use upper case letters where applicable, like the first letter of sentences / headings, etc.
  3. Please specify a language for each Markdown code blocks, unless there's no associated languages.
  4. Please insert a whitespace between Chinese and English words.
  5. Please use the correct case for technical terms, such as using HTTP instead of http, MySQL rather than mysql, Kubernetes instead of kubernetes, etc.
  6. Please check if there's any typos in the docs before submitting PRs.

Markfile Lint: We integrated in the CICD actions markdownlintopen in new window, it detects Markfile specification.

Note We recommend reading markdownlint rulesopen in new window, This document contains a description of all rules, what they are checking for, as well as an examples of documents that break the rule and corrected versions of the examples.

Engage to help anything

We choose GitHub as the primary place for {name} to collaborate. So the latest updates of {name} are always here. Although contributions via PR is an explicit way to help, we still call for any other ways.

In a word, ANY HELP IS CONTRIBUTION.

Release version

Releases of {name} are done using Release Pleaseopen in new window and GoReleaseropen in new window. The workflow looks like this:

🎯 A PR is merged to the main branch:

  • Release please is triggered, creates or updates a new release PR
  • This is done with every merge to main, the current release PR is updated every time

🎯 Merging the 'release please' PR to main:

  • Release please is triggered, creates a new release and updates the changelog based on the commit messages
  • GoReleaser is triggered, builds the binaries and attaches them to the release
  • Containers are created and pushed to the container registry

With the next relevant merge, a new release PR will be created and the process starts again

👀 Manually setting the version:

If you want to manually set the version, you can create a PR with an empty commit message that contains the version number in the commit message. For example:

Such a commit can get produced as follows:

git commit --allow-empty -m "chore: release 0.0.3" -m "Release-As: 0.0.3

Contact Us

We value close connections with our users, developers, and contributors here at kubecub. With a large community and maintainer team, we're always here to help and support you. Whether you're looking to join our community or have any questions or suggestions, we welcome you to get in touch with us.

Our most recommended way to get in touch is through Slackopen in new window. Even if you're in China, Slack is usually not blocked by firewalls, making it an easy way to connect with us. Our Slack community is the ideal place to discuss and share ideas and suggestions with other users and developers of kubecub. You can ask technical questions, seek help, or share your experiences with other users of kubecub.

In addition to Slack, we also offer the following ways to get in touch:

  • We also have Slack channels for you to communicate and discuss. To join, visit https://slack.com/ and join our 👀 kubecub slackopen in new window team channel.
  • Get in touch with us on 📨Gmail: 3293172751nss@gmail.com. If you have any questions or issues that need resolving, or any suggestions and feedback for our open source projects, please feel free to contact us via email.
  • Read our 🤖kubecub. Our kubecub is a great place to stay up-to-date with kubecub projects and trends. On the kubecub, we share our latest developments, tech trends, and other interesting information.
  • Add 🕊️Twitteropen in new window . If you prefer social media, our Twitter account is a great way to stay up-to-date with kubecub project news and trends. On Twitter, we share our latest tech and trends, as well as relevant news and events.
  • Add 📲Wechatopen in new window and indicate that you are a user or developer of kubecub. We will process your request as soon as possible.

Whether you're looking to join our community or have any questions or suggestions, we welcome you to get in touch with us.

END 链接