npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2025 – Pkg Stats / Ryan Hefner

@danglingdev/clifry

v1.0.0

Published

CLI Functional Testing tool powered by Node.JS

Downloads

33

Readme

Clifry

Node.JS application for functionally testing command line applications (CLI)

Design Philosophy

Clifry is for black-box testing command line interpreter apps (CLIs).

Its goal is to make functional testing easy by harnessing the simplicity of writing javascript. It offers a very simple workflow and API, honed for running and testing CLIs. Clifry is configuration-file-free, and wants to get out of your way.

Clifry doesn't provide much in the way of domain specific testing functionality. It's up to you to use something like the standard unix diff tool if you want to compare human-readable file outputs, or any external tool you need depending on the nature of your CLI. You can easily require npm modules of your choosing in your javascript test files, as long as they are compatible with Node.JS.

Clifry will always stay lean and minimal, by design.

Note: Clifry was created to test black-box test Airfry, a javascript static site generator. So it's battle tested in that way.

How To Write Tests

Clifry will run tests against a CLI that you specify as an argument. You write tests as separate javascript files. Clifry will find and run through them.

A clifry test file must accept an instance of the api object, and return a promise to resolve (pass) or reject (fail) the test.

The API object passed to your test provides a minimal set of functions designed to make it easy to interact with your CLI for functional testing purposes.

Most of these functions are designed to be used with javascript's async await mechanism, in order to keep the flow of your tests clean and easy to read.

Example test.js file: Run python interactively to make sure it can do math!
const test = (CliFry) => {
  return new Promise(async function (resolve, reject) {
    const testRun = CliFry(
      {
        name: "Simple Test",
        description: "Run python, do math, exit.",
      },
      // arguments
      ["-i", "-q"]
    );

    try {
      await testRun.start(100);

      await testRun.untilStderrIncludes(">>>", 5000);

      testRun.write("10+10");

      await testRun.untilStdoutIncludes("20", 2000);

      await testRun.untilOutputIdleSeconds(1, 2000);

      testRun.write("exit()");

      await testRun.untilStopped(1000);

      resolve("success");
    } catch (error) {
      reject("Python can't do math!");
    }
  });
};

module.exports = test;

Hopefully the above is somewhat self explanatory.

Of course testing stdout and stderr is only one aspect of testing a CLI. In the case of Airfry, a static site generator, the clifry tests were written to use the unix diff command to compare site outputs at different points in time. Refer to the Airfry test folder in git to see how it works.

Clifry is designed so that you include the 3rd party libraries you need to test the domain specific data you are testing for within your javascript test files. You can use npm and require as you desire. Perhaps you want to compare audio or video files at each step of the test. There's probably an npm module for that!

Clifry was written in typescript and so the test API documentation has been kept that way to show you the types of the interface. Your test files must be javascript, but if you want to write them in typescript you could always set up a pre-compile step in your environment.

How to run Clifry

TODO -> NPM INSTALL INSTRUCTIONS

Create a parent test folder in your project, then create a child folder for each test you want to run.

The child folder names become the test names you can run using the Clifry's -t argument.

Optionally call Clifry with the following arguments:

-f, --folder

The parent folder for all of your child test folders (defaults to ./tests)

-t, --tests

One or more test names (folder names). If not specified, Clifry will run all that it finds in the parent test folder.

-c, --cli

The path to the normal CLI you are testing

-n, --node

The path to the node CLI you are testing

You must specify either a node or a regular binary cli, but not both.

Api

Documentation