Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/mainmatter/ember-test-selectors
Enabling better element selectors in Ember.js tests
https://github.com/mainmatter/ember-test-selectors
ember hacktoberfest test test-selectors
Last synced: 5 days ago
JSON representation
Enabling better element selectors in Ember.js tests
- Host: GitHub
- URL: https://github.com/mainmatter/ember-test-selectors
- Owner: mainmatter
- License: mit
- Created: 2016-03-01T12:27:28.000Z (almost 9 years ago)
- Default Branch: master
- Last Pushed: 2024-10-18T21:37:15.000Z (2 months ago)
- Last Synced: 2024-10-29T17:34:33.888Z (about 2 months ago)
- Topics: ember, hacktoberfest, test, test-selectors
- Language: JavaScript
- Homepage:
- Size: 4.97 MB
- Stars: 263
- Watchers: 10
- Forks: 41
- Open Issues: 14
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE
Awesome Lists containing this project
README
ember-test-selectors
==============================================================================Enabling better element selectors in [Ember.js](http://emberjs.com) tests
> [!NOTE]
> ember-test-selectors was written and is maintained by [Mainmatter](https://mainmatter.com) and contributors.
> We offer consulting, training, and team augmentation for Ember.js – check out our [website](https://mainmatter.com/ember-consulting/) to learn more!Features
------------------------------------------------------------------------------- Removes attributes starting with `data-test-` from HTML tags and
component/helper invocations in your templates for production builds- Removes properties starting with `data-test-` from your JS objects like
component classes for production buildsMore information on why that is useful are available on our
[blog](http://mainmatter.com/blog/2016/03/04/ember-test-selectors.html)!Compatibility
------------------------------------------------------------------------------- Ember 3.8 or above
- Ember CLI 3.8 or above
- Node.js 12 or aboveInstallation
------------------------------------------------------------------------------```bash
ember install ember-test-selectors
```Usage
------------------------------------------------------------------------------In your templates you are now able to use `data-test-*` attributes, which are
automatically removed from `production` builds:```hbs
{{post.title}}
{{post.body}}
Like```
Once you've done that you can use attribute selectors to look up and interact
with those elements:```js
assert.dom('[data-test-post-title]').hasText('Ember is great!');await click('[data-test-like-button]');
```### Usage with Components
You can use the same syntax also for component invocations:
```hbs
```
Inside the `Spinner` component template the `data-test-spinner` attribute will
be applied to the element that has `...attributes` on it, or on the component
wrapper `div` element if you don't use `tagName = ''`.### Usage in Ember addons
If you want to use ember-test-selectors in an addon make sure that it appears
in the `dependencies` section of the `package.json` file, not in the
`devDependencies`. This ensures that the selectors are also stripped correctly
even if the app that uses the addon does not use ember-test-selectors itself.Configuration
------------------------------------------------------------------------------You can override when the `data-test-*` attributes should be stripped from the
build by modifying your `ember-cli-build.js` file:```js
var app = new EmberApp({
'ember-test-selectors': {
strip: false
}
});
````strip` accepts a `Boolean` value and defaults to `!app.tests`, which means
that the attributes will be stripped for production builds, unless the build
was triggered by `ember test`. That means that if you use
`ember test --environment=production` the test selectors will still work, but
for `ember build -prod` they will be stripped out.License
------------------------------------------------------------------------------ember-test-selectors is developed by and ©
[Mainmatter GmbH](http://mainmatter.com) and contributors. It is released under the
[MIT License](https://github.com/mainmatter/ember-simple-auth/blob/master/LICENSE).ember-test-selectors is not an official part of [Ember.js](http://emberjs.com)
and is not maintained by the Ember.js Core Team.