-
Notifications
You must be signed in to change notification settings - Fork 7
Contribution
We welcome you to check the existing issues <https://github.com/ITMO-NSS-team/Fedot.Industrial/issues>
__ for bugs or
enhancements to work on. If you have an idea for an extension to FEDOT.Industrial,
please file a new issue <https://github.com/ITMO-NSS-team/Fedot.Industrial/issues/new/choose>
__ so we can
discuss it.
Make sure to familiarize yourself with the project layout before making any major contributions.
The preferred way to contribute to FEDOT.Industrial is to fork the main repository <https://github.com/ITMO-NSS-team/Fedot.Industrial>
__ on GitHub:
-
Fork the
project repository <https://github.com/ITMO-NSS-team/Fedot.Industrial>
__: click on the 'Fork' button near the top of the page. This creates a copy of the code under your account on the GitHub server. -
Clone this copy to your local disk:
git clone [email protected]:ITMO-NSS-team/Fedot.Industrial.git
cd FEDOT.Industrial
- Create a branch to hold your changes:
git checkout -b my-contribution
-
Make sure your local environment is setup correctly for development. Installation instructions are almost identical to
the user instructions <instructions file>
__ except that FEDOT.Industrial should not be installed. If you have FEDOT.Industrial installed on your computer then make sure you are using a virtual environment that does not have FEDOT.Industrial installed. -
Start making changes on your newly created branch, remembering to never work on the
main
branch! Work on this copy on your computer using Git to do the version control. -
To check your changes haven't broken any existing tests and to check new tests you've added pass run the following (note, you must have the
nose
package installed within your dev environment for this to work):
pytest -s
- When you're done editing and local testing, run:
git add modified_files
git commit
to record your changes in Git, then push them to GitHub with:
git push -u origin my-contribution
Finally, go to the web page of your fork of the FEDOT.Industrial repo, and click 'Pull Request' (PR) to send your changes to the maintainers for review.
(If it looks confusing to you, then look up the Git documentation <http://git-scm.com/documentation>
__ on the web.)
Before you submit a pull request for your contribution, please work through this checklist to make sure that you have done everything necessary so we can efficiently review and accept your changes.
If your contribution changes FEDOT.Industrial in any way:
-
Update the
documentation <https://github.com/ITMO-NSS-team/Fedot.Industrial/tree/main/docs>
__ so all of your changes are reflected there. -
Update the
README <https://github.com/ITMO-NSS-team/Fedot.Industrial/blob/main/README.md>
__ if anything there has changed.
If your contribution involves any code changes:
-
Update the
project unit tests <https://github.com/ITMO-NSS-team/Fedot.Industrial/tree/main/tests>
__ to test your code changes. -
Make sure that your code is properly commented with
docstrings <https://www.python.org/dev/peps/pep-0257/>
__ that have structure according toGoogle-style docstrings <https://sphinxcontrib-napoleon.readthedocs.io/en/latest/example_google.html#example-google>
__ and comments explaining your rationale behind non-obvious coding practices.
If your contribution requires a new library dependency:
-
Double-check that the new dependency is easy to install via
pip
or Anaconda and supports Python 3. If the dependency requires a complicated installation, then we most likely won't merge your changes because we want to keep FEDOT.Industrial easy to install. -
Add the required version of the library to
requirements.txt <https://github.com/ITMO-NSS-team/Fedot.Industrial/blob/main/requirements.txt>
__
Take care of the documentation.
All the documentation is created with the Sphinx autodoc feature. Use .. automodule:: <module_name> section which describes all the code in the module.
-
If a new package with several scripts:
-
Go to
docs/source/Industrial <https://github.com/ITMO-NSS-team/Fedot.Industrial/tree/main/docs/source/Industrial>
__ and create new your_name_for_file.rst file. -
Add a Header underlined with “=” sign. It’s crucial.
-
Add automodule or autoclass description for each of your scripts. ::
.. automodule:: core.your.first.script.path :members: :no-undoc-members:
.. autoclass:: core.your.second.script.path.class :members: :no-undoc-members: ...
-
Add your_name_for_file to the toctree at docs/source/Industrial/index.rst
-
-
If a new module to the existed package:
Most of the sections are already described in
docs/source/Industrial <https://github.com/ITMO-NSS-team/Fedot.Industrial/tree/main/docs/source/Industrial>
__ , so you can:- choose the most appropriate and repeat 3-d step from the previous section.
- or create a new one and repeat 2-3 steps from the previous section.
-
If a new function or a class to the existing module:
Be happy. Everything is already done for you.
After submitting your pull request,
Travis-CI <https://travis-ci.com/>
__ will automatically run unit tests
on your changes and make sure that your updated code builds and runs on
Python 3. We also use services that automatically check code quality and
test coverage.
Check back shortly after submitting your pull request to make sure that your code passes these checks. If any of the checks come back with a red X, then do your best to address the errors.
This document guide is based on well-written TPOT Framework contribution guide <https://github.com/EpistasisLab/tpot/blob/master/docs_sources/contributing.md>
__.