Setup using vitest
vitest
is the most modern and user-friendly testing platform built on top of vite
with out-of-box ESM and TypeScript support.
TIP
You can see the described example as a code in the repository here.
Note
This section shows the minimal configuration - for full features and nice defaults, check out the API Reference
section or inspect all the options inline using editor's suggestions.
Create a vitest
setup file with the following content:
ts
// 1. Import testing functions
// This is optional - if you prefer globally declared functions for testing,
// the module will pick the necessary functions from the global scope by itself.
import { assert, describe, expect, it } from 'vitest';
// 2. Import the factory that will create functions bound to `vitest`
import { createTestUtils } from '@morev/stylelint-testing-library';
// 3. Import types if you need to.
// You can declare global types directly in the same file (below).
import type { CreateTestRule, CreateTestRuleConfig } from '@morev/stylelint-testing-library';
// 4. Create testing functions
// Passing `testFunctions` is optional if you prefer globally declared functions.
// To see all available `createTestUtils` options, please
// refer to the `API Reference` section of this documentation
// or use inline IDE suggestions.
const { createTestRule, createTestRuleConfig } = createTestUtils({
testFunctions: { assert, describe, expect, it },
});
// 5. Make these functions globally available
// If you don't like to declare test functions globally -
// I guess you know how to design getting these functions as a separate hook :)
globalThis.createTestRule = createTestRule;
globalThis.createTestRuleConfig = createTestRuleConfig;
// 6. Declare a type for globally registered functions
// It's optional, but objectively there's no reason not to do it.
declare global {
var createTestRule: CreateTestRule;
var createTestRuleConfig: CreateTestRuleConfig;
}
ts
import { assert, describe, expect, it } from 'vitest';
import { createTestUtils } from '@morev/stylelint-testing-library';
import type { CreateTestRule, CreateTestRuleConfig } from '@morev/stylelint-testing-library';
const { createTestRule, createTestRuleConfig } = createTestUtils({
testFunctions: { assert, describe, expect, it },
});
globalThis.createTestRule = createTestRule;
globalThis.createTestRuleConfig = createTestRuleConfig;
declare global {
var createTestRule: CreateTestRule;
var createTestRuleConfig: CreateTestRuleConfig;
}
Next, specify the path to it in the vitest
configuration file as setupFiles
option:
ts
import { defineConfig } from 'vitest/config';
export default defineConfig({
test: {
setupFiles: ['./vitest.setup.ts'],
},
});
Next, create a script for testing in your package.json
:
json
{
"name": "your-awesome-stylelint-plugin",
"scripts": {
"test": "vitest"
},
}
We're all set!
Next, follow the instructions on the Usage
page.