codecombat/test/app/views/courses/HeroSelectModal.spec.coffee
Phoenix Eliot fd45c9d473 Implement HeroSelectModal for demo flow
Add Campaign factory

First basic tests for HeroSelectModal in demo flow

Implement HeroSelectModal for demo flow

Improve tests

Disable empty test

Fix text inconsistency around 'me'

Just listen once

Add HeroSelectModal events test

Don't reuse destroyed modal

Fix inconsistent modal close behavior

Fix tests
2016-08-16 11:19:40 -07:00

50 lines
1.9 KiB
CoffeeScript

HeroSelectModal = require 'views/courses/HeroSelectModal'
factories = require 'test/app/factories'
describe 'HeroSelectModal', ->
modal = null
coursesView = null
user = null
hero1 = factories.makeThangType({ original: "hero1original", _id: "hero1id", heroClass: "Warrior", name: "Hero 1" })
hero2 = factories.makeThangType({ original: "hero2original", _id: "hero2id", heroClass: "Warrior", name: "Hero 2" })
heroesResponse = JSON.stringify([hero1, hero2])
beforeEach (done) ->
window.me = user = factories.makeUser({ heroConfig: { thangType: hero1.get('original') } })
modal = new HeroSelectModal()
subview = modal.subviews.hero_select_view
subview.heroes.fakeRequests[0].respondWith({ status: 200, responseText: heroesResponse })
jasmine.demoModal(modal)
_.defer ->
modal.render()
done()
afterEach ->
modal.stopListening()
it 'highlights the current hero', ->
expect(modal.$(".hero-option[data-hero-original='#{hero1.get('original')}']")[0].className.split(" ")).toContain('selected')
it 'saves when you change heroes', (done) ->
modal.$(".hero-option[data-hero-original='#{hero2.get('original')}']").click()
_.defer ->
expect(user.fakeRequests.length).toBe(1)
request = user.fakeRequests[0]
expect(request.method).toBe("PUT")
expect(JSON.parse(request.params).heroConfig?.thangType).toBe(hero2.get('original'))
done()
it 'triggers its events properly', (done) ->
spyOn(modal, 'trigger')
modal.render()
modal.$('.hero-option:nth-child(2)').click()
request = jasmine.Ajax.requests.mostRecent()
request.respondWith({ status: 200, responseText: me.attributes })
expect(modal.trigger).toHaveBeenCalled()
expect(modal.trigger.calls.argsFor(0)[0]).toBe('hero-select:success')
expect(modal.trigger).not.toHaveBeenCalledWith('hide')
modal.$('.select-hero-btn').click()
expect(modal.trigger).toHaveBeenCalledWith('hide')
done()