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

node-mongoose-fixtures

v0.3.0

Published

Easy way to create mongoose fixtures.

Downloads

5,563

Readme

node-mongoose-fixtures

Build Status Code Climate

Create mongoose fixtures from a dataset.

This will iteratively insert records through mongoose.

install

npm install node-mongoose-fixtures

usage

var fixtures = require('node-mongoose-fixtures');

fixtures({
    <table name>: [
        <record>,
        <record>
    ],
    <table name>: [
        <record>,
        <record>
    ]
});

examples

var mongoose = require('mongoose'),
    Schema = mongoose.Schema,
    fixtures = require('node-mongoose-fixtures');

// User
var userSchema = new Schema({
    username: String,
    password: String
});
mongoose.model('users', userSchema);

// Book
var bookSchema = new Schema({
    title: String
});
mongoose.model('books', bookSchema);


// Create dataset immediately
fixtures({
    users: [
        {username: 'one', password: 'pass'},
        {username: 'two', password: 'pass'}
    ],
    books: [
        {title: 'Enders Game'},
        {title: 'Speaker of the Dead'}
    ]
}, function(err, data) {
    // data is an array of all the documents created
});

// Name a dataset for future use
fixtures.save('users', {
    users: [
        {username: 'one', password: 'pass'},
        {username: 'two', password: 'pass'}
    ]
});

// Use the named dataset
fixtures('users', function(err, data) {
    // Again, data is an array of all documents created
});

api

Create Dataset

fixtures(dataset, <mongoose instance>, <callback>);

Immediately creates the documents from the dataset through the mongoose connection.

  • dataset can be a hash or a name of a named fixture.
  • mongoose instance is optional and is a singular instance of mongoose.
  • callback is an optional function when the action is complete. It's parameters are callback(error, data documents). Both arguments are arrays. The data documents are mongoose documents from the fixture data.

Save a Named Fixture

fixtures.save(name, dataset, <callback>);

Save a fixture to be used for later.

  • name is the name of your new named fixture.
  • dataset is the hash of the dataset you want to save.
  • callback is an optional function when the action is complete. It's parameters are callback(err, old fixtures). The old fixtures are what you've overwritten.

Retrieve a Named Fixture's Dataset

fixtures.get(name, <callback>);

Retrieves a named fixture's dataset. If callback is omitted, this will simply return the named fixture's dataset.

  • name is the name of the named fixture you wish to retrieve.
  • callback is an optional function when the action is complete. It's parameters are callback(err, dataset).

Clear Named Fixture

fixtures.clear(<name>, <callback>);

Clears named fixtures.

  • name is optional. It's the name of the named fixture. If omitted, all named fixtures will be cleared.
  • callback is an optional function when the action is complete. It has no parameters.

Reset Database Collection(s)

fixtures.reset(<model name>, <mongoose instance>, <callback>);

Deletes all documents within a collection.

  • model name is optional. It's the name of the collection. If omitted, all collections will be purged.
  • mongoose instance is optional and is a singular instance of mongoose.
  • callback is an optional function when the action is complete. It's parameters are the same as the callback from mongoose.Model.remove()

support

Donations are welcome to help support the continuous development of this project.

Flattr Bitcoin