-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathindex.test.js
52 lines (47 loc) · 1.43 KB
/
index.test.js
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
const commitlint = require("@commitlint/lint");
const config = require("./commitlint.config.js");
const load = require("@commitlint/load");
const lint = async (message) => {
const preparedConfig = await load.default(config);
return commitlint.default(message, preparedConfig.rules, {
parserOpts: preparedConfig.parserPreset.parserOpts,
...preparedConfig,
});
};
test("good-messages", async () => {
const messages = [
"ci: hello, world", // anti-prettier
"feat!: hello, world", // breaking change
];
for (let message of messages) {
const result = await lint(message);
expect(result.valid).toBe(true);
}
});
test("no-type", async () => {
const message = "hello, world";
const result = await lint(message);
expect(result.valid).toBe(false);
});
test("bad-type", async () => {
const messages = [
"bad: hello, world", // no such type
"CI: hello, world", // wrong casing
"ci:hello, world", // space required
"ci - hello, world", // wrong delimeter
];
for (let message of messages) {
const result = await lint(message);
expect(result.valid).toBe(false);
}
});
test("referenced-word-inside-message", async () => {
const messages = [
"feat(GOOD-123)!: Add eslint autofix config", // "feat" inside message
"fix: smth autofix config", // "fix" inside message
];
for (let message of messages) {
const result = await lint(message);
expect(result.valid).toBe(true);
}
});