2015-03-06 08:00:56 +08:00
|
|
|
# This tests the basic Contenteditable component. For various modules of
|
|
|
|
# the contenteditable (such as selection, tooltip, quoting, etc) see the
|
|
|
|
# related test files.
|
|
|
|
#
|
2015-02-19 06:24:16 +08:00
|
|
|
_ = require "underscore-plus"
|
|
|
|
React = require "react/addons"
|
|
|
|
ReactTestUtils = React.addons.TestUtils
|
2015-03-21 08:51:49 +08:00
|
|
|
ContenteditableComponent = require "../lib/contenteditable-component",
|
2015-02-19 06:24:16 +08:00
|
|
|
|
2015-03-06 08:02:47 +08:00
|
|
|
describe "ContenteditableComponent", ->
|
2015-02-19 06:24:16 +08:00
|
|
|
beforeEach ->
|
|
|
|
@onChange = jasmine.createSpy('onChange')
|
|
|
|
html = 'Test <strong>HTML</strong>'
|
|
|
|
@component = ReactTestUtils.renderIntoDocument(
|
|
|
|
<ContenteditableComponent html={html} onChange={@onChange}/>
|
|
|
|
)
|
2015-03-06 08:15:29 +08:00
|
|
|
@editableNode = ReactTestUtils.findRenderedDOMComponentWithAttr(@component, 'contentEditable').getDOMNode()
|
2015-02-19 06:24:16 +08:00
|
|
|
|
|
|
|
describe "render", ->
|
|
|
|
it 'should render into the document', ->
|
|
|
|
expect(ReactTestUtils.isCompositeComponentWithType @component, ContenteditableComponent).toBe true
|
|
|
|
|
|
|
|
it "should include a content-editable div", ->
|
2015-03-06 08:15:29 +08:00
|
|
|
expect(@editableNode).toBeDefined()
|
2015-02-19 06:24:16 +08:00
|
|
|
|
|
|
|
describe "when the html is changed", ->
|
|
|
|
beforeEach ->
|
|
|
|
@changedHtmlWithoutQuote = 'Changed <strong>NEW 1 HTML</strong><br>'
|
|
|
|
|
2015-03-06 08:00:56 +08:00
|
|
|
@performEdit = (newHTML, component = @component) =>
|
2015-03-06 08:15:29 +08:00
|
|
|
@editableNode.innerHTML = newHTML
|
|
|
|
ReactTestUtils.Simulate.input(@editableNode, {target: {value: newHTML}})
|
2015-02-19 06:24:16 +08:00
|
|
|
|
|
|
|
it "should fire `props.onChange`", ->
|
|
|
|
@performEdit('Test <strong>New HTML</strong>')
|
|
|
|
expect(@onChange).toHaveBeenCalled()
|
|
|
|
|
2015-03-03 07:33:58 +08:00
|
|
|
# One day we may make this more efficient. For now we aggressively
|
|
|
|
# re-render because of the manual cursor positioning.
|
|
|
|
it "should fire if the html is the same", ->
|
2015-02-19 06:24:16 +08:00
|
|
|
expect(@onChange.callCount).toBe(0)
|
|
|
|
@performEdit(@changedHtmlWithoutQuote)
|
|
|
|
expect(@onChange.callCount).toBe(1)
|
|
|
|
@performEdit(@changedHtmlWithoutQuote)
|
2015-03-03 07:33:58 +08:00
|
|
|
expect(@onChange.callCount).toBe(2)
|