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 🙏

© 2024 – Pkg Stats / Ryan Hefner

fixture-dir

v0.1.0

Published

Create/copy directory to temporary directory

Downloads

26

Readme

fixture-dir Build status

Create/copy directory to temporary directory

fixture-dir was built for quickly setting up/tearing down directories that originate from tests but should not contaminate the repo. Previous to fixture-dir's creation, I have used this pattern in foundry-release-git and sexy-bash-prompt.

A mocha flavor is available, mocha-fixture-dir, which provides automatic directory cleanup.

Getting Started

Install the module with: npm install fixture-dir

// Generate a tmp namespace for our tests
var exec = require('child_process').exec;
var FixtureDir = require('fixture-dir');
var fixtureDir = new FixtureDir('my-node-module-tests');

// Inside of our tests, copy over folder contents and interact with them
before(function () {
  // Create a `git-log` folder with the contents of our `git-log` fixture
  var that = this;
  fixtureDir.mkdir({
    folderName: 'git-log',
    copyFrom: __dirname + '/test-files/git-log' // Folder with `.git` activity
  }, function (err, dir) {
    // Save the directory for cleanup and callback
    that.dir = dir;
    done();
  });
});
before(function (done) {
  // Run `git log` in our directory (/tmp/my-node-module-tests/git-log)
  exec('git log', {cwd: this.dir.path}, function (err, stdout, stderr) {
    // Save our stdout and callback
    this.stdout = stdout;
    done(err);
  });
});
after(function (done) {
  // Cleanup our directory
  this.dir.destroy(done);
  delete this.done;
});

it('retrieved `git log` in our fixture directory', function () {
  assert(this.stdout);
});

Documentation

fixture-dir returns the FixtureDir constructor via its module.exports.

FixtureDir(folderName)

Constructor for fixture directory namespaces inside of /tmp (or your equivalent temporary directory).

  • folderName String, Folder to create all subsequent temporary directories inside of
    • We require this to be reduce pollution of the /tmp folder names
    • The folder path will be /tmp/{{folderName}} (e.g. /tmp/hai for {folderName: 'hai'}

FixtureDir#mkdir([options], cb)

  • options Object, Optional container for various flags/parameters
    • options.folderName String, Folder name to create
      • The folder path will be /tmp/top-level/{{folderName}} (e.g. /tmp/top-level/world for {folderName: 'world'}
      • If this is not provided, we will use a random string generated by tmp
    • options.copyFrom String, Path to source folder to copy contents from
  • cb Function, Error-first callback function with signature (err, dir)
    • err Error|null, If any errors occurred then this will be it
    • dir Directory, Instance of Directory for folder we just created

Directory

Class representation of a directory for getting path and cleaning up

Directory.path

Filepath to directory (e.g. /tmp/my-node-module-tests/git-log)

Directory.destroy(cb)

Method to clean up temporary directory (usually for next test run)

  • cb Function, Error-first callback function with signature (err)
    • err Error|null, If any errors occurred then this will be it

Examples

Creating a temporary folder with no contents:

var fixtureDir = new FixtureDir('my-node-module-tests');
before(function () {
  var that = this;
  fixtureDir.mkdir(function (err, dir) {
    // Generated directory `/tmp/my-node-module-tests/abc123`
    that.dir = dir;
    done();
  });
});

Contributing

In lieu of a formal styleguide, take care to maintain the existing coding style. Add unit tests for any new or changed functionality. Lint via grunt and test via npm test.

Donating

Support this project and others by twolfson via gittip.

Support via Gittip

Unlicense

As of Apr 12 2014, Todd Wolfson has released this repository and its contents to the public domain.

It has been released under the UNLICENSE.