Skip to content

A simple mock interface specifically for testing code relying on Sequelize models

License

Notifications You must be signed in to change notification settings

Foyer-Inc/sequelize-mock

This branch is 46 commits ahead of BlinkUX/sequelize-mock:master.

Folders and files

NameName
Last commit message
Last commit date

Latest commit

author
Abram
May 6, 2021
0166363 · May 6, 2021
Jun 9, 2020
Jun 10, 2020
Mar 13, 2017
May 6, 2021
Jun 9, 2020
Nov 22, 2017
Jan 27, 2021
Jun 22, 2017
Oct 7, 2016
Feb 19, 2021
Jun 10, 2020
Oct 18, 2016
Jun 10, 2020
May 6, 2021
May 6, 2021

Repository files navigation

Sequelize Mock

npm MIT License

A mocking interface designed for testing code that uses Sequelize.

Install

npm i sequelize-mock-v5 --save-dev

Getting Started

The Mock Models created with this library function as drop in replacements for your unit testing.

Start by importing the library

var SequelizeMock = require('sequelize-mock-v5');

Initialize the library as you would Sequelize

var DBConnectionMock = new SequelizeMock();

Define your models

var UserMock = DBConnectionMock.define('users', {
		'email': '[email protected]',
		'username': 'foyer',
		'picture': 'user-picture.jpg',
	}, {
		instanceMethods: {
			myTestFunc: function () {
				return 'Test User';
			},
		},
	});

Once Mock models have been defined, you can use them as drop-in replacements for your Sequelize model objects. Data is not retrieved from a database and instead is returned based on the setup of the mock objects, the query being made, and other applied or included information.

For example, your code might look something like this

UserMock.findOne({
	where: {
		username: 'my-user',
	},
}).then(function (user) {
	// `user` is a Sequelize Model-like object
	user.get('id');         // Auto-Incrementing ID available on all Models
	user.get('email');      // '[email protected]'; Pulled from default values
	user.get('username');   // 'my-user'; Pulled from the `where` in the query

	user.myTestFunc();      // Will return 'Test User' as defined above
});

Contributing

This library is under active development, so you should feel free to submit issues, questions, or pull requests.

License

Created by Blink UX and licensed under the MIT license. Check the LICENSE file for more information.

About

A simple mock interface specifically for testing code relying on Sequelize models

Resources

License

Code of conduct

Stars

Watchers

Forks

Packages

No packages published

Languages

  • JavaScript 100.0%