1
0
mirror of https://github.com/kremalicious/metamask-extension.git synced 2024-11-26 12:29:06 +01:00

break out IndexDbController && Run the first time test on mascara

This commit is contained in:
frankiebee 2017-04-27 17:21:10 +02:00
parent e7e0919d7c
commit 53537824f1
9 changed files with 47 additions and 81 deletions

3
.gitignore vendored
View File

@ -16,3 +16,6 @@ development/bundle.js
builds.zip builds.zip
test/integration/bundle.js test/integration/bundle.js
development/states.js development/states.js
test/background.js
test/bundle.js
test/test-bundle.js

View File

@ -22,6 +22,7 @@ const STORAGE_KEY = 'metamask-config'
// const METAMASK_DEBUG = 'GULP_METAMASK_DEBUG' // const METAMASK_DEBUG = 'GULP_METAMASK_DEBUG'
const METAMASK_DEBUG = true const METAMASK_DEBUG = true
let popupIsOpen = false let popupIsOpen = false
let connectedClientCount = 0
const log = require('loglevel') const log = require('loglevel')
global.log = log global.log = log
@ -32,6 +33,11 @@ self.addEventListener('install', function(event) {
}) })
self.addEventListener('activate', function(event) { self.addEventListener('activate', function(event) {
event.waitUntil(self.clients.claim()) event.waitUntil(self.clients.claim())
self.clients.matchAll()
.then((clients) => {
if (connectedClientCount < clients.length) sendMessageToAllClients('reconnect')
})
}) })
console.log('inside:open') console.log('inside:open')
@ -108,6 +114,7 @@ function setupController (initState, client) {
connectionListener.on('remote', (portStream, messageEvent) => { connectionListener.on('remote', (portStream, messageEvent) => {
console.log('REMOTE CONECTION FOUND***********') console.log('REMOTE CONECTION FOUND***********')
connectedClientCount += 1
connectRemote(portStream, messageEvent.data.context) connectRemote(portStream, messageEvent.data.context)
}) })
@ -143,4 +150,12 @@ function setupController (initState, client) {
return Promise.resolve() return Promise.resolve()
} }
function sendMessageToAllClients (message) {
self.clients.matchAll().then(function(clients) {
clients.forEach(function(client) {
client.postMessage(message)
})
})
}
function noop () {} function noop () {}

View File

@ -1,71 +0,0 @@
const EventEmitter = require('events')
module.exports = class IndexDbController extends EventEmitter {
constructor (opts) {
super()
global.IDBTransaction = global.IDBTransaction || global.webkitIDBTransaction || global.msIDBTransaction || {READ_WRITE: "readwrite"}; // This line should only be needed if it is needed to support the object's constants for older browsers
global.IDBKeyRange = global.IDBKeyRange || global.webkitIDBKeyRange || global.msIDBKeyRange
this.migrations = opts.migrations
this.key = opts.key
this.version = opts.version
this.initialState = opts.initialState
}
// Opens the database connection and returns a promise
open () {
return this.get('dataStore')
.then((data) => {
if (!data) {
return this._add('dataStore', this.initialState)
.then(() => this.get('dataStore'))
.then((versionedData) => Promise.resolve(versionedData))
}
return Promise.resolve(data)
})
}
get (key = 'dataStore') {
return this._request('get', key)
}
put (state) {
return this._request('put', state, 'dataStore')
}
_add (key = 'dataStore', objStore) {
return this._request('add', objStore, key)
}
_request (call, ...args) {
return new Promise((resolve, reject) => {
const self = this
const dbOpenRequest = global.indexedDB.open(this.key, this.version)
dbOpenRequest.addEventListener('upgradeneeded', (event) => {
this.db = event.target.result
this.db.createObjectStore('dataStore')
})
dbOpenRequest.onsuccess = (event) => {
this.db = dbOpenRequest.result
this.emit('success')
const dbTransaction = this.db.transaction('dataStore', 'readwrite')
const request = dbTransaction.objectStore('dataStore')
const objRequest = request[call](...args)
objRequest.addEventListener('success', (event) => {
return resolve(objRequest.result)
})
objRequest.addEventListener('error', (err) => {
return reject(`IndexDBController - ${call} failed to excute on indexedDB`)
})
dbTransaction.addEventListener('complete', (event) => {
this.emit('complete')
})
}
dbOpenRequest.addEventListener('error', (event) => {
return reject({message: `IndexDBController - open:@${call} failed to excute on indexedDB`, errorEvent: event})
})
})
}
}

