为了账号安全,请及时绑定邮箱和手机立即绑定

toast组件单元测试

标签:
JavaScript
  1. 先看是否存在

     describe('Toast', () => {
         it('存在.', () => {
             expect(Toast).to.be.exist
         })
     });
    
  2. 看属性,我们要测 ToastVue 和 plugin.js

     describe('Toast', () => {
     it('存在.', () => {
         expect(Toast).to.be.exist
     })
     describe('props',function () {
         this.timeout(15000) // 设置15秒关闭
         it('接收 autoClose', (done)=>{
         let div = document.createElement('div')
         document.body.appendChild(div)
         const Constructor = Vue.extend(Toast)
         const vm = new Constructor(
             {
             propsData:{
                 autoClose: true,
                 autoCloseDelay: 1
             }
             }
         ).$mount(div)
         setTimeout(()=>{
             expect(document.body.contains(vm.$el)).to.eq(false)
             done()
         },6000)
         })
     })
     });
     // 进一步优化,变成关闭的时候进行测试,不需要设置6秒
     vm.$on('close',()=>{
         expect(document.body.contains(vm.$el)).to.eq(false)
         done()
     })
    
  3. 报异常错误,要用 yarn run dev-test 代替 npm run dev-test

  4. 测试 closeButton。

    it('接收 closeButton', ()=>{
         const callback = sinon.fake();
      const Constructor = Vue.extend(Toast)
      const vm = new Constructor({
        propsData: {
          closeButton: {
            text: '关闭吧',
            callback,
          },
        }
      }).$mount()
      let closeButton = vm.$el.querySelector('.close')
      expect(closeButton.textContent.trim()).to.eq('关闭吧')
      closeButton.click()
      expect(callback).to.have.been.called
    })

这里测试后的时候出现 warning,Cannot read property ‘style’ of undefined,通过修改 toast.vue 中代码解决

    methods: {
        updateStyles () {
            this.$nextTick(() => {
                if(this.$refs.toast && this.$refs.line){
                    this.$refs.line.style.height =
                    `${this.$refs.toast.getBoundingClientRect().height}px`
                }
            })
        }
    }
点击查看更多内容
TA 点赞

若觉得本文不错,就分享一下吧!

评论

作者其他优质文章

正在加载中
  • 推荐
  • 评论
  • 收藏
  • 共同学习,写下你的评论
感谢您的支持,我会继续努力的~
扫码打赏,你说多少就多少
赞赏金额会直接到老师账户
支付方式
打开微信扫一扫,即可进行扫码打赏哦
今天注册有机会得

100积分直接送

付费专栏免费学

大额优惠券免费领

立即参与 放弃机会
意见反馈 帮助中心 APP下载
官方微信

举报

0/150
提交
取消