add test
This commit is contained in:
parent
fbb5091f94
commit
e80a95dc37
1 changed files with 69 additions and 0 deletions
|
@ -1,6 +1,7 @@
|
||||||
assert = require 'assert'
|
assert = require 'assert'
|
||||||
http = require 'http'
|
http = require 'http'
|
||||||
path = require 'path'
|
path = require 'path'
|
||||||
|
qs = require 'querystring'
|
||||||
|
|
||||||
{remote} = require 'electron'
|
{remote} = require 'electron'
|
||||||
{protocol} = remote.require 'electron'
|
{protocol} = remote.require 'electron'
|
||||||
|
@ -8,6 +9,9 @@ path = require 'path'
|
||||||
describe 'protocol module', ->
|
describe 'protocol module', ->
|
||||||
protocolName = 'sp'
|
protocolName = 'sp'
|
||||||
text = 'valar morghulis'
|
text = 'valar morghulis'
|
||||||
|
postData =
|
||||||
|
name: 'post test'
|
||||||
|
type: 'string'
|
||||||
|
|
||||||
afterEach (done) ->
|
afterEach (done) ->
|
||||||
protocol.unregisterProtocol protocolName, ->
|
protocol.unregisterProtocol protocolName, ->
|
||||||
|
@ -405,6 +409,22 @@ describe 'protocol module', ->
|
||||||
error: (xhr, errorType, error) ->
|
error: (xhr, errorType, error) ->
|
||||||
done(error)
|
done(error)
|
||||||
|
|
||||||
|
it 'can receive post data', (done) ->
|
||||||
|
handler = (request, callback) ->
|
||||||
|
uploadData = request.uploadData[0].bytes.toString()
|
||||||
|
callback({data: uploadData})
|
||||||
|
protocol.interceptStringProtocol 'http', handler, (error) ->
|
||||||
|
return done(error) if error
|
||||||
|
$.ajax
|
||||||
|
url: "http://fake-host"
|
||||||
|
type: "POST"
|
||||||
|
data: postData
|
||||||
|
success: (data) ->
|
||||||
|
assert.deepEqual qs.parse(data), postData
|
||||||
|
done()
|
||||||
|
error: (xhr, errorType, error) ->
|
||||||
|
done(error)
|
||||||
|
|
||||||
describe 'protocol.interceptBufferProtocol', ->
|
describe 'protocol.interceptBufferProtocol', ->
|
||||||
it 'can intercept http protocol', (done) ->
|
it 'can intercept http protocol', (done) ->
|
||||||
handler = (request, callback) -> callback(new Buffer(text))
|
handler = (request, callback) -> callback(new Buffer(text))
|
||||||
|
@ -418,6 +438,55 @@ describe 'protocol module', ->
|
||||||
error: (xhr, errorType, error) ->
|
error: (xhr, errorType, error) ->
|
||||||
done(error)
|
done(error)
|
||||||
|
|
||||||
|
it 'can receive post data', (done) ->
|
||||||
|
handler = (request, callback) ->
|
||||||
|
uploadData = request.uploadData[0].bytes
|
||||||
|
callback(uploadData)
|
||||||
|
protocol.interceptBufferProtocol 'http', handler, (error) ->
|
||||||
|
return done(error) if error
|
||||||
|
$.ajax
|
||||||
|
url: "http://fake-host"
|
||||||
|
type: "POST"
|
||||||
|
data: postData
|
||||||
|
success: (data) ->
|
||||||
|
assert.equal data, $.param postData
|
||||||
|
done()
|
||||||
|
error: (xhr, errorType, error) ->
|
||||||
|
done(error)
|
||||||
|
|
||||||
|
describe 'protocol.interceptHttpProtocol', ->
|
||||||
|
it 'can send POST request', (done) ->
|
||||||
|
server = http.createServer (req, res) ->
|
||||||
|
body = ''
|
||||||
|
req.on 'data', (chunk) ->
|
||||||
|
body += chunk
|
||||||
|
req.on 'end', ->
|
||||||
|
res.end body
|
||||||
|
server.close()
|
||||||
|
server.listen 0, '127.0.0.1', ->
|
||||||
|
{port} = server.address()
|
||||||
|
url = "http://127.0.0.1:#{port}"
|
||||||
|
handler = (request, callback) ->
|
||||||
|
data =
|
||||||
|
url: url
|
||||||
|
method: 'POST'
|
||||||
|
uploadData:
|
||||||
|
contentType: 'application/x-www-form-urlencoded'
|
||||||
|
data: request.uploadData[0].bytes.toString()
|
||||||
|
session: null
|
||||||
|
callback(data)
|
||||||
|
protocol.interceptHttpProtocol 'http', handler, (error) ->
|
||||||
|
return done(error) if error
|
||||||
|
$.ajax
|
||||||
|
url: "http://fake-host"
|
||||||
|
type: "POST"
|
||||||
|
data: postData
|
||||||
|
success: (data) ->
|
||||||
|
assert.deepEqual qs.parse(data), postData
|
||||||
|
done()
|
||||||
|
error: (xhr, errorType, error) ->
|
||||||
|
done(error)
|
||||||
|
|
||||||
describe 'protocol.uninterceptProtocol', ->
|
describe 'protocol.uninterceptProtocol', ->
|
||||||
it 'returns error when scheme does not exist', (done) ->
|
it 'returns error when scheme does not exist', (done) ->
|
||||||
protocol.uninterceptProtocol 'not-exist', (error) ->
|
protocol.uninterceptProtocol 'not-exist', (error) ->
|
||||||
|
|
Loading…
Reference in a new issue