2017-01-24 55 views
18

Mam składnikiem reakcji (to jest uproszczone w celu wykazania wydania)Jak drwić React metod składnik o żartach i enzymów

class MyComponent extends Component { 
    handleNameInput = (value) => { 
     this.searchValue(value); 
    }; 

    searchValue = (value) => { 
     //Do something 
    } 

    render() { 
     reutrn(<div></div>) 
    } 
} 

Teraz chcę przetestować że handleNameInput() Telefonowanie searchValue z podanej wartości .

W tym celu chciałbym stworzyć jest mock function, który zastępuje metodę komponentu.

Oto mój przypadek testowy do tej pory:

it('handleNameInput',() => { 
    let wrapper = shallow(<MyComponent/>); 
    wrapper.searchDish = jest.fn(); 
    wrapper.instance().handleNameInput('BoB'); 
    expect(wrapper.searchDish).toBeCalledWith('BoB'); 
}) 

Ale mam w konsoli jest SyntaxError:

SyntaxError

at XMLHttpRequest.open (node_modules/jsdom/lib/jsdom/living/xmlhttprequest.js:458:15) 
    at run_xhr (node_modules/browser-request/index.js:215:7) 
    at request (node_modules/browser-request/index.js:179:10) 
    at DishAdmin._this.searchDish (src/main/react/components/DishAdmin.js:155:68) 
    at DishAdmin._this.handleNameInput (src/main/react/components/DishAdmin.js:94:45) 
    at Object.<anonymous> (src/main/react/tests/DishAdmin.test.js:122:24) 

Więc moje pytanie brzmi: jak właściwie kpić z metod składowych z enzymem?

+0

Jaki jest błąd składni? –

+0

Dodano do pytania :) –

+0

Bez dokładnego rozpoznania źródła nie można pomóc - nie widzę żadnych błędów składniowych w kodzie, który opublikowałeś. –

Odpowiedz

35

Metoda może być wyśmiewany w ten sposób:

it('handleNameInput',() => { 
    let wrapper = shallow(<MyComponent/>); 
    wrapper.instance().searchDish = jest.fn(); 
    wrapper.update(); 
    wrapper.instance().handleNameInput('BoB'); 
    expect(wrapper.instance().searchDish).toBeCalledWith('BoB'); 
}) 

też trzeba zadzwonić .update na opakowaniu badanego składnika w celu zarejestrowania funkcji makiety prawidłowo.

Błąd składniowy pochodził z niewłaściwego przypisania (trzeba przypisać metodę do instancji). Inne moje problemy wynikały z braku wywoływania .update() po wyśmiewaniu metody.

+0

Dla mnie to rzuca i błąd z 'spodziewać (wrapper.searchDish)' - nie fałszywa funkcja lub szpieg. Tylko gdy zmienię na 'expect (wrapper.instance(). SearchDish), to działa poprawnie. –

+0

@NikSumeiko nawet otrzymałem ten sam błąd, zapisałem funkcję symulującą do zmiennej i sprawdziłem 'toBeCalledWith' na tym: ' const searchDishMock = jest.fn(); ... oczekiwać (searchDishMock) .toBeCalledWith ("BoB"); ' – Yusufali2205

+0

Jeśli' wrapper.update(); 'nie działa, możesz również wypróbować' wrapper.instance(). ForceUpdate(); ' –

0

@ odpowiedź miha pracował z małą zmianą:

it('handleNameInput',() => { 
    let wrapper = shallow(<MyComponent/>); 
    const searchDishMock = jest.fn(); 
    wrapper.instance().searchDish = searchDishMock; 
    wrapper.update(); 
    wrapper.instance().handleNameInput('BoB'); 
    expect(searchDishMock).toBeCalledWith('BoB'); 
})