| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869 |
- /**
- * Checks a given css property of an element exists and optionally if it has the expected value.
- *
- * ```
- * this.demoTest = function (browser) {
- * browser.expect.element('#main').to.have.css('display');
- * browser.expect.element('#main').to.have.css('display', 'Testing for display');
- * browser.expect.element('#main').to.not.have.css('display');
- * browser.expect.element('#main').to.have.css('display').before(100);
- * browser.expect.element('#main').to.have.css('display').which.equals('block');
- * browser.expect.element('#main').to.have.css('display').which.contains('some value');
- * browser.expect.element('#main').to.have.css('display').which.matches(/some\ value/);
- * };
- * ```
- *
- * @method css
- * @param {string} property The css property name
- * @param {string} [message] Optional log message to display in the output. If missing, one is displayed by default.*
- * @display .css(property)
- * @since v0.7
- * @api expect
- */
- var util = require('util');
- var events = require('events');
- var BaseAssertion = require('./_baseAssertion.js');
- function CssAssertion(property, msg) {
- this.cssProperty = property;
- this.flag('cssFlag', true);
- BaseAssertion.call(this);
- this.customMessage = typeof msg != 'undefined';
- this.message = msg || 'Expected element <%s> to ' + (this.negate ? 'not have' : 'have') + ' css property "' + property + '"';
- this.start();
- }
- util.inherits(CssAssertion, BaseAssertion);
- CssAssertion.prototype.executeCommand = function(callback) {
- this.protocol.elementIdCssProperty(this.elementResult.ELEMENT, this.cssProperty, callback);
- };
- CssAssertion.prototype['@haveFlag'] = function() {
- this.passed = this.negate ? (this.resultValue === '') : (this.resultValue !== '');
- this.expected = this.negate ? 'not present' : 'present';
- this.actual = this.resultValue === '' ? 'not present' : 'present';
- };
- CssAssertion.prototype.elementFound = function() {
- if (this.retries > 0 && this.negate) {
- return;
- }
- if (this.passed && this.waitForMs) {
- var message = 'property was present';
- if (this.hasCondition()) {
- message = 'condition was met';
- }
- this.elapsedTime = this.getElapsedTime();
- this.messageParts.push(' - ' + message + ' in ' + this.elapsedTime + 'ms');
- }
- };
- CssAssertion.prototype.elementNotFound = function() {
- this.passed = false;
- };
- module.exports = CssAssertion;
|