使用Jest在Vue测试中找不到模块'@ jest / globals'

时间:2020-05-14 10:22:07

标签: javascript vue.js testing jestjs

我正在尝试从Project内部的vue文档编写一个非常简单的测试。 我可以在项目中使用笑话来运行测试,但是一旦我尝试用笑话来模拟axios请求,我就会遇到此错误:

 FAIL  tests/unit/test.spec.js

●测试套件无法运行

Cannot find module '@jest/globals' from 'test.spec.js'

  14 |   })

  at Resolver.resolveModule (node_modules/jest-resolve/build/index.js:259:17)
  at _getJestObj (tests/unit/test.spec.js:16:7)
  at Object.<anonymous> (tests/unit/test.spec.js:3:1)

这是我的Foo组件:

<template>
  <button @click="fetchResults">{{ value }}</button>
</template>

<script>
  import axios from 'axios'

  export default {
    data() {
      return {
        value: null
      }
    },

    methods: {
      async fetchResults() {
        const response = await axios.get('mock/service')
        this.value = response.data
      }
    }
  }
</script>

与相关的测试:

import { shallowMount } from '@vue/test-utils'
import Foo from './Foo'
jest.mock('axios', () => ({
  get: Promise.resolve('value')
}))

it('fetches async when a button is clicked', done => {
    const wrapper = shallowMount(Foo)
    wrapper.find('button').trigger('click')
    wrapper.vm.$nextTick(() => {
      expect(wrapper.text()).toBe('value')
      done()
    })
  }

任何帮助将不胜感激:) 谢谢大家!

2 个答案:

答案 0 :(得分:7)

假设您还使用babel-jest,请确保同时将jestbabel-jest的两个版本都设置为26。我遇到了同样的问题,这是因为软件包版本不同步。

答案 1 :(得分:0)

就我而言,此错误发生在babel-jest@26.0.1中。降级为babel-jest@21.2.0后,问题消失了。