aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorDan Finlay <542863+danfinlay@users.noreply.github.com>2018-01-25 02:57:04 +0800
committerGitHub <noreply@github.com>2018-01-25 02:57:04 +0800
commit84dfb19eccc878844f78efb75b754c5b3ee47de1 (patch)
tree5c357247d1c29e9edf9406775d4400ccda6083a6
parent7c4a9c32fa449197bf790b6ce6e91c41efe05ab9 (diff)
parent598390e83ec68feaef256c0cfa3a239c6595475a (diff)
downloadtangerine-wallet-browser-84dfb19eccc878844f78efb75b754c5b3ee47de1.tar.gz
tangerine-wallet-browser-84dfb19eccc878844f78efb75b754c5b3ee47de1.tar.zst
tangerine-wallet-browser-84dfb19eccc878844f78efb75b754c5b3ee47de1.zip
Merge pull request #3079 from MetaMask/i3076-UseStorageLocalInstead-danjm-1
Additions to the UseStorageLocalInstead branch
-rw-r--r--app/scripts/background.js14
-rw-r--r--app/scripts/lib/extension-store.js6
-rw-r--r--test/unit/extension-store-test.js50
3 files changed, 59 insertions, 11 deletions
diff --git a/app/scripts/background.js b/app/scripts/background.js
index 280c28d70..88600bf1e 100644
--- a/app/scripts/background.js
+++ b/app/scripts/background.js
@@ -57,7 +57,13 @@ async function loadStateFromPersistence () {
// fetch from extension store and merge in data
if (localStore.isSupported) {
- const localData = await localStore.get()
+ let localData
+ try {
+ localData = await localStore.get()
+ } catch (err) {
+ log.error('error fetching state from local store:', err)
+ }
+
// TODO: handle possible exceptions (https://developer.chrome.com/apps/runtime#property-lastError)
versionedData = Object.keys(localData).length > 0 ? localData : versionedData
}
@@ -113,7 +119,11 @@ function setupController (initState) {
function syncDataWithExtension(state) {
if (localStore.isSupported) {
- localStore.set(state) // TODO: handle possible exceptions (https://developer.chrome.com/apps/runtime#property-lastError)
+ try {
+ localStore.set(state)
+ } catch (err) {
+ log.error('error setting state in local store:', err)
+ }
}
return state
}
diff --git a/app/scripts/lib/extension-store.js b/app/scripts/lib/extension-store.js
index 67ee71f16..4a970321c 100644
--- a/app/scripts/lib/extension-store.js
+++ b/app/scripts/lib/extension-store.js
@@ -15,12 +15,12 @@ const handleDisabledSyncAndResolve = (resolve, toResolve) => {
module.exports = class ExtensionStore {
constructor() {
- this.isSupported = !!(extension.storage.sync)
+ this.isSupported = !!(extension.storage && extension.storage.sync)
this.isEnabled = true // TODO: get value from user settings
}
async fetch() {
return new Promise((resolve) => {
- extension.storage.sync.get(KEYS_TO_SYNC, (data) => {
+ extension.storage && extension.storage.sync.get(KEYS_TO_SYNC, (data) => {
handleDisabledSyncAndResolve(resolve, data)
})
})
@@ -31,7 +31,7 @@ module.exports = class ExtensionStore {
return result
}, {})
return new Promise((resolve) => {
- extension.storage.sync.set(dataToSync, () => {
+ extension.storage && extension.storage.sync.set(dataToSync, () => {
handleDisabledSyncAndResolve(resolve)
})
})
diff --git a/test/unit/extension-store-test.js b/test/unit/extension-store-test.js
index e3b5713fb..e32f37d3c 100644
--- a/test/unit/extension-store-test.js
+++ b/test/unit/extension-store-test.js
@@ -1,5 +1,18 @@
const assert = require('assert')
+const sinon = require('sinon')
+const KEYS_TO_SYNC = ['KeyringController', 'PreferencesController']
+const mockSyncGetResult = 123
+const syncGetStub = sinon.stub().callsFake((str, cb) => cb(mockSyncGetResult))
+const syncSetStub = sinon.stub().callsFake((str, cb) => cb())
+
+window.storage = {
+ sync: {
+ get: syncGetStub,
+ set: syncSetStub,
+ },
+}
+window.runtime = {}
const ExtensionStore = require('../../app/scripts/lib/extension-store')
describe('Extension Store', function () {
@@ -11,19 +24,44 @@ describe('Extension Store', function () {
describe('#fetch', function () {
it('should return a promise', function () {
-
+ const extensionStoreFetchResult = extensionStore.fetch()
+ assert.ok(Promise.resolve(extensionStoreFetchResult) === extensionStoreFetchResult)
})
- it('after promise resolution, should have loaded the proper data from the extension', function () {
-
+ it('after promise resolution, should have loaded the proper data from the extension', function (done) {
+ extensionStore.fetch()
+ .then((result) => {
+ assert.deepEqual(syncGetStub.getCall(0).args[0], KEYS_TO_SYNC.slice(0))
+ assert.equal(result, mockSyncGetResult)
+ done()
+ })
})
})
describe('#sync', function () {
it('should return a promise', function () {
-
+ const extensionStoreSyncResult = extensionStore.sync()
+ assert.ok(Promise.resolve(extensionStoreSyncResult) === extensionStoreSyncResult)
})
- it('after promise resolution, should have synced the proper data from the extension', function () {
-
+ it('after promise resolution, should have synced the proper data from the extension', function (done) {
+ const mockState = {
+ data: {
+ KeyringController: 5,
+ PreferencesController: 6,
+ someOtherData: 7
+ },
+ someOtherProp: {
+ evenMoreData: 8,
+ },
+ }
+ const expectedDataToSync = {
+ KeyringController: 5,
+ PreferencesController: 6,
+ }
+ extensionStore.sync(mockState)
+ .then(() => {
+ assert.deepEqual(syncSetStub.getCall(0).args[0], expectedDataToSync)
+ done()
+ })
})
})
})