GitXplorerGitXplorer
o

run-forrest-run

public
1 stars
0 forks
0 issues

Commits

List of commits on branch master.
Unverified
4a78622d965237a42d3c054a9d09686274f6c1e8

fix readmy typo

oorangewise committed 7 years ago
Unverified
19f5df3b5692459dd940b60006f08e10541d7f39

create log directory if needed

oorangewise committed 7 years ago
Unverified
ea883feec1a5d90a58d3f77a938034710644a8e0

0.0.15

oorangewise committed 7 years ago
Unverified
49cf216a6c5f8ec14ed477285907198be23dd2b2

refactoring

oorangewise committed 7 years ago
Unverified
16e0e11888469163d3453f8b031ebc21bf43c9bc

0.0.14

oorangewise committed 7 years ago
Unverified
253c378c8807b68d30b765debc8ab0110f740430

add test for output file

oorangewise committed 7 years ago

README

The README file for this repository.

run-forrest-run

npm version Build Status Coverage Status JavaScript Style Guide

YAML config based script runner.

run-forrest-run

run-forrest-run should be 100% compatible with scriptz.

Installation

npm i -g run-forrest-run

Configuration

The configuration exists of flows and steps. We start of by defining a couple of options and the start flow.

options:
  retry_count: number     # (default: 0) Retry count if exit code > 0
  env: Object             # (default: {}) Additional environment variables
  output_folder: string   # (default: '') A folder for your logs
start:
  ...

The base options that are defined will be used for each step. All the environment variables from the base options will be used, if it is set. If it is also defined on the step level, then the object will be merged.

Flow configuration

# Required values
name: string                # Label
flow: string                # Type of flow 'sequential' or 'parallel'
steps: Array<Step>          # Step definitions

Step configuration

# Required values
name: string                # Label used to keep track of script
script: string              # Script location relative to where scriptz is being run
output_file: string         # Where to write logs, can be prefixed with an output_folder
arguments: Array<String>    # (default: []) Additional arguments
cwd: string                 # (default: process.cwd()) CWD of the script
env: Object                 # (default: {}) Additional environment variables
retry_count: number         # (default: 0) Retry count if exit code > 0

Examples

Example 1

Run 2 commands in parralel.

# example1.yaml
start:
  name: Main
  flow: parallel
  steps:
    - name: File listing
      script: ls
      arguments:
        - -lrt
    - name: Working directory
      script: pwd

Run this config:

$ run-forrest-run -c example1.yaml -v

Example 2

Run 3 steps in sequence, the steps itself run some commands in parralel.

# example2.yaml
start:
  name: Main
  flow: sequential
  steps:
    # the steps details are defined
    # at the bottom of this file
    - $ref: "#/cleanup"
    - $ref: "#/npm-install"
    - $ref: "#/clone"

cleanup:
  name: cleanup log directory
  script: ./cleanup.sh

npm-install:
  name: npm install
  flow: parallel
  steps:
    - name: install s3-zip
      script: npm
      arguments:
        - install
        - s3-zip
    - name: install s3-files
      script: npm
      arguments:
        - install
        - s3-files
    - name: install rotan
      script: npm
      arguments:
        - install
        - rotan

clone:
  name: clone
  flow: parallel
  steps:
    - name: git clone run-forrest-run
      script: git
      arguments:
        - clone
        - git@github.com:orangewise/run-forrest-run.git
      output_file: log/git-clone.log
    - name: git clone s3-zip
      script: git
      arguments:
        - clone
        - git@github.com:orangewise/s3-zip.git
      output_file: log/s3-zip.log

Run this config:

$ run-forrest-run -c example2.yaml -v