Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/m-sureshraj/jenni
👩💻 Jenkins Personal Assistant - CLI to interact with Jenkins server
https://github.com/m-sureshraj/jenni
cli jenkins jenkins-cli node-js
Last synced: 3 months ago
JSON representation
👩💻 Jenkins Personal Assistant - CLI to interact with Jenkins server
- Host: GitHub
- URL: https://github.com/m-sureshraj/jenni
- Owner: m-sureshraj
- License: mit
- Created: 2019-03-19T02:40:08.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2023-01-07T04:23:41.000Z (almost 2 years ago)
- Last Synced: 2024-10-10T05:38:21.076Z (3 months ago)
- Topics: cli, jenkins, jenkins-cli, node-js
- Language: JavaScript
- Homepage:
- Size: 7.08 MB
- Stars: 45
- Watchers: 3
- Forks: 4
- Open Issues: 17
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
README
# jenni
> Jenkins personal assistant - CLI tool to interact with Jenkins server
[![npm](https://img.shields.io/npm/v/jenni.svg)](https://www.npmjs.com/package/jenni)
[![Build](https://github.com/m-sureshraj/jenni/actions/workflows/build.yml/badge.svg)](https://github.com/m-sureshraj/jenni/actions?query=workflow:build+branch:master)![jenni in action](https://raw.githubusercontent.com/m-sureshraj/jenni/HEAD/media/jenni-in-action.png "jenni in action")
Note - jenni will only work inside the **git** repository
## Features
* Print Jenkins build history of a Job.
* Show estimated remaining time for running builds.
* Open Jenkins build in the browser.
* Trigger new builds. (without parameters)
* Watch the console output or stage view after triggering a build.
* View specific build console output.## Upcoming Features
* Trigger new builds with parameters
* Abort running builds## Prerequisites
- Make sure you have Node.js `>= v8.11` installed.
- Jenkins **API Token** - [How to get a Jenkins API token](https://stackoverflow.com/questions/45466090/how-to-get-the-api-token-for-jenkins)## Installation
```
> npm i -g jenni
```
Above installation will give you **globally** available `jen` command to intract with Jenkins server.### Migration from v0.2.6 to v1
The v1 has breaking changes. If you're using an old version of Jenni, follow the steps below before upgrading to v1.```
step 1: Find the config dir path
> jen c
output: Config path - /home/suresh/.config/jenni-nodejs/config.jsonstep 2: Manually delete the config directory
> rm -rf /home/suresh/.config/jenni-nodejsstep 3:
> npm update -g jenni@latest
```## Setup
> Each git project will requires separate initialization.`jen init` will walk you through to initialize jenni to your project.
![jen init](https://raw.githubusercontent.com/m-sureshraj/jenni/HEAD/media/jen-init.png "jen init")
## Usage
```
> jen --helpUsage: jen [options] [command]
Jenkins personal assistant
Options:
-v, --version output the version number
-d, --debug Enable debug mode
-h, --help output usage informationCommands:
init|i Initialize jen
status|s Print branch build status
open|o Open jenkins build in browser
build|b [options] Trigger a new build
console|co [options] Show console output
config|c [options] Show or Update repository configuration
```| Command | Options | Description |
| --- | --- | --- |
| `jen init` \| `i` | - | Initialize jenni to your project. |
| `jen status` \| `s` | - | Print branch build history. |
| `jen open` \| `o` | Optional build number
e.g. `jen open ` | Open jenkins build in the browser. |
| `jen build` \| `b` | `--watch` \| `-w`
Watch the console output after triggering a build.
`--stage` \| `-s`
Watch the stage view after triggering a build. | Trigger a new build and optionally watch its console output or stage view. Note it's not possible to view console output, stage view together. |
| `jen console` \| `co` | `--build` \| `-b`
View specific build console output.
e.g. `jen console --build ` | By default, this command will print the last build console output. If the job has more than one running builds, then it will prompt the user to select a build to retrieve its console output. Use `--build` option to view the specific build console output.
Refer to this [flow chart](./media/console-cmd.png) that explains console command behavior. |
| `jen config` \| `c` | `--username` \| `-n`
`--token` \| `-t`
`--url` \| `-u`
`--job-name`
`--job-path`
`--job-type`
e.g. Reconfigure username & token
`jen config --username --token ` | Overwrite project jenni config. Without any options it will print current config. |## Debug
It's basic for the moment, pass `-d` or `--debug` to log debug messages. Can also be enabled by setting the environment variable `DEBUG_JEN` to `true`. E.g.```
> jen status -d// OR
> DEBUG_JEN=true jen status
```
## Known Limitations* At the moment Jenni handles only `WorkflowJob` and `WorkflowMultiBranchProject` job types. So, if you get the error message `Unsupported job type: ` please file an issue.
* When initializing Jenni (`jen init`) currently there is no way to interactively select jobs inside the folders [(Issue)](https://github.com/terkelg/prompts/issues/224). As a workaround, Jenni will print jobs up to 3 levels deep. For example
```
├── folder-1
│ ├── folder-1.1
│ │ └── job3
│ └── job2
└── job1for the above structure, the output will be:
job1
folder-1 → job2
folder-1 → folder-1.1 - job3
```
So if your job is deeply nested, you should manually configure the job. [Follow this guide](JOB_CONFIGURATION.md).## Feedback
I'm no expert Jenkins user 🤫. I'm building this tool while learning Jenkins concepts. I'm really interested in hearing your use cases, insights, and suggestions for improvements.## Similar Projects
There're a few similar project you can found below:
* [jenkins-cli](https://github.com/jenkins-zh/jenkins-cli)## license
MIT © [Sureshraj](https://github.com/m-sureshraj)