Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/tmeasday/test-reporter-helpers
https://github.com/tmeasday/test-reporter-helpers
Last synced: 30 days ago
JSON representation
- Host: GitHub
- URL: https://github.com/tmeasday/test-reporter-helpers
- Owner: tmeasday
- Created: 2016-02-18T07:53:16.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2016-03-14T00:14:23.000Z (almost 9 years ago)
- Last Synced: 2024-10-26T03:44:11.787Z (3 months ago)
- Language: JavaScript
- Size: 3.91 KB
- Stars: 0
- Watchers: 1
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# Helpers to allow your test reporter to work in full-app mode in Meteor 1.3
When you run [full-app tests in Meteor 1.3](https://github.com/meteor/guide/blob/testing-modules-content/content/testing.md#full-app-testing), your app is loaded as usual, and it is the responsibility of the test driver to hide the app and display a test reporting chrome over the top.
This package gives you a couple of useful utilities to do so.
## Writing a test driver package
- You should ensure your package is marked `testOnly`, to ensure any styles and code run by the package does not load in development or production mode.
- You need to export a function called `runTests` from your package. This is the right point to call these utilities.## API
### `hideApp(selector)`
Hide all children of the body that do not match a CSS `selector`. This would be the CSS selector that wraps your test reporter. You can call this before or after adding your reporter to the body.
### `hideOtherCSS(delimiter)`
In order to ensure that the app's CSS doesn't mess with your reporter's UI, you can use this technique to strip out all CSS that is not between two selectors that match `delimiter`.
For instance you could include a stylesheet in your package that looks like:
```css
.xxxReporterCss { color: white; }#your-reporter {
/* style away */
}.xxxReporterCss { color: white; }
```All other styles defined by the application will be stripped away.
**NOTE** that your styles *must* be between the delimter. Specifically if you want to e.g. use styles from bootstrap, you'll need to manually add the bootstrap styles in your package rather depending on the `bootstrap` package.
Alternatively, you could do a style reset using `!important` rules. Note that your stylesheet will probably load midway through the CSS file.