模拟 Capacitor 插件
在应用中创建单元测试时,最佳实践是为被测单元的任何外部依赖项创建模拟。这包括您的组件或服务正在使用的 Capacitor 插件。
大多数模拟库通过获取一个对象并将其包装在 JavaScript 代理中来创建模拟,以便可以检查对该对象方法的调用并控制方法的返回值。然而,Capacitor 插件在 JavaScript 层中被实现为代理。创建代理的代理不受支持且会失败。手动模拟可以用来规避此问题。
手动模拟
手动模拟允许用户轻松地存根整个 JavaScript 模块的功能。因此,当测试执行 import { Storage } from '@capacitor/storage' 时,测试将加载类似下面的内容,而不是加载真正的 Storage JavaScript 代理对象:
export const Storage = {
async get(data: { key: string }): Promise<{ value: string | undefined }> {
return { value: undefined };
},
async set(data: { key: string; value: string }): Promise<void> {},
async clear(): Promise<void> {},
};
由于这是一个普通的 JavaScript 对象而不是代理对象,因此非常容易进行 spy 操作。同时,由于它是模拟对象,它不会尝试进行任何原生调用。这使得手动模拟成为测试使用 Capacitor 插件的代码时的理想选择。
Jest
Jest 测试框架内置了手动模拟功能。在项目根目录创建一个 __mocks__/@capacitor文件夹,Jest 将自动从此处加载文件,而不是从node_modules` 加载。
例如,假设您有以下目录结构:
.
|
+- __mocks__
| |
| +- @capacitor
| |
| +- storage.ts
| +- toast.ts
...
+- src
您的测试将使用 storage.ts 和 toast.ts 中定义的存根,而不是 node_modules 中真正的 @capacitor/storage 和 @capacitor/toast 插件。
Jasmine
Jasmine 测试框架不包含"手动模拟"的概念,但我们可以通过使用 TypeScript 路径映射来轻松模拟这一点。