js-memoized-selector-test

1.0.1 • Public • Published

js-memoized-selector-test

A simple utility for test redux memoized selectors, I take the idea and the code from this post of medium.

Install

npm install js-memoized-selector-test --save-dev

Synopsis

Double check yourself

"Always make sure your memoization works and you not producing any regressions. You can use following snippet to wrap you selectors in unit tests and double check it returns the same result for the same set of arguments"

Usage

First import js-memoized-selector-test

// import memoizedSelector from 'js-memoized-selector-test';
var memoizedSelector = require('./dist/index.js').default;
// omit this part is for run this test
var test = require('tape');

Then if you have the follow state:

var state = {
  todos: [
    { name: 'task 1', completed: true },
    { name: 'task 2', completed: false }
  ],
  project: 'home'
};

Then maybe you can have the follow selectors:

function badGetCompletedTodos(state) {
  return state.todos.filter(t => t.completed);
};

function badGetProject(state) {
  return { project: state.project };
}

this selectors are bad defined because always returns a diferent instance of the results.

Whit memoizedSelector we apply a double check in our unit test for avoid this:

test('Bad selectors', function(t) {
  t.plan(2);
  t.throws(function() {
    var target = memoizedSelector(badCompletedTodosSelector);
    target(state);
  }, 'Memoization check failed');
  t.throws(function() {
    var target = memoizedSelector(badGetProject);
    target(state);
  }, 'Memoization check failed');
});

Here we have a good implementation of selectors, we can use reselect for this porpuse.

var createSelector = require('reselect').createSelector;

First we can rewrite our selectors:

var getTodos = function(state) {
  return state.todos;
};

var getCompletedTodos = createSelector(
  [getTodos],
  function(todos) {
    return todos.filter(t => t.completed);
  }
);

function getProject(state) {
  return state.project;
};

Then we can apply the double check in our unit test

test('Completed todos selector', function(t) {
  t.plan(1);
  var completedTodosSelector = memoizedSelector(getCompletedTodos);
  var completedTodos = completedTodosSelector(state);
  t.deepEqual(completedTodos, [state.todos[0]]);
});
test('Project selector', function(t) {
  t.plan(1);
  var projectSelector = memoizedSelector(getProject);
  var project = projectSelector(state);
  t.equal(project, state.project);
});

Memoized selector is only for apply a double check for our selectors in our unit test, then you can install like a dev dependency.

Licence

MIT

Package Sidebar

Install

npm i js-memoized-selector-test

Weekly Downloads

1

Version

1.0.1

License

MIT

Unpacked Size

66.9 kB

Total Files

5

Last publish

Collaborators

  • nicoandresr