nightwatch
Version:
Easy to use Node.js based end-to-end testing solution for web applications using the W3C WebDriver API.
62 lines (51 loc) • 1.7 kB
JavaScript
/**
* Checks if the given element does not have the specified CSS class.
*
* ```
* this.demoTest = function (browser) {
* browser.assert.cssClassNotPresent('#main', 'container');
* };
* ```
*
* @method assert.cssClassNotPresent
* @param {string|object} definition The selector (CSS / Xpath) used to locate the element.
* @param {string} className The CSS class to look for.
* @param {string} [msg] Optional log message to display in the output. If missing, one is displayed by default.
* @api assertions
* @deprecated
*/
const classListRegexp = /\s/;
const classNameRegexp = /\w/;
const {setElementSelectorProps} = require('../../utils');
exports.assertion = function(definition, className, msg) {
this.options = {
elementSelector: true
};
// eslint-disable-next-line no-console
console.warn('DEPRECATED: the assertion .cssClassNotPresent() has been deprecated and will be ' +
'removed from future versions. Use assert.not.hasClass().');
this.formatMessage = function() {
let message = msg || 'Testing if element %s doesn\'t have css class %s';
return {
message,
args: [this.elementSelector, `'${className}'`]
};
};
this.expected = function() {
return `has not ${className}`;
};
this.evaluate = function() {
return !this.classList.includes(className);
};
this.value = function(result) {
this.classList = result.value
.split(classListRegexp)
.filter(item => classNameRegexp.test(item));
return result.value;
};
this.command = function(callback) {
this.api.getAttribute(setElementSelectorProps(definition, {
suppressNotFoundErrors: true
}), 'class', callback);
};
};