diff options
author | kumavis <aaron@kumavis.me> | 2018-05-23 04:20:04 +0800 |
---|---|---|
committer | kumavis <aaron@kumavis.me> | 2018-05-23 04:20:04 +0800 |
commit | 3a80f3dd836889b7e4f4d4db8eaf42883623d9bf (patch) | |
tree | bcde7f3a6acbdf311bf66b70be6bfac2b3ed088a /test/unit/app/ComposableObservableStore.js | |
parent | 3084dc47d10e3e455c924e5aad0b0961c500ec8d (diff) | |
parent | cee55b47d03006630b1dbe038c6008654ca8f674 (diff) | |
download | tangerine-wallet-browser-3a80f3dd836889b7e4f4d4db8eaf42883623d9bf.tar.gz tangerine-wallet-browser-3a80f3dd836889b7e4f4d4db8eaf42883623d9bf.tar.zst tangerine-wallet-browser-3a80f3dd836889b7e4f4d4db8eaf42883623d9bf.zip |
Merge branch 'develop' of github.com:MetaMask/metamask-extension into network-remove-provider-engine
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' }) + }) +}) |