去抖动功能的 vue jest 单元测试

问题描述

我想从我创建的 debounce 函数编写一个单元测试,但我似乎找不到解决方案。

这是代码

    onSearchInputted: debounce(async function (e) {
        if (!this.search) {
          this.products = [...this.cachedProducts]
          return
        }

        try {
          const {data} = await this.$api.products.getAll((this.$helper.stringifyParams({
            ...this.params,name: this.search
          })))

          this.products = data.filter(v => !this.excludeItems.includes(v.id))

          this.products.forEach(v => {
            if (!this.cachedProducts.some(p => p.id === v.id)) {
              this.cachedProducts.push({...v})
            }
          })
        } catch (err) {
          this.products = []
        }
      },350)

到目前为止我尝试过的:

describe('debounce',() => {
      afterEach(() => {
        jest.restoreAllMocks();
        jest.resetAllMocks();
      });       
    jest.usefaketimers();   
      test('execute just once',async () => {
          const { wrapper } = shallowMountFunc(AutocompleteProduct,{
                mocks: {
                  ...dataMocks
                },data() {
                  return {
                    ...dataOptions
                  }
                }
          })      

          var test = jest.fn();
          var debounced = _.debounce(test,350);
         
          debounced();
         jest.runAllTimers()
         

          const vm = wrapper.vm;
          await vm.onSearchInputted()
      });
  });    

我在某处读到测试去抖动功能应该使用 jest 内置计时器,但还没有找到解决方案,我应该如何解决这个问题?

解决方法

暂无找到可以解决该程序问题的有效方法,小编努力寻找整理中!

如果你已经找到好的解决方法,欢迎将解决方案带上本链接一起发送给小编。

小编邮箱:dio#foxmail.com (将#修改为@)

相关问答

Selenium Web驱动程序和Java。元素在(x,y)点处不可单击。其...
Python-如何使用点“。” 访问字典成员?
Java 字符串是不可变的。到底是什么意思?
Java中的“ final”关键字如何工作?(我仍然可以修改对象。...
“loop:”在Java代码中。这是什么,为什么要编译?
java.lang.ClassNotFoundException:sun.jdbc.odbc.JdbcOdbc...