2015-07-14 16:14:22 +00:00
|
|
|
assert = require 'assert'
|
|
|
|
remote = require 'remote'
|
|
|
|
http = require 'http'
|
|
|
|
path = require 'path'
|
|
|
|
app = remote.require 'app'
|
2015-06-16 02:37:39 +00:00
|
|
|
BrowserWindow = remote.require 'browser-window'
|
|
|
|
|
2015-07-02 14:12:18 +00:00
|
|
|
describe 'session module', ->
|
2015-07-14 15:59:06 +00:00
|
|
|
@timeout 10000
|
2015-06-16 09:23:29 +00:00
|
|
|
fixtures = path.resolve __dirname, 'fixtures'
|
2015-06-16 02:37:39 +00:00
|
|
|
w = null
|
2015-06-20 02:42:18 +00:00
|
|
|
url = "http://127.0.0.1"
|
2015-06-16 09:23:29 +00:00
|
|
|
|
2015-07-02 14:12:18 +00:00
|
|
|
beforeEach -> w = new BrowserWindow(show: false, width: 400, height: 400)
|
2015-06-16 02:37:39 +00:00
|
|
|
afterEach -> w.destroy()
|
|
|
|
|
|
|
|
it 'should get cookies', (done) ->
|
|
|
|
server = http.createServer (req, res) ->
|
2015-07-14 16:14:22 +00:00
|
|
|
res.setHeader('Set-Cookie', ['0=0'])
|
2015-06-16 02:37:39 +00:00
|
|
|
res.end('finished')
|
2015-06-20 02:42:18 +00:00
|
|
|
server.close()
|
2015-06-16 02:37:39 +00:00
|
|
|
|
2015-07-24 07:49:19 +00:00
|
|
|
server.listen 0, '127.0.0.1', ->
|
2015-06-16 02:37:39 +00:00
|
|
|
{port} = server.address()
|
2015-06-20 02:42:18 +00:00
|
|
|
w.loadUrl "#{url}:#{port}"
|
2015-07-14 15:59:06 +00:00
|
|
|
w.webContents.on 'did-finish-load', ->
|
2015-07-14 16:14:22 +00:00
|
|
|
w.webContents.session.cookies.get {url: url}, (error, list) ->
|
2015-07-14 15:59:06 +00:00
|
|
|
return done(error) if error
|
2015-07-14 16:14:22 +00:00
|
|
|
for cookie in list when cookie.name is '0'
|
|
|
|
if cookie.value is '0'
|
|
|
|
return done()
|
|
|
|
else
|
|
|
|
return done("cookie value is #{cookie.value} while expecting 0")
|
|
|
|
done('Can not find cookie')
|
2015-06-16 02:37:39 +00:00
|
|
|
|
2015-07-14 15:59:06 +00:00
|
|
|
it 'should over-write the existent cookie', (done) ->
|
2015-07-14 16:14:22 +00:00
|
|
|
app.defaultSession.cookies.set {url: url, name: '1', value: '1'}, (error) ->
|
|
|
|
return done(error) if error
|
|
|
|
app.defaultSession.cookies.get {url: url}, (error, list) ->
|
2015-07-14 15:59:06 +00:00
|
|
|
return done(error) if error
|
2015-07-14 16:14:22 +00:00
|
|
|
for cookie in list when cookie.name is '1'
|
|
|
|
if cookie.value is '1'
|
|
|
|
return done()
|
|
|
|
else
|
|
|
|
return done("cookie value is #{cookie.value} while expecting 1")
|
|
|
|
done('Can not find cookie')
|
2015-06-16 02:37:39 +00:00
|
|
|
|
|
|
|
it 'should remove cookies', (done) ->
|
2015-07-14 16:14:22 +00:00
|
|
|
app.defaultSession.cookies.set {url: url, name: '2', value: '2'}, (error) ->
|
|
|
|
return done(error) if error
|
|
|
|
app.defaultSession.cookies.remove {url: url, name: '2'}, (error) ->
|
2015-07-14 15:59:06 +00:00
|
|
|
return done(error) if error
|
2015-07-14 16:14:22 +00:00
|
|
|
app.defaultSession.cookies.get {url: url}, (error, list) ->
|
2015-07-14 15:59:06 +00:00
|
|
|
return done(error) if error
|
2015-07-14 16:14:22 +00:00
|
|
|
for cookie in list when cookie.name is '2'
|
|
|
|
return done('Cookie not deleted')
|
|
|
|
done()
|
2015-07-02 14:12:18 +00:00
|
|
|
|
|
|
|
describe 'session.clearStorageData(options)', ->
|
|
|
|
fixtures = path.resolve __dirname, 'fixtures'
|
|
|
|
it 'clears localstorage data', (done) ->
|
|
|
|
ipc = remote.require('ipc')
|
|
|
|
ipc.on 'count', (event, count) ->
|
|
|
|
ipc.removeAllListeners 'count'
|
|
|
|
assert not count
|
|
|
|
done()
|
|
|
|
w.loadUrl 'file://' + path.join(fixtures, 'api', 'localstorage.html')
|
|
|
|
w.webContents.on 'did-finish-load', ->
|
2015-07-13 22:22:40 +00:00
|
|
|
options =
|
|
|
|
origin: "file://",
|
|
|
|
storages: ['localstorage'],
|
|
|
|
quotas: ['persistent'],
|
|
|
|
w.webContents.session.clearStorageData options, ->
|
2015-07-02 14:12:18 +00:00
|
|
|
w.webContents.send 'getcount'
|