New Case Study:See how Anthropic automated 95% of dependency reviews with Socket.Learn More
Socket
Sign inDemoInstall
Socket

grunt-flowbin

Package Overview
Dependencies
Maintainers
1
Versions
10
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

grunt-flowbin

Grunt command to work with flow-bin

  • 0.2.0
  • latest
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
7
decreased by-36.36%
Maintainers
1
Weekly downloads
 
Created
Source

grunt-flowbin

Greenkeeper badge

This is a thin grunt wrapper around the flow-bin command line tool.

Build Status

It allows you to integrate Flow's static JavaScript analysis into your Grunt toolchain. Unlike other solutions, this one attempts to pass off as much work to flow-bin as possible and get out of your way.

Installation

npm install --save-dev grunt-flowbin

Configuration

Add a target to your grunt configuration for each flow command you'd like to run. If you wanted to run flow check as grunt flowbin:check you'd add this:

grunt.initConfig({
  flowbin: {
    check: {},
  },
});

flow options

If you're too solarized and need to run flow check --color=never as grunt flowbin:check then you can add target options for it like:

grunt.initConfig({
  flowbin: {
    check: {
      color: 'never',
    },
  },
});

If you want to pass a flag (an option without a value) like flow check --quiet, give the option a value of null:

grunt.initConfig({
  flowbin: {
    check: {
      quiet: null,
    },
  },
});

If you want to see the way flow check is invoked (the default options, etc), run grunt --verbose ....

Supported flow commands

Here are the Grunt targets you can define for all the flow commands currently supported. If you define a target that's not supported, the Grunt task will attempt to run it just like flow yourtarget but that may or may not work.

grunt.initConfig({
  flowbin: {
    check: {},
    start: {},
    stop: {},
    status: {},
  },
});

Run flow --help for info on what these commands do.

Continuous flow checks

Since grunt flowbin:check checks all files (which can be slow), you will probably want to use grunt-contrib-watch to only check files as they change in your source tree. flow-bin provides support for this with a standalone server that caches a bunch of things.

Here's an example of how to start a server, watch for file changes, and check files as they change:

grunt.initConfig({
  // Configure your `grunt flowbin` task:
  flowbin: {
    // Define targets for the flow commands you need.
    start: {},
    status: {},
  },
  // Configure your `grunt watch:develop` task:
  watch: {
    develop: {
      files: [
        // Watch all your source files. Your path may be different.
        'src/**/*.js',
      ],
      tasks: [
        // Run your custom test command (assuming it exists as such):
        'test',
        // Ask the flow server for status on recently changed files:
        'flowbin:status',
      ],
    },
  },
});

// Register a custom command that starts a flow server then watches
// for file changes:
grunt.registerTask('develop', [
  'flowbin:start',
  'watch:develop',
]);

With this configuration, you can start a custom task as grunt develop that calls flowbin:start to start the server then watch:develop to watch for file changes. When a file changes, this configuration calls your custom test command and then flowbin:status to only check the status on newer files.

Contributing

Grab a clone and get started like this:

npm install
npm test

Keywords

FAQs

Package last updated on 14 Jun 2017

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc