From 6babb5de383df9a3744cbdcf8244ef75d339d4f9 Mon Sep 17 00:00:00 2001 From: Domenico Matteo Date: Tue, 21 Jul 2015 22:27:20 +0200 Subject: [PATCH] improve ReactTestUtils.Simulate documentation --- docs/10.4-test-utils.md | 15 +++++++++++---- 1 file changed, 11 insertions(+), 4 deletions(-) diff --git a/docs/10.4-test-utils.md b/docs/10.4-test-utils.md index aacd81a6..98345f7f 100644 --- a/docs/10.4-test-utils.md +++ b/docs/10.4-test-utils.md @@ -16,15 +16,22 @@ Simulate.{eventName}(DOMElement element, object eventData) Simulate an event dispatch on a DOM node with optional `eventData` event data. **This is possibly the single most useful utility in `ReactTestUtils`.** -Example usage: +**Clicking an element** +```javascript +var node = React.findDOMNode(this.refs.button); +React.addons.TestUtils.Simulate.click(node); +``` +**Changing the value of an input field and then pressing ENTER** ```javascript var node = React.findDOMNode(this.refs.input); -React.addons.TestUtils.Simulate.click(node); -React.addons.TestUtils.Simulate.change(node, {target: {value: 'Hello, world'}}); -React.addons.TestUtils.Simulate.keyDown(node, {key: "Enter"}); +node.value = 'giraffe' +React.addons.TestUtils.Simulate.change(node); +React.addons.TestUtils.Simulate.keyDown(node, {key: "Enter", keyCode: 13, which: 13}); ``` +*note that you will have to provide any event property that you're using in your component (e.g. keyCode, which, etc...) as React is not creating any of these for you* + `Simulate` has a method for every event that React understands. ### renderIntoDocument