cmdx

module
v1.3.0-0 Latest Latest
Warning

This package is not in the latest version of its module.

Go to latest
Published: May 11, 2020 License: MIT

README

cmdx

Build Status codecov Go Report Card GitHub last commit License

Task runner. It provides useful help messages and supports interactive prompts.

Alternative

Overview

cmdx is the task runner. Using cmdx you can manage tasks for your project such as test, build, format, lint, and release.

For example, This is the tasks for cmdx itself.

$ cmdx -l
init, i - setup git hooks
coverage, c - test a package (fzf is required)
test, t - test
fmt - format the go code
vet, v - go vet
lint, l - lint the go code
release, r - release the new version
durl - check dead links (durl is required)
ci-local - run the Drone pipeline at localhost (drone-cli is required)

$ cmdx help release
NAME:
   cmdx release - release the new version

USAGE:
   cmdx release <version>

DESCRIPTION:
   release the new version
ARGUMENTS:
   version

You can make the simple shell script rich with cmdx

  • cmdx supports the parse of the flag and positional arguments
  • cmdx provides useful help messages
  • cmds supports the interactive prompt by AlecAivazis/survey

cmdx searches the configuration file from the current directory to the root directory recursively and runs the task at the directory where the configuration file exists so the result of the task doesn't depend on the directory you run cmdx.

Install

Download the binary from the release page.

Getting Started

Create the configuration file.

$ cmdx --init
$ cat .cmdx.yaml

Edit the configuration file and register the task hello.

$ vi .cmdx.yaml
$ cat .cmdx.yaml
---
tasks:
- name: hello
  description: hello command
  usage: hello command
  flags:
  - name: source
    short: s
    usage: source file path
    required: true
    input_envs:
    - NAME
  - name: switch
    type: bool
  args:
  - name: name
    usage: name
    default: bb
  environment:
    FOO: foo
  script: "echo hello {{.source}} $NAME {{if .switch}}on{{else}}off{{end}} {{.name}} $FOO" # use Go's text/template

Output the help.

$ cmdx help
NAME:
   cmdx - task runner

USAGE:
   cmdx [global options] command [command options] [arguments...]

VERSION:
   0.2.2

AUTHOR:
   Shunsuke Suzuki

COMMANDS:
   hello     hello command
   help, h   Shows a list of commands or help for one command

GLOBAL OPTIONS:
   --config value, -c value  configuration file path
   --name value, -n value    configuration file name. The configuration file is searched from the current directory to the root directory recursively
   --init, -i                create the configuration file
   --list, -l                list tasks
   --help, -h                show help
   --version, -v             print the version

List tasks.

$ cmdx -l
hello - hello command

Run the task hello.

$ cmdx hello -s README
+ echo hello README $NAME off bb $FOO
hello README README off bb foo

$ cmdx hello -s README --switch
+ echo hello README $NAME on bb $FOO
hello README README on bb foo
$ cmdx hello --target foo
target: foo

Example

In order to understand cmdx, it is good to execute cmdx command actually. We prepare the sample configuration file for you to execute cmdx.

Please see examples.

Configuration

path type description required default
.timeout timeout the task command timeout false
.input_envs []string default environment variable binding false []
.script_envs []string default environment variable binding false []
.environment map[string]string top level environment variables false {}
.tasks []task the list of tasks true
task.name string the task name true
task.short string the task short name false
task.description string the task description false ""
task.usage string the task usage false ""
task.flags []flag the task flag arguments false []
task.args []arg the task positional arguments false []
task.input_envs []string task level environment variable binding false []
task.script_envs []string task level environment variable binding false []
task.environment map[string]string the task's environment variables false {}
task.script string the task command. This is run by sh -c true
task.timeout timeout the task command timeout false
task.require require requirement of task false {}
require.exec []stringArray required executable files false []
require.environment []stringArray required environment variables false []
stringArray array whose element is string or array of string
timtout.duration int the task command timeout (second) false 36000 (10 hours)
timtout.kill_after int the duration the kill signal is sent after timeout.duration false 0, which means the command isn't killed
flag.name string the flag name true
flag.short string the flag short name false
flag.usage string the flag usage false ""
flag.default string the flag argument's default value false ""
flag.input_envs []string flag level environment variable binding false []
flag.script_envs []string flag level environment variable binding false []
flag.type string the flag type. Either "string" or "bool" false "string"
flag.required bool whether the flag argument is required false false
flag.validate []validate parameters to validate the value of flag false []
flag.prompt prompt prompt false prompt is disabled
prompt.type string prompt type true
prompt.message string prompt message false flag.name or arg.name
prompt.help string prompt help false
prompt.options []string entries of select or multi_select prompt true if the prompt type is select or multi_select
arg.name string the positional argument name true
arg.usage string the positional argument usage false ""
arg.default string the positional argument's default value false ""
arg.input_envs []string the positional argument level environment variable binding false []
arg.script_envs []string the positional argument level environment variable binding false []
arg.required bool whether the argument is required false false
arg.prompt prompt prompt false prompt is disabled
arg.validate []validate parameters to validate the value of arg false []
validate.type string value type (email, url, int) false
validate.regexp string the regular expression false
validate.min_length int the minimum string length false
validate.max_length int the maximum string length false
validate.prefix string the prefix false
validate.suffix string the suffix false
validate.contain string the string which the value should contain false
validate.enum []string enum false
script

