Skip to content

Latest commit

 

History

History
87 lines (56 loc) · 8.22 KB

CONTRIBUTING.md

File metadata and controls

87 lines (56 loc) · 8.22 KB

Contributing to Open License Manager

The following is a set of guidelines for contributing to Open License Manager and its sub-projects.

How to contribute

Interacting with the team

If you're experiencing issues with the project, due to lack of documentation or you basically just want to ask a question you can contact us on project forum. If you're compiling licensecc following the guide and you meet an issue you'd better open a bug. Please try to be very specific about your problem. You can use the guidelines in "How to Submit A (Good) Bug Report" to structure your question.

Reporting Bugs

Before creating bug reports, please check the repository to see if the problem has already been reported. If it has and the issue is still open, add a comment to the existing issue instead of opening a new one. When you are creating a bug report, please include as many details as possible.

How to submit a good Bug Report

Bugs are tracked as GitHub issues. Explain the problem and include additional details to help maintainers reproduce the problem:

  • Use a clear and descriptive title for the issue to identify the problem.
  • Describe the exact steps which reproduce the problem in as many details as possible. For example, start by explaining how are you using Open License Manager.
  • Provide specific examples to demonstrate the steps. Include links to files or GitHub projects, or licenses, which can cause the bug. If you're providing code snippets in the issue, use Markdown code blocks.
  • Describe the current behavior and the expected one* Describe the current result, and the expected behavior.
  • Provide a unit test to demonstrate the bug. The best way to report a bug, and to have it fixed forever is to design a test to demonstrate it.
  • If you're reporting that Open License Manager crashed, include a crash dump and the associated message.
  • Label the issue as bug.

Provide more context by answering these questions:

  • Can you reproduce the problem using the example application?
  • Can you reliably reproduce the issue? If not, provide details about how often the problem happens and under which conditions it normally happens.
  • If the problem is related integrating Open License Manager with your application, produce a minimal example to demonstrate it Does the problem happen only with some license type? Does the problem only happen in Linux/Docker/Windows?

Include details about your configuration and environment:

  • Update Open License Manager to the latest version If possible try to pull the latest changes from develop branch.
  • What's the name and version of the OS you're using?
  • What's the name and version of the compiler you're using? Are you cross compiling? If you're cross compiling specify the host and the target operating system.
  • What's are the cmake command line you used to generate your build scripts?
  • Are you running Open License Manager in a virtual machine/docker? If so, which VM software are you using and which operating systems and versions are used for the guest?

Suggesting Enhancements or new features

This section guides you through submitting an enhancement suggestion for Open License Manager, including completely new features and minor improvements to existing functionality. Following these guidelines helps maintainers and the community understand your suggestion 📝 and find related suggestions 🔎.

If you have an idea about a new feature or a question about an environment support, the simplest way you can reach the team is through the project forum.

Otherwise you can open an enhancement suggestion in github. Before you do so check existing enhancement request to see if the enhancement has already been suggested. When you are creating an enhancement suggestion, please include as many details as possible.

Please also check for the current and planned features in the wiki to see where the project is heading to.

How to submit a (good) enhancement suggestion

Enhancement suggestions are tracked as GitHub issues.

  • Use a clear and descriptive title for the issue to identify the suggestion.
  • Provide a detailed description of the suggested enhancement in as many details as possible.
  • Explain why this enhancement would be useful to most Open License Manager users and isn't something that can or should be implemented.
  • List some other software protection where this feature exists.
  • Specify the name and version of the OS you're proposing the enhancement for. If applicable include all the environment informations: is this for running the application in a VM? in a Docker?
  • Label the issue as enhancement.

Your first code contribution

Unsure where to begin contributing to Open License Manager? You can start by looking through the good first issue and help-wanted issues.

You can have a look to the project upcoming milestones to see what's going to be implemented soon and what is the project direction. If you decide to contribute on an issue scheduled in the current milestone, comment on the issue first. If the issue is marked as "assigned" there may be already some work done for it. Commenting on the issue will ensure we don't duplicate our work. Also have a look to the branches: there may be a feature branch corresponding to the issue with some work already done.

If you have already forked the repository to implement a specific feature, and you want your code to be merged in the main repository please first file an enhancement request as explained in suggesting enhancements. If you found a bug and you want to propose a fix please report a bug before.

We apply a subset of GitFlow development workflow. Be sure to work against develop branch, since master is reserved for stable releases, and may be outdated.

General coding rules

Supposing you already know how to contribute to an open source project on GitHub (if you have doubts you can check this short guide ), you're working on an existing issue the code is already committed on your fork.

  • Ensure your feature branch is up to date with the develop, eventually merge the latest changes from the develop branch. This will help us save time.
  • Reformat the changed code using "clang-format" to keep consistent formatting style. The style we use is in .clang-format at the base of the project.
  • Prepare your pull request, in the pull request comment reference the issue the pull request will fix.
  • Check your pull request compiles and pass the checks on Travis CI
  • In the pull request comment reference the issue you want to fix.
Don't
  • Don't reformat the code following your personal likes, it introduce a lot of "noise" and makes very hard to merge. Use the clang-format style provided at the base of the project.
  • Very large pull requests with few comments, no corresponding issue explaining what's it about will probably be rejected.
    • We understand that the project is still in beta stage, however we would like to discuss it with you before we take project changing decision. You can reach us on the project forum.