################ Github Actions ################ This project is automatically processed using `Github Actions `__, a tool to build continuous integration and continuous deployment pipelines for testing, releasing and deploying software without the use of third-party websites/platforms. Currently, we have developed the next procedures for this project: ************* Pull Request ************* - **Python Code format check**: Python code format is checked in every pull request following **Pep8** `standard `__ (Level 2 aggressive) and `isort `__ to sort imports. In case the code does not follow the standard, a warning will rise during the workflow execution. - **Code type check**: We are using `pytype `__ in *Sinergym* module. This check controls input and output types in functions and methods. This workflow ignores `import-error` type using command `pytype -d import-error sinergym/`. For example, **pytype** cannot include google cloud storage module, so this option specification is necessary. If some type error happens, the workflow shows an error until the user fixes it. - **Documentation checks**: This action checks whether source documentation has been modified in every pull-request. If source documentation has been updated, it will **compile** documentation with *Sphinx* and raise errors if they exist. This workflow checks **vocabulary spelling** too. If you have a mistake and *Sphinx* finds an unknown word, this workflow will return an error. In case you want to use a word that is not in the default dictionary, please add that word to `docs/source/spelling_wordlist.txt` (please, respect alphabetical order) because Sphinx-spelling accepts words allocated in that list. .. Warning:: Sphinx Warning messages behave like errors for workflow status. .. Note:: Sphinx Spelling works on code docstring too. - **Testing**: It is an action that builds a remote container using *Dockerfile* and executes **Pytest** inside that container. It is a remote container because it is built in Github, just for testing purposes. - **Repository security**: This workflow identifies differences between source and base in workflows and tests. It executes that functionality only in forked repositories in order to **prevent malicious software** in the workflow, for instances, attempts to ignore tests. The event is *pull_request_target*, this means the workflow is checkout from base repository (our main branch) and it cannot be manipulated by third-parties. .. Note:: These checks can be skipped in a specific commit writing `[ci skip]` string in commit message. For more information, see issue `#161 `__. ************************************ Push main (or merge a pull request) ************************************ These workflows will be executed in sequential order: - **Apply format**: A bot generates a commit in the main branch applying format changes when it is necessary (**autopep8** 2 level aggressive and/or **isort** module). - **Update Documentation build to GitHub pages**: A bot generates a commit in **main** branch applying new documentation build when it is necessary (spelling check included here too) in a folder called **docs/compilation**. The version control ignores the default folder name *build*. - **Update our Docker Hub repository**: This job builds a container with all extra requirements and it is pushed to our `Docker Hub repository `__ using *latest* tag automatically. This update is executed only when the previous format and documentation workflows have successfully finished. - **Testing and CodeCov update**: Project tests are executed in the same way than pull request event. However, when test are executed, the coverage report is uploaded to CodeCov service in order to register the code coverage percentage in the project. ******************************** New release created or modified ******************************** - When a **release** is *published* or *edited* manually in the repository, an action catches the release tag version and it uses it to build a container and upload/update on Docker Hub with that tag version. - At the same time, another job will update the **PyPi** *Sinergym* repository with its current version tag. .. Note:: See `.github/workflows YML files `__ to see the code we use. .. Note:: If you forked the repository from *Sinergym*, we recommend you to **enable Github Action in your project** in order to take advantage of this functionality in your developments. .. Note:: Currently, the workflows explained above upload two containers. A container with **all extra packages** and a container with **minimal** installation.