Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

barrels

Package Overview
Dependencies
Maintainers
1
Versions
21
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

barrels

Simple DB Fixtures for Sails.js with associations support

  • 1.6.1
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
4.6K
increased by376.05%
Maintainers
1
Weekly downloads
 
Created
Source

Simple DB Fixtures for Sails.js with Associations Support

Build Status Dependency Status

Installation

$ npm i --save-dev barrels

Usage

Drop your fixtures in test/fixtures as JSON files (or CommonJS modules) named after your models.

Once your Sails.js server is started:

var Barrels = require('barrels');
var barrels = new Barrels();
var fixtures = barrels.data;
barrels.populate(function(err) {
  ...
});

Pass to the constructor the path to the folder containing your fixtures (defaults to ./test/fixtures).

Populate'ing the test database involves three steps:

  • Removing any existing data from the collection corresponding to the fixture
  • Loading the fixture data into the test database
  • Automatically applying associations (can be disabled by passing false as the last parameter to populate)

Populate also accepts an array of names of collections to populate as the first (optional) argument, for example:

barrels.populate(['products'], function(err) {
  // Only products will be populated
  ...
});

Automatic association

Use the number of position (starting from one) of an entry in the JSON fixture as a reference to associate models (see https://github.com/bredikhin/barrels/blob/master/test/fixtures/products.json for example). This feature can be disabled by passing false as the last parameter to populate.

Required associations

If you have any associations described as required: true, they will be added automatically, no matter if the last parameter to populate is false or not. However, you have to load your fixtures gradually (by passing an array of collection names as the first parameter) in such an order that collections corresponding to the required associations get populated first.

Let's say, for example, you are implementing a Passport.js-based authentication, and every Passport has User as a required association. You'd write something like this:

barrels.populate(['user'], function(err) {
  if (err)
    return done(err); // Higher level callback

  // Users will already be populated here, so the required association should work
  barrels.populate(['passport'], function(err) {
    if (err)
      return done(err); // Higher level callback

      // Do your thing...
      done();
    });
  });

Dependencies

License

The MIT License

Copyright (c) 2013-2014 Ruslan Bredikhin

FAQs

Package last updated on 09 Nov 2015

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