Code Monkey home page Code Monkey logo

ghokin's Introduction

Go Report Card codecov GitHub tag

Ghokin format and apply transformation on gherkin files.



Install

Download the latest binary for your achitecture here.

If you can't find a binary for your architecture, install the go toolchain, clone the repository and run : go install ..

Usage

Clean and/or apply transformation on gherkin files

Usage:
  ghokin [command]

Available Commands:
  check       Check a file/folder is well formatted
  fmt         Format a feature file/folder
  help        Help about any command

Flags:
      --config string   config file
  -h, --help            help for ghokin

Use "ghokin [command] --help" for more information about a command.

โš ๏ธ Ghokin works only on UTF-8 encoded files, it will detect and convert automatically files that are not encoded in this charset.

fmt stdout

Dump stdin or a feature file formatted on stdout

ghokin fmt stdout features/test.feature

or

cat features/test.feature|ghokin fmt stdout

fmt replace

Format and replace a file or all files in a directory

ghokin fmt replace features/test.feature

or

ghokin fmt replace features/

check

Ensure a file or all files in a directory are well formatted, exit with an error code otherwise

ghokin check features/test.feature

or

ghokin check features/

Documentation

Shell commands

You can run shell commands from within your feature file to transform some datas with annotations, to do so you need first to define in the config an alias and afterwards you can simply "comment" the line before the line you want to transform with that alias. For instance let say @json calls behind the curtain jq, we could validate and format some json in our feature like so :

Feature: A Feature
  Description

  Scenario: A scenario to test
    Given a thing
    # @json
    """
    {
      "test": "test"
    }
    """

Config

Defaut config is to use 2 spaces for indentation.

It's possible to override configuration by defining a .ghokin.yml file in the home directory or in the current directory where we are running the binary from :

indent: 2
aliases:
  json: "jq ."

Aliases key defined shell commands callable in comments as we discussed earlier.

It's possible to use environments variables instead of a static config file :

export GHOKIN_INDENT=2
export GHOKIN_ALIASES='{"json":"jq ."}'

Contribute

If you want to add a new feature to ghokin project, the best way is to open a ticket first to know exactly how to implement your changes in code.

Setup

After cloning the repository you need to install vendors with go mod vendor To test your changes locally you can run go tests with : make test-all

Recommend Projects

  • React photo React

    A declarative, efficient, and flexible JavaScript library for building user interfaces.

  • Vue.js photo Vue.js

    ๐Ÿ–– Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.

  • Typescript photo Typescript

    TypeScript is a superset of JavaScript that compiles to clean JavaScript output.

  • TensorFlow photo TensorFlow

    An Open Source Machine Learning Framework for Everyone

  • Django photo Django

    The Web framework for perfectionists with deadlines.

  • D3 photo D3

    Bring data to life with SVG, Canvas and HTML. ๐Ÿ“Š๐Ÿ“ˆ๐ŸŽ‰

Recommend Topics

  • javascript

    JavaScript (JS) is a lightweight interpreted programming language with first-class functions.

  • web

    Some thing interesting about web. New door for the world.

  • server

    A server is a program made to process requests and deliver data to clients.

  • Machine learning

    Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.

  • Game

    Some thing interesting about game, make everyone happy.

Recommend Org

  • Facebook photo Facebook

    We are working to build community through open source technology. NB: members must have two-factor auth.

  • Microsoft photo Microsoft

    Open source projects and samples from Microsoft.

  • Google photo Google

    Google โค๏ธ Open Source for everyone.

  • D3 photo D3

    Data-Driven Documents codes.