11

我有一个使用element-ui组件的组件。

树.vue

<div>
  <el-tree :data="treeData" :props="config"></el-tree>
</div>

我想测试与组件的交互性(例如,能够单击其中一个el-treehtml 元素),但是当我vue-test-utils mount用来挂载Tree组件时,它不会呈现它的子组件,就像它shallow一样组件代替。

树.test.js

import Vue from 'vue';
import { mount } from 'vue-test-utils';
import Tree from './Tree.vue';

const wrapper = mount(Tree);

it('renders element ui tree component', () => {
  console.log(wrapper.html());
});

输出:

<div><el-tree data="[object Object],[object Object]" props="[object Object]"></el-tree></div>

知道如何完全渲染Tree组件,包括它的子组件吗?

4

3 回答 3

6

我有一个类似的问题,元素 ui 组件无法识别。

必须在测试文件中导入 createLocalVue 和 ElementUI

import { shallow, mount, createLocalVue } from '@vue/test-utils'
import Vue from 'vue';
import ElementUI from 'element-ui';
import Editor from '../src/components/layout/Editor'

接着

const localVue = createLocalVue();
localVue.use(ElementUI);

接着

describe('Editor', () => {
 let wrapper
 beforeEach(() => {
  wrapper = shallow(Editor, {localVue}, {
    data : {
      x: '0',
      y: '0',
    }
  })
})

it('renders a vue instance', () => {
  expect(wrapper.isVueInstance()).toBe(true);
})
于 2018-05-10T17:41:46.720 回答
0

这看起来像您没有el-tree正确导入组件。Vue 没有将<el-tree>标签翻译成组件,而是简单地将其视为 html 元素。

查看元素快速入门页面,了解导入组件的不同方法,并确保您已正确设置。

如果您仍有问题,请添加更多详细信息。

于 2018-04-01T01:51:02.480 回答
0

您应该在测试文件中导入 element-ui。看看这个:https ://vue-test-utils.vuejs.org/guides/#applying-global-plugins-and-mixins 。

但是,我不知道如何全局导入element-ui,所以我不需要在每个测试文件中手动导入它

于 2019-04-18T09:23:43.533 回答