electron/spec/api-session-spec.coffee

124 lines
4.6 KiB
CoffeeScript
Raw Normal View History

assert = require 'assert'
remote = require 'remote'
http = require 'http'
path = require 'path'
2015-09-21 13:44:51 +00:00
fs = require 'fs'
app = remote.require 'app'
2015-06-16 02:37:39 +00:00
BrowserWindow = remote.require 'browser-window'
describe 'session module', ->
@timeout 10000
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"
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) ->
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}"
w.webContents.on 'did-finish-load', ->
w.webContents.session.cookies.get {url: url}, (error, list) ->
return done(error) if error
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
it 'should over-write the existent cookie', (done) ->
app.defaultSession.cookies.set {url: url, name: '1', value: '1'}, (error) ->
return done(error) if error
app.defaultSession.cookies.get {url: url}, (error, list) ->
return done(error) if error
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) ->
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) ->
return done(error) if error
app.defaultSession.cookies.get {url: url}, (error, list) ->
return done(error) if error
for cookie in list when cookie.name is '2'
return done('Cookie not deleted')
done()
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, ->
w.webContents.send 'getcount'
2015-09-21 13:44:51 +00:00
describe 'DownloadItem', ->
2015-09-24 07:55:45 +00:00
# A 5 MB mock pdf.
mockPDF = new Buffer 1024 * 1024 * 5
2015-09-21 13:44:51 +00:00
contentDisposition = 'inline; filename="mock.pdf"'
2015-09-24 07:55:45 +00:00
ipc = require 'ipc'
downloadFilePath = path.join fixtures, 'mock.pdf'
2015-09-21 13:44:51 +00:00
downloadServer = http.createServer (req, res) ->
res.writeHead 200, {
'Content-Length': mockPDF.length,
'Content-Type': 'application/pdf',
'Content-Disposition': contentDisposition
}
res.end mockPDF
downloadServer.close()
it 'can download successfully', (done) ->
downloadServer.listen 0, '127.0.0.1', ->
{port} = downloadServer.address()
2015-09-24 07:55:45 +00:00
ipc.sendSync 'set-download-option', false
2015-09-21 13:44:51 +00:00
w.loadUrl "#{url}:#{port}"
2015-09-24 07:55:45 +00:00
ipc.once 'download-done', (state, url, mimeType, receivedBytes,
totalBytes, disposition, filename) ->
2015-09-24 07:55:45 +00:00
assert.equal state, 'completed'
assert.equal filename, 'mock.pdf'
2015-09-24 07:55:45 +00:00
assert.equal url, "http://127.0.0.1:#{port}/"
assert.equal mimeType, 'application/pdf'
assert.equal receivedBytes, mockPDF.length
assert.equal totalBytes, mockPDF.length
assert.equal disposition, contentDisposition
assert fs.existsSync downloadFilePath
fs.unlinkSync downloadFilePath
done()
2015-09-21 13:44:51 +00:00
it 'can cancel download', (done) ->
downloadServer.listen 0, '127.0.0.1', ->
{port} = downloadServer.address()
2015-09-24 07:55:45 +00:00
ipc.sendSync 'set-download-option', true
2015-09-21 13:44:51 +00:00
w.loadUrl "#{url}:#{port}/"
2015-09-24 07:55:45 +00:00
ipc.once 'download-done', (state, url, mimeType, receivedBytes,
totalBytes, disposition, filename) ->
2015-09-24 07:55:45 +00:00
assert.equal state, 'cancelled'
assert.equal filename, 'mock.pdf'
2015-09-24 07:55:45 +00:00
assert.equal mimeType, 'application/pdf'
assert.equal receivedBytes, 0
assert.equal totalBytes, mockPDF.length
assert.equal disposition, contentDisposition
done()