Vue Jest не ждет Axios Post - PullRequest
       6

Vue Jest не ждет Axios Post

3 голосов
/ 27 сентября 2019

Я тестирую запрос на вход, но Jest не вызывает макет:

Это mys test:

const User = '123123'

jest.mock('axios', () => ({
  get: jest.fn(),
  post: (_url, _body) => new Promise((resolve, reject) => {
    if (_body.username != User) return reject({ data: { auth: false } })
    resolve({
      data: {
        auth: true,
        data: '123456789789213',
        name: 'Indra'
      }
    })
  })
}))

describe('Component', () => {
  let actions
  let store

  beforeEach(() => {
    actions = {
      logIn: jest.fn()
    }
    store = new Vuex.Store({
      actions
    })
  })
test('Logins in server', () => {
    const wrapper = shallowMount(Login, { store, localVue })

    const inputLogin = wrapper.find('[name=login]')
    const inputPassword = wrapper.find('[name=password]')

    //fake user and password
    inputLogin.element.value = User
    inputPassword.element.value = 'Indra1234'

    wrapper.find('button').trigger('click')
    expect(actions.logIn).toHaveBeenCalled()
  })
})

И это моя функция входа

methods : {
        AuthUser () {
            if(this.server == "Selecione um servidor") return this.$swal('Atenção', 'Favor selecionar um servidor!', 'error');
            console.log("Solicitando login")
            this.loading = true
            try {
                axios.post(this.server+"/auth",
                {
                    username: this.id,
                    password: this.password
                })
                .then(result => {
                    console.log(result)
                    if(result.data.auth) {
                        this.tk = result.data.data
                        this.nome = result.data.name
                        this.logIn
                        setTimeout(() => {
                            console.log("oi")
                            $("body, this").css("background-color","#FBF5F3");
                            // this.$router.push('/home')
                            this.$eventHub.$emit('logIn', 1);
                        }, 1000);

                    } else {
                        this.loading = false
                        this.$swal('Atenção', 'Usuário ou senha incorretos!', 'warning');
                    }
                }).catch((er) => {
                    this.loading = false
                    this.$swal('Desculpe', 'Ocorreu um erro de comunicação com o servidor!', 'error');
                    console.log(er)
                })
            } catch (error) {
                this.loading = false
                this.$swal('Desculpe', 'Ocorreu um erro ao realizar o login', 'error');
                console.log('Erro interno: ', error)
            }

        }
    }

И когда я запускаю тест

enter image description here

, обратите внимание, что в журнале консоли «Solicitando login» он вызывается.Конфиги теста были сделаны Vue cli 3, и я использую https://lmiller1990.github.io/vue-testing-handbook/vuex-actions.html#creating-the-action в качестве эталона

Ответы [ 2 ]

1 голос
/ 27 сентября 2019

Я не вижу, как ты сбрасываешь обещания.Можете ли вы попробовать использовать библиотеку обещаний флеша?

npm i --save-dev flush-promises

, а затем ...

// up top
import flushPromises from 'flush-promises';

//...
    wrapper.find('button').trigger('click');
    await flushPromises();
    expect(actions.logIn).toHaveBeenCalled();

подробнее здесь ... https://vue -test-utils.vuejs.org / направляющие / тестирование Асинхр-components.html

0 голосов
/ 27 сентября 2019

Проблема была в том, что когда я устанавливал входные значения.

Когда я регистрирую console.log (wrapper.vm.id, wrapper.vm.password), они были нулевыми

Длярешить

    inputLogin.element.value = User
    inputLogin.trigger('input');
    inputPassword.element.value = 'Indra1234'
    inputPassword.trigger('input');

И, конечно, также flushPromises ()

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...