View File

@ -27,7 +27,7 @@ const background = new SWcontroller({
wakeUpInterval: 20000 wakeUpInterval: 20000
}) })
// Setup listener for when the service worker is read // Setup listener for when the service worker is read
background.on('ready', (readSw) => { const connectApp = function (readSw) {
let connectionStream = SwStream({ let connectionStream = SwStream({
serviceWorker: background.controller, serviceWorker: background.controller,
context: name, context: name,
@ -37,8 +37,24 @@ background.on('ready', (readSw) => {
store.subscribe(() => { store.subscribe(() => {
const state = store.getState() const state = store.getState()
if (state.appState.shouldClose) window.close() if (state.appState.shouldClose) window.close()
console.log('IN the things?')
}) })
}) })
}
background.on('ready', (sw) => {
background.removeListener('updatefound', connectApp)
connectApp(sw)
}) })
background.startWorker() background.on('updatefound', () => background.serviceWorkerApi.ready
.then((sw) =>{
background.removeListener('ready', connectApp)
connectApp(sw.active)
})
)
background.on('message', (messageEvent) => {
console.log(messageEvent)
})
window.addEventListener('load', () => background.startWorker())
// background.startWorker()
console.log('hello from MetaMascara ui!') console.log('hello from MetaMascara ui!')

View File

@ -14,7 +14,8 @@
<script src="./helpers.js"></script> <script src="./helpers.js"></script>
<script src="./test-bundle.js"></script> <script src="./test-bundle.js"></script>
<script src="/testem.js"></script> <script src="/testem.js"></script>
<script src="./bundle.js"></script>
<div id="app-content"></div> <div id="app-content"></div>
<script src="./bundle.js"></script>
</body> </body>
</html> </html>

View File

@ -6,8 +6,8 @@ QUnit.test('render init screen', function (assert) {
var done = assert.async() var done = assert.async()
let app let app
wait().then(function() { wait(1000).then(function() {
app = $('#app-content') app = $('#app-content').contents()
const recurseNotices = function () { const recurseNotices = function () {
let button = app.find('button') let button = app.find('button')
if (button.html() === 'Continue') { if (button.html() === 'Continue') {

View File

@ -1,5 +1,5 @@
const EventEmitter = require('events') const EventEmitter = require('events')
const IDB = require('../../../mascara/src/lib/index-db-controller') const IDB = require('idb-global')
const KEY = 'metamask-test-config' const KEY = 'metamask-test-config'
module.exports = class Helper extends EventEmitter { module.exports = class Helper extends EventEmitter {
constructor () { constructor () {

View File

@ -1,7 +1,8 @@
const Helper = require('./util/mascara-test-helper.js') const Helper = require('./util/mascara-test-helper.js')
debugger
window.addEventListener('load', () => { window.addEventListener('load', () => {
const helper = new Helper() // const helper = new Helper()
helper.on('complete', () => require('../src/ui.js')) // helper.on('complete', () => require('../src/ui.js'))
helper.tryToCleanContext() // helper.tryToCleanContext()
require('../src/ui.js')
}) })

View File

@ -73,6 +73,7 @@
"extensionizer": "^1.0.0", "extensionizer": "^1.0.0",
"gulp-eslint": "^2.0.0", "gulp-eslint": "^2.0.0",
"hat": "0.0.3", "hat": "0.0.3",
"idb-global": "^1.0.0",
"identicon.js": "^1.2.1", "identicon.js": "^1.2.1",
"iframe": "^1.0.0", "iframe": "^1.0.0",
"iframe-stream": "^1.0.2", "iframe-stream": "^1.0.2",