forked from instructure/canvas-lms
-
Notifications
You must be signed in to change notification settings - Fork 0
Expand file tree
/
Copy pathCheckboxViewSpec.coffee
More file actions
46 lines (40 loc) · 1.81 KB
/
Copy pathCheckboxViewSpec.coffee
File metadata and controls
46 lines (40 loc) · 1.81 KB
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
#
# Copyright (C) 2013 - present Instructure, Inc.
#
# This file is part of Canvas.
#
# Canvas is free software: you can redistribute it and/or modify it under
# the terms of the GNU Affero General Public License as published by the Free
# Software Foundation, version 3 of the License.
#
# Canvas is distributed in the hope that it will be useful, but WITHOUT ANY
# WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR
# A PARTICULAR PURPOSE. See the GNU Affero General Public License for more
# details.
#
# You should have received a copy of the GNU Affero General Public License along
# with this program. If not, see <http://www.gnu.org/licenses/>.
define ['jquery', 'underscore', 'compiled/views/gradebook/CheckboxView'], ($, _, CheckboxView) ->
QUnit.module 'gradebook/CheckboxView',
setup: ->
@view = new CheckboxView(color: 'red', label: 'test label')
@view.render()
@view.$el.appendTo('#fixtures')
@checkbox = @view.$el.find('.checkbox')
teardown: ->
$('#fixtures').empty()
test 'displays checkbox and label', ->
ok @view.$el.html().match(/test label/), 'should display label'
ok @view.$el.find('.checkbox').length, 'should display checkbox'
test 'toggles active state', ->
ok @view.checked, 'should default to checked'
@view.$el.click()
ok !@view.checked, 'should uncheck when clicked'
@view.$el.click()
ok @view.checked, 'should check when clicked'
test 'visually indicates state', ->
checkedColor = @view.$el.find('.checkbox').css('background-color')
ok _.include(['rgb(255, 0, 0)', 'red'], checkedColor), 'displays checked state'
@view.$el.click()
uncheckedColor = @view.$el.find('.checkbox').css('background-color')
ok _.include(['rgba(0, 0, 0, 0)', 'transparent'], uncheckedColor), 'displays unchecked state'