From 78590ee41ff61e6cdbe05181526e2e6fa83fb5e8 Mon Sep 17 00:00:00 2001 From: kerryliu Date: Tue, 16 Feb 2016 15:12:07 -0800 Subject: [PATCH] Framework: add schema for current user --- client/state/current-user/reducer.js | 7 ++++++- client/state/current-user/schema.js | 4 ++++ client/state/current-user/test/reducer.js | 13 +++++++++++-- client/state/sites/test/reducer.js | 11 ++++------- 4 files changed, 25 insertions(+), 10 deletions(-) create mode 100644 client/state/current-user/schema.js diff --git a/client/state/current-user/reducer.js b/client/state/current-user/reducer.js index e377ebf98aff0..08aa90d430f99 100644 --- a/client/state/current-user/reducer.js +++ b/client/state/current-user/reducer.js @@ -7,6 +7,8 @@ import { combineReducers } from 'redux'; * Internal dependencies */ import { CURRENT_USER_ID_SET, SERIALIZE, DESERIALIZE } from 'state/action-types'; +import { isValidStateWithSchema } from 'state/utils'; +import { idSchema } from './schema'; /** * Tracks the current user ID. @@ -23,7 +25,10 @@ export function id( state = null, action ) { case SERIALIZE: return state; case DESERIALIZE: - return state; + if ( isValidStateWithSchema( state, idSchema ) ) { + return state; + } + return null; } return state; diff --git a/client/state/current-user/schema.js b/client/state/current-user/schema.js new file mode 100644 index 0000000000000..d57c3b147e05d --- /dev/null +++ b/client/state/current-user/schema.js @@ -0,0 +1,4 @@ +export const idSchema = { + type: [ 'integer', 'null' ], + minimum: 0 +}; diff --git a/client/state/current-user/test/reducer.js b/client/state/current-user/test/reducer.js index 9632904b254c7..8b4916555c2df 100644 --- a/client/state/current-user/test/reducer.js +++ b/client/state/current-user/test/reducer.js @@ -2,6 +2,7 @@ * External dependencies */ import { expect } from 'chai'; +import sinon from 'sinon'; /** * Internal dependencies @@ -27,13 +28,21 @@ describe( 'reducer', () => { } ); describe( 'persistence', () => { - it.skip( 'should validate ID is positive', () => { + before( () => { + sinon.stub( console, 'warn' ); + } ); + + after( () => { + console.warn.restore(); + } ); + + it( 'should validate ID is positive', () => { const state = id( -1, { type: DESERIALIZE } ); expect( state ).to.equal( null ); } ); - it.skip( 'should validate ID is a number', () => { + it( 'should validate ID is a number', () => { const state = id( 'foobar', { type: DESERIALIZE } ); diff --git a/client/state/sites/test/reducer.js b/client/state/sites/test/reducer.js index 6070e92a8be32..e289e881746c0 100644 --- a/client/state/sites/test/reducer.js +++ b/client/state/sites/test/reducer.js @@ -2,24 +2,21 @@ * External dependencies */ import { expect } from 'chai'; -import mockery from 'mockery'; +import sinon from 'sinon'; import deepFreeze from 'deep-freeze'; /** * Internal dependencies */ import { SITE_RECEIVE, SERIALIZE, DESERIALIZE } from 'state/action-types'; +import { items } from '../reducer'; -let items; describe( 'reducer', () => { before( function() { - mockery.registerMock( 'lib/warn', () => {} ); - mockery.enable( { warnOnReplace: false, warnOnUnregistered: false } ); - items = require( '../reducer' ).items; + sinon.stub( console, 'warn' ); } ); after( function() { - mockery.deregisterAll(); - mockery.disable(); + console.warn.restore(); } ); describe( '#items()', () => { it( 'should default to an empty object', () => {