add spec
This commit is contained in:
parent
ed465208a2
commit
7ba947aee9
6 changed files with 119 additions and 1 deletions
|
@ -5,7 +5,7 @@ const ws = require('ws')
|
|||
const url = require('url')
|
||||
const remote = require('electron').remote
|
||||
|
||||
const {BrowserWindow, session, webContents} = remote
|
||||
const {BrowserWindow, ipcMain, protocol, session, webContents} = remote
|
||||
|
||||
const isCI = remote.getGlobal('isCi')
|
||||
|
||||
|
@ -442,6 +442,88 @@ describe('chromium feature', function () {
|
|||
done()
|
||||
})
|
||||
})
|
||||
|
||||
describe('custom non standard schemes', function () {
|
||||
const protocolName = 'storage'
|
||||
let contents = null
|
||||
before(function (done) {
|
||||
const handler = function (request, callback) {
|
||||
let parsedUrl = url.parse(request.url)
|
||||
let filename
|
||||
switch (parsedUrl.pathname) {
|
||||
case '/localStorage' : filename = 'local_storage.html'; break
|
||||
case '/sessionStorage' : filename = 'session_storage.html'; break
|
||||
case '/WebSQL' : filename = 'web_sql.html'; break
|
||||
case '/indexedDB' : filename = 'indexed_db.html'; break
|
||||
case '/cookie' : filename = 'cookie.html'; break
|
||||
default : filename = ''
|
||||
}
|
||||
callback({path: fixtures + '/pages/storage/' + filename})
|
||||
}
|
||||
protocol.registerFileProtocol(protocolName, handler, function (error) {
|
||||
done(error)
|
||||
})
|
||||
})
|
||||
|
||||
after(function (done) {
|
||||
protocol.unregisterProtocol(protocolName, () => done())
|
||||
})
|
||||
|
||||
beforeEach(function () {
|
||||
contents = webContents.create({})
|
||||
})
|
||||
|
||||
afterEach(function () {
|
||||
contents.destroy()
|
||||
contents = null
|
||||
})
|
||||
|
||||
it('cannot access localStorage', function (done) {
|
||||
ipcMain.once('local-storage-response', function (event, error) {
|
||||
assert.equal(
|
||||
error,
|
||||
'Failed to read the \'localStorage\' property from \'Window\': Access is denied for this document.')
|
||||
done()
|
||||
})
|
||||
contents.loadURL(protocolName + '://host/localStorage')
|
||||
})
|
||||
|
||||
it('cannot access sessionStorage', function (done) {
|
||||
ipcMain.once('session-storage-response', function (event, error) {
|
||||
assert.equal(
|
||||
error,
|
||||
'Failed to read the \'sessionStorage\' property from \'Window\': Access is denied for this document.')
|
||||
done()
|
||||
})
|
||||
contents.loadURL(protocolName + '://host/sessionStorage')
|
||||
})
|
||||
|
||||
it('cannot access WebSQL database', function (done) {
|
||||
ipcMain.once('web-sql-response', function (event, error) {
|
||||
assert.equal(
|
||||
error,
|
||||
'An attempt was made to break through the security policy of the user agent.')
|
||||
done()
|
||||
})
|
||||
contents.loadURL(protocolName + '://host/WebSQL')
|
||||
})
|
||||
|
||||
it('cannot access indexedDB', function (done) {
|
||||
ipcMain.once('indexed-db-response', function (event, error) {
|
||||
assert.equal(error, 'The user denied permission to access the database.')
|
||||
done()
|
||||
})
|
||||
contents.loadURL(protocolName + '://host/indexedDB')
|
||||
})
|
||||
|
||||
it('cannot access cookie', function (done) {
|
||||
ipcMain.once('cookie-response', function (event, cookie) {
|
||||
assert(!cookie)
|
||||
done()
|
||||
})
|
||||
contents.loadURL(protocolName + '://host/cookie')
|
||||
})
|
||||
})
|
||||
})
|
||||
|
||||
describe('websockets', function () {
|
||||
|
|
5
spec/fixtures/pages/storage/cookie.html
vendored
Normal file
5
spec/fixtures/pages/storage/cookie.html
vendored
Normal file
|
@ -0,0 +1,5 @@
|
|||
<script>
|
||||
const {ipcRenderer} = require('electron')
|
||||
document.cookie = "test=123"
|
||||
ipcRenderer.send('cookie-response', document.cookie)
|
||||
</script>
|
7
spec/fixtures/pages/storage/indexed_db.html
vendored
Normal file
7
spec/fixtures/pages/storage/indexed_db.html
vendored
Normal file
|
@ -0,0 +1,7 @@
|
|||
<script>
|
||||
let req = window.indexedDB.open('test')
|
||||
req.onerror = function (event) {
|
||||
const {ipcRenderer} = require('electron')
|
||||
ipcRenderer.send('indexed-db-response', event.target.error.message)
|
||||
}
|
||||
</script>
|
8
spec/fixtures/pages/storage/local_storage.html
vendored
Normal file
8
spec/fixtures/pages/storage/local_storage.html
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
<script>
|
||||
try {
|
||||
window.localStorage
|
||||
} catch (e) {
|
||||
const {ipcRenderer} = require('electron')
|
||||
ipcRenderer.send('local-storage-response', e.message)
|
||||
}
|
||||
</script>
|
8
spec/fixtures/pages/storage/session_storage.html
vendored
Normal file
8
spec/fixtures/pages/storage/session_storage.html
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
<script>
|
||||
try {
|
||||
window.sessionStorage
|
||||
} catch (e) {
|
||||
const {ipcRenderer} = require('electron')
|
||||
ipcRenderer.send('session-storage-response', e.message)
|
||||
}
|
||||
</script>
|
8
spec/fixtures/pages/storage/web_sql.html
vendored
Normal file
8
spec/fixtures/pages/storage/web_sql.html
vendored
Normal file
|
@ -0,0 +1,8 @@
|
|||
<script>
|
||||
try {
|
||||
window.openDatabase('test', '1.0', 'test database', 65536)
|
||||
} catch (e) {
|
||||
const {ipcRenderer} = require('electron')
|
||||
ipcRenderer.send('web-sql-response', e.message)
|
||||
}
|
||||
</script>
|
Loading…
Reference in a new issue