codecombat/test/app/views/play/level/tome/Problem.spec.coffee
Phoenix Eliot 663c220eaf Show wev-dev iFrame error messages like Aether's
This heavily refactors SpellView and adds infrastructure for receiving and reporting Errors raised by the web-dev iFrame. The web-dev error system, the Aether error system, and the Ace html-worker avoid disturbing each others' errors/annotations (though currently Aether+web-dev errors won't coexist), and they clear/update their own asynchronously.

Show web-dev iFrame errors as Ace annotations

Add functional error banners (with poor messages)

Improve error banners, don't allow duplicate Problems

Refactor setAnnotations override

Convert all constructor calls for Problems

Add comments, clean up

Clean up

Don't clear things unnecessarily

Clean up error message sending from iFrame

Add web-dev:error schema

Clarify error message attributes

Refactor displaying AetherProblems

Refactor displaying user problem banners

Refactor onWebDevError

Set ace styles on updating @problems

Clean up, fix off-by-1 error

Add comment

Show stale web-dev errors differently
Some web-dev errors are generated by "stale" code — code that's still running in the iFrame but doesn't have the player's recent changes.
This shows those errors differently than if they weren't "stale", and suggests they re-run their code.

Hook up web-dev event schema

Destroy ignored duplicate problems

Functionalize a bit of stuff

Fix ProblemAlertView never loading
2016-08-31 10:59:06 -07:00

92 lines
3.3 KiB
CoffeeScript

Problem = require 'views/play/level/tome/Problem'
describe 'Problem', ->
# boilerplate problem params
ace = {
getSession: -> {
getDocument: -> {
createAnchor: ->
}
addMarker: ->
}
}
aether = {
raw: "this.say('hi');\nthis.sad('bye');"
language: { id: 'javascript' }
}
aetherProblem = {
hint: 'did you mean say instead of sad?'
id: 'unknown_ReferenceError'
level: 'error'
message: 'Line 1: tmp2[tmp3] is not a function'
range: [
{ row: 1 }
{ row: 1 }
]
type: 'runtime'
}
levelID = 'awesome'
# TODO: Problems are no longer saved when creating Problems; instead it's in SpellView. Update tests?
xit 'save user code problem', ->
new Problem {aether, aetherProblem, ace, isCast: false, levelID}
expect(jasmine.Ajax.requests.count()).toBe(1)
request = jasmine.Ajax.requests.mostRecent()
expect(request.url).toEqual("/db/user.code.problem")
params = JSON.parse(request.params)
expect(params.code).toEqual(aether.raw)
expect(params.codeSnippet).toEqual("this.sad('bye');")
expect(params.errHint).toEqual(aetherProblem.hint)
expect(params.errId).toEqual(aetherProblem.id)
expect(params.errLevel).toEqual(aetherProblem.level)
expect(params.errMessage).toEqual(aetherProblem.message)
expect(params.errRange).toEqual(aetherProblem.range)
expect(params.errType).toEqual(aetherProblem.type)
expect(params.language).toEqual(aether.language.id)
expect(params.levelID).toEqual(levelID)
xit 'save user code problem no range', ->
aetherProblem.range = null
new Problem {aether, aetherProblem, ace, isCast: false, levelID}
expect(jasmine.Ajax.requests.count()).toBe(1)
request = jasmine.Ajax.requests.mostRecent()
expect(request.url).toEqual("/db/user.code.problem")
params = JSON.parse(request.params)
expect(params.code).toEqual(aether.raw)
expect(params.errHint).toEqual(aetherProblem.hint)
expect(params.errId).toEqual(aetherProblem.id)
expect(params.errLevel).toEqual(aetherProblem.level)
expect(params.errMessage).toEqual(aetherProblem.message)
expect(params.errType).toEqual(aetherProblem.type)
expect(params.language).toEqual(aether.language.id)
expect(params.levelID).toEqual(levelID)
# Difference when no range
expect(params.codeSnippet).toBeUndefined()
expect(params.errRange).toBeUndefined()
xit 'save user code problem multi-line snippet', ->
aether.raw = "this.say('hi');\nthis.sad\n('bye');"
aetherProblem.range = [ { row: 1 }, { row: 2 } ]
new Problem {aether, aetherProblem, ace, isCast: false, levelID}
expect(jasmine.Ajax.requests.count()).toBe(1)
request = jasmine.Ajax.requests.mostRecent()
expect(request.url).toEqual("/db/user.code.problem")
params = JSON.parse(request.params)
expect(params.code).toEqual(aether.raw)
expect(params.codeSnippet).toEqual("this.sad\n('bye');")
expect(params.errHint).toEqual(aetherProblem.hint)
expect(params.errId).toEqual(aetherProblem.id)
expect(params.errLevel).toEqual(aetherProblem.level)
expect(params.errMessage).toEqual(aetherProblem.message)
expect(params.errRange).toEqual(aetherProblem.range)
expect(params.errType).toEqual(aetherProblem.type)
expect(params.language).toEqual(aether.language.id)
expect(params.levelID).toEqual(levelID)