Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/blueprintui/web-test-runner-jasmine
Plugin for using Jasmine with Web Test Runner
https://github.com/blueprintui/web-test-runner-jasmine
jasmine web-test-runner
Last synced: 3 months ago
JSON representation
Plugin for using Jasmine with Web Test Runner
- Host: GitHub
- URL: https://github.com/blueprintui/web-test-runner-jasmine
- Owner: blueprintui
- License: mit
- Created: 2021-10-18T03:09:39.000Z (over 3 years ago)
- Default Branch: main
- Last Pushed: 2024-04-28T19:11:19.000Z (9 months ago)
- Last Synced: 2024-05-01T09:45:16.540Z (9 months ago)
- Topics: jasmine, web-test-runner
- Language: TypeScript
- Homepage:
- Size: 223 KB
- Stars: 4
- Watchers: 1
- Forks: 3
- Open Issues: 3
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
# web-test-runner-jasmine
[![npm version](https://badge.fury.io/js/web-test-runner-jasmine.svg)](https://badge.fury.io/js/web-test-runner-jasmine) ![CI Build](https://github.com/coryrylan/web-test-runner-jasmine/actions/workflows/build.yml/badge.svg)
A [Web Test Runner](https://modern-web.dev/docs/test-runner/overview/) plugin for running Jasmine.
## Setup
Import `jasmineTestRunnerConfig` and add too your `web-test-runner.config.mjs`.
If using TypeScript you can add `esbuildPlugin`.```javascript
import { playwrightLauncher } from '@web/test-runner-playwright';
import { esbuildPlugin } from '@web/dev-server-esbuild';
import { jasmineTestRunnerConfig } from 'web-test-runner-jasmine';export default /** @type {import("@web/test-runner").TestRunnerConfig} */ ({
...jasmineTestRunnerConfig(),
testFramework: {
config: {
defaultTimeoutInterval: 5000
},
},
nodeResolve: true,
files: ['./src/*.spec.js'],
browsers: [playwrightLauncher({ product: 'chromium' })],
plugins: [esbuildPlugin({ target: 'auto', sourceMap: true })]
});
```Once added you can use Jasmine within your tests.
```javascript
describe('a test suite', () => {
let element: HTMLElement;beforeEach(() => {
element = document.createElement('p');
element.innerHTML = 'hello there';
});afterEach(() => {
element.remove();
});it('should create element', () => {
expect(element.innerHTML).toBe('hello there');
});
});
```To run your tests run `web-test-runner` in the terminal.
```bash
web-test-runner
```## TypeScript
If you use TypeScript you will need to add some additional configuiration. Update your
config to read `.ts` extentions and add the `ts: true` flag to the `esBuildPlugin`.```javascript
import { playwrightLauncher } from '@web/test-runner-playwright';
import { esbuildPlugin } from '@web/dev-server-esbuild';
import { jasmineTestRunnerConfig } from 'web-test-runner-jasmine';export default /** @type {import("@web/test-runner").TestRunnerConfig} */ ({
...
files: ['./src/*.spec.ts'],
plugins: [esbuildPlugin({ ts: true, json: true, target: 'auto', sourceMap: true })]
...
});
```Ensure you have the `@types/jasmine` package installed and add `jasmine` to the `types`
in your `tsconfig.json`.```json
{
"compilerOptions": {
...
"types": ["jasmine"],
...
}
}
```Learn more about [Web Test Runner](https://modern-web.dev/docs/test-runner/overview/).