Skip to main content

Kraken Client Tool

Overview

kkci is a tool that interacts with Kraken Server. It provides:

  • custom tools commands like list tools, register new tool or upload a tool code
  • auxiliary commands - like get kkci or server versions

Installation

kkci is hosted on https://pypi.org and can be installed by pip tool.

The command for kkci installation looks as follows:

$ pip install krakenci-client==0.980
Collecting krakenci-client==0.980
Using cached krakenci-client-0.980.tar.gz (4.6 kB)
Installing build dependencies ... done
Getting requirements to build wheel ... done
Preparing metadata (pyproject.toml) ... done
Collecting requests<3.0.0,>=2.26.0
Using cached requests-2.28.1-py3-none-any.whl (62 kB)
Collecting click<8.0.0,>=7.1.2
Using cached click-7.1.2-py2.py3-none-any.whl (82 kB)
Collecting tabulate<0.9.0,>=0.8.9
Downloading tabulate-0.8.10-py3-none-any.whl (29 kB)
Collecting urllib3<1.27,>=1.21.1
Using cached urllib3-1.26.10-py2.py3-none-any.whl (139 kB)
Collecting certifi>=2017.4.17
Using cached certifi-2022.6.15-py3-none-any.whl (160 kB)
Collecting idna<4,>=2.5
Using cached idna-3.3-py3-none-any.whl (61 kB)
Collecting charset-normalizer<3,>=2
Using cached charset_normalizer-2.1.0-py3-none-any.whl (39 kB)
Building wheels for collected packages: krakenci-client
Building wheel for krakenci-client (pyproject.toml) ... done
Created wheel for krakenci-client: filename=krakenci_client-0.980-py3-none-any.whl size=4776 sha256=14c3ffa7b3676949839ddde24b82c6ffaa464dd55d17b69bbb55dffd48976162
Stored in directory: /home/godfryd/.cache/pip/wheels/78/10/bb/e935de7562c5b54ca6248247129a728662cab84f0a91ee6192
Successfully built krakenci-client
Installing collected packages: urllib3, tabulate, idna, click, charset-normalizer, certifi, requests, krakenci-client
Successfully installed certifi-2022.6.15 charset-normalizer-2.1.0 click-7.1.2 idna-3.3 krakenci-client-0.980 requests-2.28.1 tabulate-0.8.10 urllib3-1.26.10

It is good to always indicate what kkci version should be installed. In the example above, there is 0.980 version installed. The kkci version needs to match the version of Kraken Server otherwise it will not work.

The list of kkci versions can be checked on PyPI profile page: https://pypi.org/project/krakenci-client/#history. The version of Kraken Server is presented on its web pages in the top left corner.

Tools Commands

tools list

List Kraken Tools the last versions.

$ kkci -s http://admin:admin@localhost:8080 tools list
Id Name Location Entry Last Version
---- -------------- ----------------------- ------- ------------
5 artifacts 1
9 cache 1
7 cloc 1
1 git 1
10 gotest 1
11 junit_collect 1
16 local 1
17 local_tool 1
8 nglint 1
131 pkg_install minio:tool-131/tool.zip main 48d4c5e
6 pylint 1
3 pytest 1
4 rndtest 1
2 shell 1
12 values_collect 1

tools list-versions

List all versions of the given Kraken Tool.

$ kkci -s http://admin:admin@localhost:8080 tools list-versions pkg_install
Id Name Location Entry Version
---- ----------- ----------------------------------- ------- ---------
131 pkg_install minio:tool-131/tool.zip main 48d4c5e
130 pkg_install /home/godfryd/repos/kraken/pkg-tool main dev4
98 pkg_install /home/godfryd/repos/kraken/pkg-tool main dev3
97 pkg_install /home/godfryd/repos/kraken/pkg-tool main dev2
96 pkg_install /home/godfryd/repos/kraken/pkg-tool main dev1
95 pkg_install /home/godfryd/repos/kraken/pkg-tool main 14119
94 pkg_install /home/godfryd/repos/kraken/pkg-tool main dev

tools register

Register a new or overwrite the existing tool described in indicated TOOL_FILE.

$ kkci -s http://admin:admin@localhost:8080 tools register tool.json
Stored tool pkg_install@dev5

tools register-remote

Register a tool located in a remote repository indicated by URL.

$ kkci -s http://admin:admin@localhost:8080 tools register-remote \
-f pkg_install/tool.json https://github.com/Kraken-CI/kraken-tools
Stored tool pkg_install@48d4c5e

tools generate-step-file

Generate a step file for a tool by indicating its TOOL-FILE. This step file will allow running the tool on a local machine.

