Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/helpscout/seed-barista
☕️ Barista: CSS unit testing with Javascript
https://github.com/helpscout/seed-barista
css node-sass open-source sass seed unit-testing
Last synced: 3 months ago
JSON representation
☕️ Barista: CSS unit testing with Javascript
- Host: GitHub
- URL: https://github.com/helpscout/seed-barista
- Owner: helpscout
- Created: 2017-03-18T14:36:06.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2020-09-03T23:10:24.000Z (over 4 years ago)
- Last Synced: 2024-04-28T12:03:28.140Z (9 months ago)
- Topics: css, node-sass, open-source, sass, seed, unit-testing
- Language: JavaScript
- Homepage: http://developer.helpscout.net/seed/css-unit-testing/
- Size: 332 KB
- Stars: 25
- Watchers: 12
- Forks: 5
- Open Issues: 5
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Barista ☕️ [![Build Status](https://travis-ci.org/helpscout/seed-barista.svg?branch=master)](https://travis-ci.org/helpscout/seed-barista) [![Coverage Status](https://coveralls.io/repos/github/helpscout/seed-barista/badge.svg?branch=master)](https://coveralls.io/github/helpscout/seed-barista?branch=master) [![npm version](https://badge.fury.io/js/seed-barista.svg)](https://badge.fury.io/js/seed-barista) [![dependencies Status](https://david-dm.org/helpscout/seed-barista/status.svg)](https://david-dm.org/helpscout/seed-barista) [![Gitter](https://badges.gitter.im/join_chat.svg)](https://gitter.im/seed-css/barista)
Barista is a Javascript utility for (S)CSS unit testing, compatible with most major test runners and assertion libraries.
Seed isn't required for Barista to work. Although, Barista does make it easier to write tests for Seed CSS.
For added convenience, we recommend trying out [seed-bistro](https://github.com/helpscout/seed-bistro).
It comes with Barista + other libraries for CSS testing goodness 🙌The latest versions of Barista require **Node.js v6** or newer to work (and not explode).
## Install
```
npm install seed-barista --save-dev
```## Basic Usage
### [Static](/docs/api/static.md)
Below is an example of how you can setup a [Mocha](https://mochajs.org/) test with Barista. A fast and simple way to test `.scss` output is to verify the rendered output matches against expected strings.
```javascript
var expect = require('chai').expect;
var barista = require('seed-barista');describe('harry component styles', function() {
it('should render a class of wizard + harry', function() {
var output = barista({ file: '_wizard.scss' });
var rule = output.rule('.your-a-wizard.harry');expect(rule.exists()).to.be.true;
expect(rule.prop('background')).to.equal('red');
expect(rule.prop('color')).to.equal('yellow');
});
});
```Check out the full [API documentation](/docs/api/static.md)
### [Mounted](/docs/api/mounted.md)
Mounted based testing creates a [virtual DOM](https://github.com/tmpvar/jsdom), allowing you to write assertions against DOM elements. Barista's Mounted API uses jQuery to retrieve computed CSS styles.
```javascript
var expect = require('chai').expect;
var barista = require('seed-barista');describe('harry component styles', function() {
it('should render a class of wizard + harry', function() {
var output = barista({ file: '_wizard.scss' }).mount();
var rule = output.find('.your-a-wizard.harry');expect(rule.prop('background')).to.equal('red');
expect(rule.prop('color')).to.equal('yellow');
});
});
```Check out the full [API documentation](/docs/api/mounted.md)
## Examples
**Check out an [example test](https://github.com/helpscout/seed-barista/blob/master/test/integration/examples/button.js)**