mirror of
https://github.com/codeninjasllc/codecombat.git
synced 2025-01-23 12:49:47 -05:00
73bbe598da
Improve image gallery Add How to Copy/Paste section Fix modal close button Add specs for image gallery Fix up i18n Fix render resetting scroll Address code review feedback Ensure afterRender is called
68 lines
2.9 KiB
CoffeeScript
68 lines
2.9 KiB
CoffeeScript
Course = require 'models/Course'
|
||
Level = require 'models/Level'
|
||
LevelSession = require 'models/LevelSession'
|
||
ImageGalleryModal = require 'views/play/level/modal/ImageGalleryModal'
|
||
ProgressView = require 'views/play/level/modal/ProgressView'
|
||
factories = require 'test/app/factories'
|
||
utils = require 'core/utils'
|
||
|
||
describe 'ImageGalleryModal', ->
|
||
modal = null
|
||
|
||
beforeEach (done) ->
|
||
modal = new ImageGalleryModal()
|
||
modal.render()
|
||
_.defer done
|
||
|
||
it '(demo)', ->
|
||
jasmine.demoModal(modal)
|
||
|
||
it 'shows a list of images', ->
|
||
expect(modal.$('img').length).toBeGreaterThan(16)
|
||
|
||
describe 'clicking an image', ->
|
||
beforeEach (done) ->
|
||
@clickedImage = modal.$('li:nth-child(5)').click()
|
||
@clickedImagePath = @clickedImage.data('portrait-url')
|
||
@clickedImageUrl = utils.pathToUrl(@clickedImagePath)
|
||
@clickedImageTag = '<img src="' + @clickedImageUrl + '"/>'
|
||
_.defer done
|
||
|
||
it 'highlights the chosen image', ->
|
||
expect(modal.$('li:nth-child(5)').hasClass('selected')).toBe(true)
|
||
|
||
it 'displays the URL/image tags in the Copy section', ->
|
||
expect(modal.$('.image-url').text()).toBe(@clickedImageUrl)
|
||
expect(modal.$('.image-tag').text()).toBe(@clickedImageTag)
|
||
|
||
describe "How to Copy/Paste section", ->
|
||
userAgents = {
|
||
windows: 'Mozilla/5.0 (Windows NT 6.3; Trident/7.0; rv:11.0) like Gecko'
|
||
mac: 'Mozilla/5.0 (Macintosh; Intel Mac OS X 10_11_6) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/52.0.2743.116 Safari/537.36'
|
||
}
|
||
|
||
it 'Shows Windows shortcuts to Windows users', (done) ->
|
||
spyOn(utils, 'userAgent').and.callFake ->
|
||
userAgents.windows
|
||
modal.render()
|
||
# This test is a little fragile — Only works if the text node is an immediate child to .windows-only
|
||
expect(modal.$('.how-to-copy-paste :not(.hidden)').text()).toMatch(/Control|Ctrl/i)
|
||
expect(modal.$('.how-to-copy-paste :not(.hidden)').text()).not.toMatch(/Command|Cmd/i)
|
||
@clickedImage = modal.$('li:nth-child(5)').click()
|
||
_.defer ->
|
||
expect(modal.$('.how-to-copy-paste :not(.hidden)').text()).toMatch(/Control|Ctrl/i)
|
||
expect(modal.$('.how-to-copy-paste :not(.hidden)').text()).not.toMatch(/Command|Cmd/i)
|
||
done()
|
||
|
||
it 'Shows Mac shortcuts to Mac users', (done) ->
|
||
spyOn(utils, 'userAgent').and.callFake ->
|
||
userAgents.mac
|
||
modal.render()
|
||
# This test is a little fragile — Only works if the text node is an immediate child to .mac-only
|
||
expect(modal.$('.how-to-copy-paste :not(.hidden)').text()).toMatch(/Command|Cmd/i)
|
||
expect(modal.$('.how-to-copy-paste :not(.hidden)').text()).not.toMatch(/Control|Ctrl/i)
|
||
@clickedImage = modal.$('li:nth-child(5)').click()
|
||
_.defer ->
|
||
expect(modal.$('.how-to-copy-paste :not(.hidden)').text()).toMatch(/Command|Cmd/i)
|
||
expect(modal.$('.how-to-copy-paste :not(.hidden)').text()).not.toMatch(/Control|Ctrl/i)
|
||
done()
|