task.script is the task command. This is parsed by Golang's text/template package. The value of the flag and positional argument can be referred by the argument name.

For example,

# refer the value of the argument "source"
script: "echo {{.source}}"

Multiple lines

script: |
  echo foo
  echo bar

If the positional argument is optional and the argument isn't passed and the default value isn't set, the value is an empty string "".

And some special variables are defined.

name type description
_builtin.args []string the list of positional arguments which aren't defined by the configuration args
_builtin.args_string string the string which joins _builtin.args by the space " "
_builtin.all_args []string the list of all positional arguments
_builtin.args_string string the string which joins _builtin.all_args by the space " "
input_envs, script_envs

input_envs is a list of environment variables that are bound to the variable.

tasks:
- name: foo
  script: "echo {{.source}}"
  args:
  - name: source
    input_envs:
    - command_env
$ COMMAND_ENV=zzz cmdx foo
+ echo zzz
zzz

script_envs is a list of environment variables which the variable is bound to.

tasks:
- name: foo
  script: "echo $COMMAND_ENV"
  args:
  - name: source
    script_envs:
    - command_env
$ cmdx foo zzz
+ echo $COMMAND_ENV
zzz
timeout

cmdx supports the configuration about the timeout of the task.

  1. send SIGINT after timeout.duration seconds (default 36,000 seconds)
  2. if timeout.kill_after isn't 0, send SIGKILL after timeout.duration + timeout.kill_after seconds. By default timeout.kill_after is 0 so SIGKILL isn't sent

For example, the following task foo's timeout is 3 seconds.

tasks:
- name: foo
  script: sleep 100
  timeout:
    duration: 3
$ cmdx foo
+ sleep 100
the command is timeout: 3 sec

The task timeout configuration inherits the top level timeout configuration.

timeout:
  duration: 3
tasks:
- name: foo # the timeout.duration is 3
  script: sleep 100
require

task.require is the requirement to run the task.

require.exec

For example, in the following example both of curl and wget is required.

tasks:
- name: foo
  script: curl http://example.com
  require:
    exec:
    - curl
    - wget

If curl isn't installed, the task is failed.

$ cmdx foo
curl is required

Note that the shell's alias is ignored. Internally, exec.LookupPath is used.

In the following example, either curl or wget is required.

tasks:
- name: foo
  script: curl http://example.com
  require:
    exec:
    - - curl
      - wget
$ cmdx foo
one of the following is required: curl, wget
require.environment

require.environment is the required environment variables. Note that if the value of the environment variable is an emtpy string, the environment variable is treated as unset.

tasks:
- name: foo
  script: curl http://example.com
  require:
    environment:
    - GITHUB_TOKEN
$ cmdx foo
the environment variable 'GITHUB_TOKEN' is required
tasks:
- name: foo
  script: curl http://example.com
  require:
    environment:
    - - GITHUB_TOKEN
      - GITHUB_ACCESS_TOKEN
$ cmdx foo
one of the following environment variables is required: GITHUB_TOKEN, GITHUB_ACCESS_TOKEN

validation

cmdx supports to validate args and flags.

For example,

# .cmdx.yaml
tasks:
- name: hello
  script: echo hello
  args:
  - name: age
    validate:
    - type: int
$ cmdx hello foo
age is invalid: must be int: foo

prompt

cmdx supports the interactive prompt by AlecAivazis/survey. cmdx supports the following prompt types.

  • input
  • multiline
  • password
  • confirm
  • select
  • multi_select
  • editor

About prompt type, please see AlecAivazis/survey's document.

value source priority

  1. command line arguments
  2. environment variable (input_envs)
  3. prompt (prompt isn't launched if the value is set by command line argument or environment variable)
  4. default value

Contributing

Please see the CONTRIBUTING.md.

License

MIT

Directories

Path Synopsis
cmd
pkg

Jump to

Keyboard shortcuts

? : This menu
/ : Search site
f or F : Jump to
y or Y : Canonical URL