mirror of
https://github.com/overleaf/overleaf.git
synced 2025-01-14 13:13:16 +00:00
cb675d38c2
frontend -> real-time and doc-updater -> real-time should be in sync. Otherwise we can send a payload to doc-updater, but can not receive the confirmation of it -- and the client will send it again in a loop. Also log the size of the payload.
34 lines
No EOL
1.1 KiB
CoffeeScript
34 lines
No EOL
1.1 KiB
CoffeeScript
require('chai').should()
|
|
expect = require("chai").expect
|
|
SandboxedModule = require('sandboxed-module')
|
|
modulePath = '../../../app/js/SafeJsonParse'
|
|
sinon = require("sinon")
|
|
|
|
describe 'SafeJsonParse', ->
|
|
beforeEach ->
|
|
@SafeJsonParse = SandboxedModule.require modulePath, requires:
|
|
"settings-sharelatex": @Settings = {
|
|
maxUpdateSize: 16 * 1024
|
|
}
|
|
"logger-sharelatex": @logger = {error: sinon.stub()}
|
|
|
|
describe "parse", ->
|
|
it "should parse documents correctly", (done) ->
|
|
@SafeJsonParse.parse '{"foo": "bar"}', (error, parsed) ->
|
|
expect(parsed).to.deep.equal {foo: "bar"}
|
|
done()
|
|
|
|
it "should return an error on bad data", (done) ->
|
|
@SafeJsonParse.parse 'blah', (error, parsed) ->
|
|
expect(error).to.exist
|
|
done()
|
|
|
|
it "should return an error on oversized data", (done) ->
|
|
# we have a 2k overhead on top of max size
|
|
big_blob = Array(16*1024).join("A")
|
|
data = "{\"foo\": \"#{big_blob}\"}"
|
|
@Settings.maxUpdateSize = 2 * 1024
|
|
@SafeJsonParse.parse data, (error, parsed) =>
|
|
@logger.error.called.should.equal true
|
|
expect(error).to.exist
|
|
done() |