$ kkci tools generate-step-file tool.json
Please, enter values for pkg_install tool parameters
pkgs (string): asd
provider (string, one of ['apt', 'yum', 'dnf', 'apk']): apt
aaa (integer): 1
git_cfg parameter is complex one, enter its value manually in the step file
background (boolean, default False):
source parameter is complex one, enter its value manually in the step file
keys parameter is complex one, enter its value manually in the step file
Step file stored to step.json

tools run

Run a tool on a local machine by indicating its TOOL-FILE with step file provide with -f option.

$ kkci tools run tool.json -f step.json
execute 'python3 -m pip install -r requirements.txt --target=./vendor' in '/home/godfryd/repos/kraken-tools/pkg_install'
Collecting distro
Using cached distro-1.7.0-py3-none-any.whl (20 kB)
Installing collected packages: distro
Successfully installed distro-1.7.0
WARNING: You are using pip version 22.0.4; however, version 22.1.2 is available.
You should consider upgrading via the '/home/godfryd/.cache/pypoetry/virtualenvs/krakenci-client-gzjv3aIZ-py3.10/bin/python3 -m pip install --upgrade pip' command.
execute 'PYTHONPATH=/home/godfryd/repos/kraken-tools/pkg_install:/home/godfryd/repos/kraken-tools/pkg_install/vendor /home/godfryd/.cache/pypoetry/virtualenvs/krakenci-client-gzjv3aIZ-py3.10/bin/python -m kraken.agent.tool -m main -s /home/godfryd/repos/kraken-tools/pkg_install/step.json check-integrity' in 'None'
execute 'PYTHONPATH=/home/godfryd/repos/kraken-tools/pkg_install:/home/godfryd/repos/kraken-tools/pkg_install/vendor /home/godfryd/.cache/pypoetry/virtualenvs/krakenci-client-gzjv3aIZ-py3.10/bin/python -m kraken.agent.tool -m main -s /home/godfryd/repos/kraken-tools/pkg_install/step.json get_commands' in 'None'
execute 'PYTHONPATH=/home/godfryd/repos/kraken-tools/pkg_install:/home/godfryd/repos/kraken-tools/pkg_install/vendor /home/godfryd/.cache/pypoetry/virtualenvs/krakenci-client-gzjv3aIZ-py3.10/bin/python -m kraken.agent.tool -m main -s /home/godfryd/repos/kraken-tools/pkg_install/step.json run' in 'None'
2022-07-07 06:35:32,144 run step tool pkg_install, cmd run
2022-07-07 06:35:32,272 exec: 'sudo dnf -y install mc' in '/home/godfryd/repos/kraken/client'
2022-07-07 06:35:32,304 output: sudo: dnf: command not found
2022-07-07 06:35:32,304 step tool pkg_install, cmd run done with retcode 1 in 0secs
2022-07-07 06:35:32,305 tool response: {"status": "error", "reason": "retcode", "retcode": 1, "msg": "cmd exited with non-zero retcode: 1"}

tools upload

Upload tool's code from DIRECTORY to Kraken Server.

$ kkci -s http://admin:admin@localhost:8080 tools upload ./pkg-tool/tool.json
execute 'python3 -m pip install -r requirements.txt --target=./vendor' in '/home/godfryd/repos/kraken/pkg-tool'
Collecting pycvs
Using cached pycvs-0.0.3-py3-none-any.whl (8.8 kB)
Collecting colorama
Using cached colorama-0.4.5-py2.py3-none-any.whl (16 kB)
Collecting pexpect
Using cached pexpect-4.8.0-py2.py3-none-any.whl (59 kB)
Collecting ptyprocess>=0.5
Using cached ptyprocess-0.7.0-py2.py3-none-any.whl (13 kB)
Installing collected packages: ptyprocess, pexpect, colorama, pycvs
Successfully installed colorama-0.4.5 pexpect-4.8.0 ptyprocess-0.7.0 pycvs-0.0.3
WARNING: You are using pip version 22.0.4; however, version 22.1.2 is available.
You should consider upgrading via the '/home/godfryd/.cache/pypoetry/virtualenvs/krakenci-client-gzjv3aIZ-py3.10/bin/python3 -m pip install --upgrade pip' command.
Uploaded tool pkg_install@dev6

Auxiliary Commands

version

Print a version of kkci.

$ kkci version
0.1

server-version

Print a version of Kraken Server indicated in -s option.

$ kkci -s http://admin:admin@localhost:8080 server-version
0.1

dump-workflow-schema

Dump workflow schema in JSON format from indicated Kraken Server in -s option to indicated file.

$ kkci -s http://admin:admin@localhost:8080 dump-workflow-schema schema.json