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

loopback-component-fixturing

Package Overview
Dependencies
Maintainers
1
Versions
8
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

loopback-component-fixturing

Expressive fixtures generator for Loopback

  • 0.0.18
  • latest
  • Source
  • npm
  • Socket score

Version published
Maintainers
1
Created
Source

loopback-component-fixturing

Expressive fixtures generator for Loopback

build status dependency status

Installation

Basic usage

npm install --save loopback-fixtures

Then, in your server/component-config.json, add :

{
  "loopback-fixtures": {
    "fixturePath": "/fixtures/data/",
    "append": false,
    "autoLoad": false
  }
}

Write your YML fixture file /fixture/data/data.yml (adapt according your model) :

Group:
  group{1..10}:
    name: "Groupe {@} depuis les fixtures"

User:
  user{1..10}:
    name: "User {@} : {{name.lastName}}"
    groupId: @group{@}
    email: "{{internet.email}}"
    birthDate: "2016-01-01"
    favoriteNumber: "(function() { return Math.round(Math.random()*1000);})()"

How to load fixtures ?

  • If autoLoad is set to true, fixtures will be loaded when you start your application

  • With the server:

    app.loadFixtures() (return a promise)

    e.g:

    app.loadFixtures()
    .then(function() {
      console.log('Done!');
    })
    .catch(function(err) {
      console.log('Errors:', err);
    });
    
  • With a node command:

    ./node_modules/loopback-fixtures/lib/load-fixtures.js
    

Configuration options

  • fixturePath (default value '/fixtures/data')

    The directory to load data fixtures from

  • append (default value false)

    If set to true, data fixtures will be append instead of deleting all data from the database first. WARNING false will erase your database

  • autoLoad (default value false)

Features

  • Load data according your model

  • Multiple generators :

    User:
      user{1..45}:
        name: "User number {@}"
    

    {@} represents the current identifier for the generator

  • References :

    Group:
      group{1..3}:
        name: "Groupe number {@}"
    
    User:
      user{1..9}:
        name: "User number {@}"
        group: @group1  # Reference to group1
    
      user{10..19}:
        name: "User number {@}"
        group: @group.* # Reference to any matching group
    

    @group1 represents the reference for the group1 and can be used in other fixtures @group.* represents the reference for a random matching group

  • References Array :

     User:
       user1:
         name: "Steve"
       user2:
         name: "Tom"
    
     Car:
       car1:
         name: "Porsche"
       car2:
         name: "Volvo"
     
     Ownership:
       steve:
         ownership: "[@user1, @car1]"
       tom:
         ownership: "[@user2, @car2]"
    
  • Fakers :

    User:
      user{1..10}:
        name: "User n°{@} : {{name.lastName}} {{name.firstName}}"
        email: "{{internet.email}}"
    

    You can use Faker.js API to provide fake data

  • Custom function :

    User:
      user{1..10}:
        favoriteNumber: "(function() { return Math.round(Math.random()*1000);})()"
    

    You can use custom functions too

Credits

License

ISC

FAQs

Package last updated on 01 Jun 2018

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