Metadata-Version: 2.1
Name: aiojenkins
Version: 0.4.1
Summary: Asynchronous library of Jenkins API based on aiohttp
Home-page: https://github.com/pbelskiy/aiojenkins
Author: Petr Belskiy
Author-email: petr.belskiy@gmail.com
License: MIT
Download-URL: https://pypi.org/project/aiojenkins
Keywords: aiojenkins,async jenkins api
Platform: UNKNOWN
Requires-Python: >=3.6
Description-Content-Type: text/markdown
Requires-Dist: aiohttp

# aiojenkins

![Tests](https://github.com/pbelskiy/aiojenkins/workflows/Tests/badge.svg)
![Coveralls github](https://img.shields.io/coveralls/github/pbelskiy/aiojenkins?label=Coverage)
![PyPI - Downloads](https://img.shields.io/pypi/dm/aiojenkins?color=1&label=Downloads)

Asynchronous python library of Jenkins API endpoints based on aiohttp 🥳

Initial version of aiojenkins. Public API is still unstable (work is in progress)

Minimal Python version is 3.6 due async await and f-strings.

The package is tested on below matrix:
- CPython: 3.6, 3.7, 3.8
- Jenkins LTS: 1.554, 2.60.3, latest

## Installation

```sh
pip install aiojenkins
```

## Usage

Start new build:
```python
import asyncio
import aiojenkins

async def example():
    jenkins = aiojenkins.Jenkins('http://your_server/jenkins', 'login', 'password')
    await jenkins.builds.start('job_name', dict(parameter='test'))

asyncio.run(example())
```
[__Please look at tests directory for more examples.__](https://github.com/pbelskiy/aiojenkins/tree/master/tests)

## Testing

Currently tests aren't using any mocking.
I am testing locally with dockerized LTS Jenkins ver. 2.222.3

Prerequisites: `docker, pytest pytest-cov pytest-asyncio`

```sh
docker run -d --name jenkins --restart always -p 8080:8080 jenkins/jenkins:lts
docker exec jenkins cat /var/jenkins_home/secrets/initialAdminPassword
python3 -m pytest -v --cov=aiojenkins --cov-report=term --cov-report=html
```

## Contributing

Feel free to PR :)


### Implemented API

- jenkins
  - get_status() -> dict
  - get_version() -> JenkinsVersion
  - is_ready() -> bool
  - wait_until_ready()
  - quiet_down()
  - cancel_quiet_down()
  - restart()
  - safe_restart()
  - generate_token(name: str) -> Tuple[str, str]
  - revoke_token(token_uuid: str)
  - run_groovy_script(self, script: str) -> str
  - nodes
    - get_all() -> dict
    - get_info(name: str) -> dict
    - get_failed_builds(self, name: str) -> List[dict]
    - get_all_builds(self, name: str) -> List[dict]
    - get_config(name: str) -> str
    - is_exists(name: str) -> bool
    - construct(name: str,
                remote_fs: str = '/tmp',
                executors: int = 2) -> dict
    - create(name: str, config: dict)
    - delete(name: str)
    - enable(name: str)
    - disable(name: str, message: str = '')
    - update_offline_reason(name: str, message: str)
  - jobs
    - get_all() -> dict
    - get_info(name: str) -> dict
    - get_config(name: str) -> str
    - is_exists(name: str) -> bool
    - construct_config(description: str = None,
                       parameters: List[dict] = None,
                      commands: List[str] = None) -> str:
    - create(name: str, config: str)
    - delete(name: str)
    - copy(name: str, new_name: str)
    - rename(name: str, new_name: str)
    - enable(name: str)
    - disable(name: str)
  - builds
    - get_all(name: str) -> list
    - get_info(name: str, build_id: int) -> dict
    - get_url_info(url: str) -> dict
    - get_output(name: str, build_id: int) -> str
    - is_exists(name: str, build_id: int) -> bool
    - get_queue_id_info(self, queue_id: int) -> dict
    - start(name: str,
            parameters: dict = None,
            delay: int = 0) -> int
    - stop(name: str, build_id: int)
    - delete(name: str, build_id: int)
- jenkins.utils
  - construct_job_config(*, description: str = None,
                         parameters: List[dict] = None,
                         commands: List[str] = None) -> str
  - construct_node_config(*, name: str,
                          remote_fs: str = '/tmp',
                          executors: int = 2) -> dict
  - parse_build_url(build_url) -> Tuple[str, int]


