diff options
author | kumavis <kumavis@users.noreply.github.com> | 2018-05-23 04:02:41 +0800 |
---|---|---|
committer | GitHub <noreply@github.com> | 2018-05-23 04:02:41 +0800 |
commit | cee55b47d03006630b1dbe038c6008654ca8f674 (patch) | |
tree | fe818a80ee98ee76a53e9be6087c09be02241503 /test/unit/app/ComposableObservableStore.js | |
parent | 492b4a674392e4772ef8e2cc8f5836b882cfeec7 (diff) | |
parent | 238f2eb179895bbb9e2a2ec26863041564c90a9d (diff) | |
download | tangerine-wallet-browser-cee55b47d03006630b1dbe038c6008654ca8f674.tar tangerine-wallet-browser-cee55b47d03006630b1dbe038c6008654ca8f674.tar.gz tangerine-wallet-browser-cee55b47d03006630b1dbe038c6008654ca8f674.tar.bz2 tangerine-wallet-browser-cee55b47d03006630b1dbe038c6008654ca8f674.tar.lz tangerine-wallet-browser-cee55b47d03006630b1dbe038c6008654ca8f674.tar.xz tangerine-wallet-browser-cee55b47d03006630b1dbe038c6008654ca8f674.tar.zst tangerine-wallet-browser-cee55b47d03006630b1dbe038c6008654ca8f674.zip |
Merge pull request #4321 from MetaMask/testing
MM controller tests and reorganizing test files
Diffstat (limited to 'test/unit/app/ComposableObservableStore.js')
-rw-r--r-- | test/unit/app/ComposableObservableStore.js | 35 |
1 files changed, 35 insertions, 0 deletions
diff --git a/test/unit/app/ComposableObservableStore.js b/test/unit/app/ComposableObservableStore.js new file mode 100644 index 000000000..aa8abd463 --- /dev/null +++ b/test/unit/app/ComposableObservableStore.js @@ -0,0 +1,35 @@ +const assert = require('assert') +const ComposableObservableStore = require('../../../app/scripts/lib/ComposableObservableStore') +const ObservableStore = require('obs-store') + +describe('ComposableObservableStore', () => { + it('should register initial state', () => { + const store = new ComposableObservableStore('state') + assert.strictEqual(store.getState(), 'state') + }) + + it('should register initial structure', () => { + const testStore = new ObservableStore() + const store = new ComposableObservableStore(null, { TestStore: testStore }) + testStore.putState('state') + assert.deepEqual(store.getState(), { TestStore: 'state' }) + }) + + it('should update structure', () => { + const testStore = new ObservableStore() + const store = new ComposableObservableStore() + store.updateStructure({ TestStore: testStore }) + testStore.putState('state') + assert.deepEqual(store.getState(), { TestStore: 'state' }) + }) + + it('should return flattened state', () => { + const fooStore = new ObservableStore({ foo: 'foo' }) + const barStore = new ObservableStore({ bar: 'bar' }) + const store = new ComposableObservableStore(null, { + FooStore: fooStore, + BarStore: barStore, + }) + assert.deepEqual(store.getFlatState(), { foo: 'foo', bar: 'bar' }) + }) +}) |