Как работает jest.fn ()

Может кто-нибудь объяснить, как jest.fn () на самом деле работает с примером из реального мира, так как я буквально запутался в том, как его использовать и где его следует использовать.

Например, если у меня есть компонент Страны, который выбирает Список стран по нажатию кнопки с помощью функции Utils

export default class Countries extends React.Component {
  constructor(props) {
    super(props)

    this.state = {
      countryList:''
    }
  }

  getList() {
    //e.preventDefault();
    //do an api call here
    let list = getCountryList();
    list.then((response)=>{ this.setState({ countryList:response }) });
  }

  render() {

    var cListing = "Click button to load Countries List";

    if(this.state.countryList) {
      let cList = JSON.parse(this.state.countryList);
      cListing = cList.RestResponse.result.map((item)=> { return(<li key={item.alpha3_code}> {item.name} </li>); });
    }

    return (
      <div>
        <button onClick={()=>this.getList()} className="buttonStyle"> Show Countries List </button>
        <ul>
          {cListing}
        </ul>
      </div>
    );

  }
}

Используется функция Utils

const http = require('http');


    export function getCountryList() {
      return new Promise(resolve => {
        let url = "/country/get/all";
        http.get({host:'services.groupkt.com',path: url,withCredentials:false}, response => {
          let data = '';
          response.on('data', _data => data += _data);
          response.on('end', () => resolve(data));
        });
      });


    }

где я могу использовать Jest.fn () или как я могу проверить, вызывается ли функция getList, когда я нажимаю на кнопку

Ответы на вопрос(1)

Ваш ответ на вопрос