测试包含自己编写的其他组件的VueJS组件

时间:2018-11-01 22:31:33

标签: unit-testing vue.js vuejs2 vuetify.js vue-test-utils

我在一个包含多个包含其他组件的组件的网站上工作。现在,我想测试如果未设置任何数据,是否正确停用了表单的保存按钮。我正在使用UI的vuetify和用于测试的Jest。

这是我的父级组件,其中包含edit-user-details组件:

    <template>
    <v-container>
        <v-form v-model="valid">
            <v-card>
                <v-card-text>
                    <edit-user-details :user="user"></edit-user-details>
                </v-card-text>
                <v-card-actions>
                    <v-btn :disabled="!valid" @click="save()">Save</v-btn>
                    <v-btn @click="cancel()">Cancel</v-btn>
                </v-card-actions>
            </v-card>
        </v-form>
    </v-container>
</template>

<script>
    export default {
        name: "edit-user",
        components: {},
        data: () => ({
            user: {},
            valid: false
        }),
        methods: {
            save() {
                ...
            },
            cancel() {
                ...}
            }
        }
    }
</script>

这是edit-user-details组件的一部分:

<template>
    <v-container>
        <v-text-field
                v-model="user.userName"
                label="Username*"
                required
                :rules="[v => !!v || 'Please, enter a user name.']"
        ></v-text-field>
       ...
    </v-container>
</template>

<script>
    export default {
        name: "edit-user-details",
        props: {
            user: {
                type: Object,
                default: () => ({})
            }
        }
    }
</script>

这是我的测试:

import { mount, createLocalVue } from '@vue/test-utils'
import EditUser from '../../src/views/EditUser'
import Vuetify from 'vuetify';
import EditUserDetails from '../../src/components/EditUserDetails'


describe('Edited user data ', () => {

  it('can be saved if valid', () => {
      const localVue = createLocalVue();
      localVue.use(Vuetify)
      localVue.use(EditUserDetails)

      const wrapper = mount(EditUser, {
          localVue: localVue
      });

  })
})

该测试为绿色,因为它没有断言。主要问题是,我收到此错误:[Vue警告]:未知的自定义元素:-您是否正确注册了组件?对于递归组件,请确保提供“名称”选项。

所以我的问题是:如何测试包含我自己编写的其他组件的组件?

预先感谢您的帮助。

1 个答案:

答案 0 :(得分:2)

使用group by代替select

  

与安装类似,它会创建一个包装器,其中包含已安装的   呈现的Vue组件,但具有残存的子组件。

https://vue-test-utils.vuejs.org/api/#shallowmount