mirror of
https://github.com/Foundry376/Mailspring.git
synced 2025-01-11 02:30:21 +08:00
39768fd9d4
Great breakdown of React changes here: https://github.com/facebook/react/blob/master/CHANGELOG.md#0140-october-7-2015 Due to deprecation warnings, I don't think this will break third-party extensions unless they were doing really bad things.
58 lines
1.9 KiB
CoffeeScript
58 lines
1.9 KiB
CoffeeScript
# Utils for testing.
|
|
CSON = require 'season'
|
|
React = require 'react'
|
|
ReactDOM = require 'react-dom'
|
|
KeymapManager = require 'atom-keymap'
|
|
ReactTestUtils = require('react-addons-test-utils')
|
|
|
|
NylasTestUtils =
|
|
loadKeymap: (keymapPath) ->
|
|
{resourcePath} = NylasEnv.getLoadSettings()
|
|
basePath = CSON.resolve("#{resourcePath}/keymaps/base")
|
|
NylasEnv.keymaps.loadKeymap(basePath)
|
|
|
|
if keymapPath?
|
|
keymapPath = CSON.resolve("#{resourcePath}/#{keymapPath}")
|
|
NylasEnv.keymaps.loadKeymap(keymapPath)
|
|
|
|
keyDown: (key, target) ->
|
|
event = KeymapManager.buildKeydownEvent(key, target: target)
|
|
NylasEnv.keymaps.handleKeyboardEvent(event)
|
|
|
|
# React's "renderIntoDocument" does not /actually/ attach the component
|
|
# to the document. It's a sham: http://dragon.ak.fbcdn.net/hphotos-ak-xpf1/t39.3284-6/10956909_1423563877937976_838415501_n.js
|
|
# The Atom keymap manager doesn't work correctly on elements outside of the
|
|
# DOM tree, so we need to attach it.
|
|
renderIntoDocument: (component) ->
|
|
node = ReactTestUtils.renderIntoDocument(component)
|
|
$node = ReactDOM.findDOMNode(node)
|
|
unless document.body.contains($node)
|
|
parent = $node
|
|
while parent.parentNode?
|
|
parent = parent.parentNode
|
|
document.body.appendChild(parent)
|
|
return node
|
|
|
|
removeFromDocument: (reactElement) ->
|
|
$el = ReactDOM.findDOMNode(reactElement)
|
|
if document.body.contains($el)
|
|
for child in Array::slice.call(document.body.childNodes)
|
|
if child.contains($el)
|
|
document.body.removeChild(child)
|
|
return
|
|
|
|
# Returns mock observable that triggers immediately and provides helper
|
|
# function to trigger later
|
|
mockObservable: (data, {dispose} = {}) ->
|
|
dispose ?= ->
|
|
func = ->
|
|
return {
|
|
subscribe: (fn) ->
|
|
func = fn
|
|
func(data)
|
|
return {dispose}
|
|
triggerNext: (nextData = data) ->
|
|
func(nextData)
|
|
}
|
|
|
|
module.exports = NylasTestUtils
|