Skip to content

Latest commit

 

History

History
76 lines (54 loc) · 1.93 KB

README.md

File metadata and controls

76 lines (54 loc) · 1.93 KB

san-jest

san-jest 是一个 .san 文件的 jest 转换器。

项目部分代码来自 @vue/vue2-jest@27

test

特性

  1. 支持 css modules

  2. 自定义所有模块的编译选项

  3. 可以结合 webpack

  4. 无硬性依赖

使用

首先安装依赖,直接 npm i 即可:

npm i
# or
yarn

然后在 package.json 中添加以下字段:

"jest": {
    "testEnvironment": "jsdom",
    "moduleFileExtensions": [
        "js",
        "ts",
        "json",
        "san"
    ],
    "transform": {
      "^.+\\.js$": "<rootDir>/node_modules/babel-jest",
      "^.+\\.san$": "<rootDir>/node_modules/san-jest"
    },
    "globals": {
        "san-jest": {
            "templateCompileOptions": {
                "compileANode": "aNode" // 对全部 .san 文件生效
            },
            "styleCompileOptions": {},
            "scriptCompileOptions": {}
        }
    }
},

san-jest 的选项见 👀 san-sfc-compiler

这里有个注意的地方,需要写相对路径 "^.+\\.san$": "<rootDir>/node_modules/san-jest" 而不是直接 san-jest,覆盖率会统计不到 .san 文件。

选项

方法 / 属性 描述 类型
templateCompileOptions san-sfc-compiler 的选项 Object
styleCompileOptions 同上 Object
scriptCompileOptions 同上 Object

说明

  1. sass / scss / stylus 目前支持不完善,它们的 @import 语法有可能会有问题

  2. 关于 scoped css,因为 san-test-utils 无法获取组件生成的 html 中的 css 代码,所以你的测试用例可能无效

协议

MIT. Copyright (c) Baidu Inc. All rights reserved.