codecombat/test/app/views/editor/component/ThangComponentsEditView.spec.coffee

63 lines
No EOL
2 KiB
CoffeeScript

ThangComponentEditView = require('views/editor/component/ThangComponentsEditView')
SuperModel = require('models/SuperModel')
LevelComponent = require('models/LevelComponent')
responses =
'/db/level.component/B/version/0': {
system: 'System'
original: 'B'
version: {major: 0, minor:0}
name: 'B (depends on A)'
dependencies: [{original:'A', majorVersion: 0}]
}
'/db/level.component/A/version/0': {
system: 'System'
original: 'A'
version: {major: 0, minor:0}
name: 'A'
configSchema: { type: 'object', properties: { propA: { type: 'number' }, propB: { type: 'string' }} }
}
componentC = new LevelComponent({
system: 'System'
original: 'C'
version: {major: 0, minor:0}
name: 'C (depends on B)'
dependencies: [{original:'B', majorVersion: 0}]
})
componentC.loaded = true
describe 'ThangComponentsEditView', ->
view = null
beforeEach (done) ->
supermodel = new SuperModel()
supermodel.registerModel(componentC)
view = new ThangComponentEditView({ components: [], supermodel: supermodel })
_.defer ->
view.render()
view.componentsTreema.set('/', [ { original: 'C', majorVersion: 0 }])
spyOn(window, 'noty')
success = jasmine.Ajax.requests.sendResponses(responses)
expect(success).toBeTruthy()
_.defer ->
done()
afterEach ->
view.destroy()
it 'loads dependencies when you add a component with the left side treema', ->
expect(_.size(view.subviews)).toBe(3)
# TODO: Figure out why this is breaking karma but not always
it 'adds dependencies to its components list', ->
componentOriginals = (c.original for c in view.components)
expect('A' in componentOriginals).toBeTruthy()
expect('B' in componentOriginals).toBeTruthy()
expect('C' in componentOriginals).toBeTruthy()
it 'removes components that are dependent on a removed component', ->
view.components = (c for c in view.components when c.original isnt 'A')
view.onComponentsChanged()
expect(view.components.length).toBe(0)
expect(_.size(view.subviews)).toBe(0)