Merge pull request #3079 from MetaMask/i3076-UseStorageLocalInstead-danjm-1

Additions to the UseStorageLocalInstead branch
feature/default_network_editable
Dan Finlay 7 years ago committed by GitHub
commit 84dfb19ecc
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
  1. 14
      app/scripts/background.js
  2. 6
      app/scripts/lib/extension-store.js
  3. 50
      test/unit/extension-store-test.js

@ -57,7 +57,13 @@ async function loadStateFromPersistence () {
// fetch from extension store and merge in data // fetch from extension store and merge in data
if (localStore.isSupported) { 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) // TODO: handle possible exceptions (https://developer.chrome.com/apps/runtime#property-lastError)
versionedData = Object.keys(localData).length > 0 ? localData : versionedData versionedData = Object.keys(localData).length > 0 ? localData : versionedData
} }
@ -113,7 +119,11 @@ function setupController (initState) {
function syncDataWithExtension(state) { function syncDataWithExtension(state) {
if (localStore.isSupported) { 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 return state
} }

@ -15,12 +15,12 @@ const handleDisabledSyncAndResolve = (resolve, toResolve) => {
module.exports = class ExtensionStore { module.exports = class ExtensionStore {
constructor() { constructor() {
this.isSupported = !!(extension.storage.sync) this.isSupported = !!(extension.storage && extension.storage.sync)
this.isEnabled = true // TODO: get value from user settings this.isEnabled = true // TODO: get value from user settings
} }
async fetch() { async fetch() {
return new Promise((resolve) => { 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) handleDisabledSyncAndResolve(resolve, data)
}) })
}) })
@ -31,7 +31,7 @@ module.exports = class ExtensionStore {
return result return result
}, {}) }, {})
return new Promise((resolve) => { return new Promise((resolve) => {
extension.storage.sync.set(dataToSync, () => { extension.storage && extension.storage.sync.set(dataToSync, () => {
handleDisabledSyncAndResolve(resolve) handleDisabledSyncAndResolve(resolve)
}) })
}) })

@ -1,5 +1,18 @@
const assert = require('assert') 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') const ExtensionStore = require('../../app/scripts/lib/extension-store')
describe('Extension Store', function () { describe('Extension Store', function () {
@ -11,19 +24,44 @@ describe('Extension Store', function () {
describe('#fetch', function () { describe('#fetch', function () {
it('should return a promise', 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 () { describe('#sync', function () {
it('should return a promise', 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()
})
}) })
}) })
}) })

Loading…
Cancel
Save