0

TestUtils.Simulate reactJS メソッドをテストするための非常に簡単なコンポーネントを作成します。しかし、このメソッドがコンポーネントの値を更新しない理由がわかりません。私は自分のコードを間違った方法で書いたと思います。

これは私の小さなコンポーネントです:

    'use strict';

var React = require('react');

var MyComponent = React.createClass({


    getInitialState: function () {
        return {value: 'a'};
    },
    handleChange: function (event) {
        this.setState({value: event.target.value});
    },
    render: function () {
        return (
            <div>
                <input
                    ref="inp"
                    type="text"
                    value={this.state.value}
                    onChange={this.handleChange}
                />
            </div>
        );
    }
});

module.exports = MyComponent;

そして、これはテストページです:

    jest.disableAutomock();
jest.unmock('../resources/assets/js/testcomponents/testvalue');


var React = require('react'),
    MyComponent = require('../resources/assets/js/testcomponents/testvalue.js'),
    TestUtils = require('react-addons-test-utils'),
    ReactDOM = require('react-dom');



describe('MyComponent', function () {

    var AppElement = TestUtils.renderIntoDocument(<MyComponent/>);
    var DomElement = ReactDOM.findDOMNode(AppElement);

    var input = DomElement.getElementsByTagName('input')[0];



    console.log('INPUT 1 as string: ' + input.outerHTML);

    it('type', function () {
        console.log('type=' + input.getAttribute('type'));
        expect(input.getAttribute('type')).toEqual('text');
    });

    it('value', function () {
        console.log('value=' + input.getAttribute('value'));
        expect(input.getAttribute('value')).toEqual('a');
    });

    it('change', function (){


        TestUtils.Simulate.change(input, {target: {value: 'giraffe'}});
        expect(input.getAttribute('value')).toEqual('giraffe');
    });
});

行 TestUtils.Simulate.change(input, {target: {value: 'giraffe'}}); 何も作りません

4

1 に答える 1

1

主な問題は、あなたが比較することだと思います

input.getAttribute('value')

元の値のみが含まれます。次のように更新された値を確認する必要があります。

expect(input.value).toEqual('giraffe');

jsfiddle Clickで動作するジャスミンテストをセットアップしました

于 2016-05-17T14:25:56.640 に答える