So you've decided that you would like to contribute to AdvantEDGE project... what next?
It's great to hear that you have interest in AdvantEDGE & we'd love to accept your bug fix or other contributions; there is however few small guidelines that you need to follow before getting started.
... But I just have a question & I don't want to read this whole thing!!!
There are three main ways of contributing to the project: by reporting an issue, by suggesting an enhancement or by contributing content.
As such, we cover these use cases below
Please don't open a GitHub Issue to ask a question; you'll get faster result by using the resources below.
We put time & efforts keeping the wiki up to date, so we recommend to look there first.
- Project questions -- FAQ & Roadmap
- Concepts questions -- Platform concepts, platform APIs, Edge App. Models, Edge App. Types & Frontend concepts
- Services questions -- platform APIs, Location service, Application State Transfer service
- Setup questions -- Hardware, Runtime environment, Development environment
- Deployment questions -- Deployment cheat-sheet, meepctl CLI tool, Build, Deploy, Upgrade, Test
- Usage questions -- GUI, basic operation, creating a first scenario, scenario monitoring, using external nodes, pod placement
Of course - because we cannot document everything - if you still have a question, you can reach out to us.
We use GitHub's new feature called Discussions - simply start a discussion and you will have direct access to the development team!
Whether it's a bug found while using the platform or simply a typo noticed while browsing the documentation, we appreciate that you open a GitHub issue (here)
When reporting a bug, try to be as concise & specific as possible so we can reproduce the problem.
A Bug Report template is provided in GitHub to help documenting the problem.
Use the Custom Issue template to provide a link to the page, a copy the problematic text and an indication of what the problem is.
We appreciate feature enhancements and as such, we collect feature ideas via GitHub issues (here)
If you are not sure about the proposed enhancement, it's always a good idea to communicate with us by starting a Discussion about the feature beforehand.
Contributing content is more involving than submitting an issue or an enhancement request as it requires a CLA and learning how to operate with the project team.
The following sub-sections cover these aspects.
In order for us to accept content contributions, a Contributor License Agreement (CLA) is required.
Fill-in the requested information and send it to [email protected] using subject CLA
Note: it is important to include your GitHub id(s) in the CLA so we know who you are when submitting a pull-request.
In order to prepare your contribution, you will need to create your fork of the AdvantEDGE repo. To do so, simply click the Fork button in the repo
Your fork is your own copy of the repo where you can modify things without impacting others; your fork's GitHub path should be https://github.com/<your-gh-username/AdvantEDGE.git
After creating your fork, you can clone it locally and start making modifications. We also require making modifications on a branch originating from the develop
branch (preferred) or alternatively the master
branch.
git clone https://github.com/<your-gh-username/AdvantEDGE.git
git checkout develop
git checkout -b <your-branch-name>
During development, keep your commit message concise and precise so we understand what the change is about.
We accept a single contribution per branch, so if you are fixing two bugs - please create two different branches each originating from develop
& each containing only the necessary changes for the bug they fix.
Finally, for code contributions, we require that you run the linter (e.g. meepctl lint all
), Unit Tests and Cypress tests on your branch.
Note: Keep results to include in your pull request.
With implementation complete and linter/tests passing
You are ready to make your pull request, here.
First, make sure that all necessary code is committed to your branch and that you have pushed your branch back to your fork.
git add <your-modified-files>
git commit -m 'what-has-changed'
git push
If unsure, it's a good idea to double check that your branch has been pushed back to the repo using the GitHub browser client. Your fork can be accessed from here, your branch should show up in the branch drop down of your fork and your changes should show up once the branch is selected.
In the pull request, indicate the branch containing your changes, the nature of the changes you made, a reference to the related GitHub issue and the test results.
What to expect next?
We do peer reviews of all internal contributions - so as an external contributor you can expect that someone from the core team will review your PR.
This is normal and is part of the process. Be patient as we may be busy addressing other issues - we will eventually get back to you with a status & possibly change requests. Please note that we reserve the right to accept or not a contribution. For internal reasons, from time to time, we may decide not to include your proposition, this has nothing to do with your skills or the value of your contribution.
Making first contributions can be intimidating - after all it's often difficult to figure out where to start and learn how to interact with a new team (that's us :) ). This is normal and we are here to help.
We recommend the following approach:
- Start small - documentation contributions are an easy way to start as they are simpler to perform. If you used the project before (or not) and find that documentation is confusing / missing - then you may have an opportunity. Alternatively, look for issues tagged
documentation
&good first issue
- Look for the issues tagged
good first issue
- as these are simpler and often isolated / self-contained - Once you are accustomed with the project, you can start tackling other larger existing issues.
- The holly-grail of contributing would be opening an issue / getting an enhancement request approved and submitting the PR implementing it
Anyhow, when picking an issue, it's always a good idea to comment on the issue to let others know you are looking at it; you can also email us at [email protected]
We hope this is helpful - and...
... looking forward to hear from you!