Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/14nrv/jest-vue-matcher
Additional jest matchers for vue
https://github.com/14nrv/jest-vue-matcher
jest jest-matchers vue vue-test vue-test-utils vue-testing-tools vuejs wallaby
Last synced: 4 months ago
JSON representation
Additional jest matchers for vue
- Host: GitHub
- URL: https://github.com/14nrv/jest-vue-matcher
- Owner: 14nrv
- License: mit
- Created: 2018-10-19T13:13:00.000Z (over 6 years ago)
- Default Branch: dev
- Last Pushed: 2020-10-25T02:41:13.000Z (over 4 years ago)
- Last Synced: 2024-10-04T20:48:46.981Z (5 months ago)
- Topics: jest, jest-matchers, vue, vue-test, vue-test-utils, vue-testing-tools, vuejs, wallaby
- Language: JavaScript
- Size: 388 KB
- Stars: 8
- Watchers: 2
- Forks: 3
- Open Issues: 0
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
[data:image/s3,"s3://crabby-images/d4396/d4396e09e5e5d3a8852563a5041882d138a1de5a" alt="NPM Version"](https://www.npmjs.com/package/jest-vue-matcher)
[data:image/s3,"s3://crabby-images/f08bb/f08bbb3093aaa9bd66648093224d2e761e2910ab" alt="Build Status"](https://travis-ci.org/14nrv/jest-vue-matcher)
[data:image/s3,"s3://crabby-images/d9cba/d9cbac2653937b7c1589c4aab46689722b391417" alt="Test Coverage"](https://codeclimate.com/github/14nrv/jest-vue-matcher/test_coverage)
[data:image/s3,"s3://crabby-images/2bb0c/2bb0ce50c705e85d92813b07b09bfe6f8521272e" alt="Maintainability"](https://codeclimate.com/github/14nrv/jest-vue-matcher/maintainability)
[data:image/s3,"s3://crabby-images/fd432/fd43213bb59a161ac6c4afe58ccd16987c6acfd9" alt="License: MIT"](https://opensource.org/licenses/MIT)
[data:image/s3,"s3://crabby-images/c0ae3/c0ae335c28a46fdf42a2ff891e33de1371068750" alt="semantic-release"](https://github.com/semantic-release/semantic-release)
data:image/s3,"s3://crabby-images/eb397/eb397a029e6c13badccbdfa959963ed40767b2e7" alt="PRs Welcome"# jest-vue-matcher
Additional jest matchers for vue## Install
```
yarn add jest-vue-matcher -D
```## Setup
```js
import { mount } from '@vue/test-utils'
import matchers from 'jest-vue-matcher'
import MyComponent from '@/components/MyComponent.vue'let wrapper
describe('MyComponent', () => {
beforeEach(() => {
wrapper = mount(MyComponent)
expect.extend(matchers(wrapper))
})// ...
})
```## Matchers available
* toHaveText(text)
```js
expect('h1').toHaveText('My title')
expect('h1').not.toHaveText('Not my title')
```
* toBeADomElement()
```js
expect('h1').toBeADomElement()
expect('notH1').not.toBeADomElement()
```
* toHaveClass(className)
```js
expect('h1').toHaveClass('title')
expect('h1').not.toHaveClass('not-title')
```
* toHaveAttribute(attributeName, attributeValue)
```js
expect('h1').toHaveAttribute('class', 'title')
expect('h1').not.toHaveAClass('class', 'not-title')
```
* toHaveValue(value)
```js
expect('input[type=text]').toHaveValue('plop')
expect('input[type=text]').not.toHaveValue('not plop')
```
* toHaveProp(propName)
```js
expect(wrapper).toHaveProp('propName')
expect(wrapper).not.toHaveProp('not-propName')
```
* toEmit(eventName)
```js
expect(wrapper).toEmit('eventName')
expect(wrapper).not.toEmit('not eventName')
```
* toEmitWith(eventName, eventValue)
```js
expect(wrapper).toEmitWith('eventName', 'eventValue')
expect(wrapper).not.toEmitWith('not eventName', { data: 'eventValue' })
```## Inspiration
Inspirated by [mwangaben-vthelpers](https://github.com/mwangaben/mwangaben-vthelpers)