all files / DEV/lib/commands/ waitForEnabled.js

91.43% Statements 32/35
50% Branches 12/24
0% Functions 0/4
40% Lines 2/5
27 statements, 12 branches Ignored     
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88                                                                                                                                                                             
/**
 *
 * Wait for an element (selected by css selector) for the provided amount of
 * milliseconds to be (dis/en)abled. If multiple elements get queryied by given
 * selector, it returns true (or false if reverse flag is set) if at least one
 * element is (dis/en)abled.
 *
 * @param {String}   selector element to wait for
 * @param {Number=}  ms       time in ms (default: 500)
 * @param {Boolean=} reverse  if true it waits for the opposite (default: false)
 *
 * @uses action/selectorExecuteAsync, protocol/timeoutsAsyncScript
 * @type utility
 *
 */
 
'use strict';
 
Object.defineProperty(exports, '__esModule', {
    value: true
});
 
var _utilsErrorHandler = require('../utils/ErrorHandler');

var waitForEnabled = function waitForEnabled(selector, ms) {
    // istanbul ignore next

    var _this = this;
 
    var reverse = arguments.length <= 2 || arguments[2] === undefined ? false : arguments[2];
 
    /*!
     * ensure that ms is set properly
     */
    if (typeof ms !== 'number') {
        ms = this.options.waitforTimeout;
    }

    return this.waitUntil(function () {
        return _this.isEnabled(selector).then(function (isEnabled) {
            if (!Array.isArray(isEnabled)) {
                return isEnabled !== reverse;
            }

            var result = reverse;
            var _iteratorNormalCompletion = true;
            var _didIteratorError = false;
            var _iteratorError = undefined;
 
            try {
                for (var _iterator = isEnabled[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {
                    var val = _step.value;
 
                    if (!reverse) {
                        result = result || val;
                    } else {
                        result = result && val;
                    }
                }
            } catch (err) {
                _didIteratorError = true;
                _iteratorError = err;
            } finally {
                try {
                    if (!_iteratorNormalCompletion && _iterator['return']) {
                        _iterator['return']();
                    }
                } finally {
                    if (_didIteratorError) {
                        throw _iteratorError;
                    }
                }
            }
 
            return result !== reverse;
        });
    }, ms)['catch'](function (e) {
        if (e.message === 'Promise never resolved with an truthy value') {
            var isReversed = reverse ? '' : 'not';
            throw new _utilsErrorHandler.CommandError('element (' + selector + ') still ' + isReversed + ' enabled after ' + ms + 'ms');
        }
        throw e;
    });
};
 
exports['default'] = waitForEnabled;
module.exports = exports['default'];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy9jaHJpc3RpYW5icm9tYW5uL1NpdGVzL1dlYnByb2pla3RlL3dlYmRyaXZlcmpzL0RFVi9saWIvY29tbWFuZHMvd2FpdEZvckVuYWJsZWQuanMiXSwibmFtZXMiOltdLCJtYXBwaW5ncyI6Ijs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztpQ0FnQjZCLHVCQUF1Qjs7QUFFcEQsSUFBSSxjQUFjLEdBQUcsU0FBakIsY0FBYyxDQUFhLFFBQVEsRUFBRSxFQUFFLEVBQW1COzs7OztRQUFqQixPQUFPLHlEQUFHLEtBQUs7Ozs7O0FBSXhELFFBQUksT0FBTyxFQUFFLEtBQUssUUFBUSxFQUFFO0FBQ3hCLFVBQUUsR0FBRyxJQUFJLENBQUMsT0FBTyxDQUFDLGNBQWMsQ0FBQTtLQUNuQzs7QUFFRCxXQUFPLElBQUksQ0FBQyxTQUFTLENBQUMsWUFBTTtBQUN4QixlQUFPLE1BQUssU0FBUyxDQUFDLFFBQVEsQ0FBQyxDQUFDLElBQUksQ0FBQyxVQUFDLFNBQVMsRUFBSztBQUNoRCxnQkFBSSxDQUFDLEtBQUssQ0FBQyxPQUFPLENBQUMsU0FBUyxDQUFDLEVBQUU7QUFDM0IsdUJBQU8sU0FBUyxLQUFLLE9BQU8sQ0FBQTthQUMvQjs7QUFFRCxnQkFBSSxNQUFNLEdBQUcsT0FBTyxDQUFBOzs7Ozs7QUFDcEIscUNBQWdCLFNBQVMsOEhBQUU7d0JBQWxCLEdBQUc7O0FBQ1Isd0JBQUksQ0FBQyxPQUFPLEVBQUU7QUFDViw4QkFBTSxHQUFHLE1BQU0sSUFBSSxHQUFHLENBQUE7cUJBQ3pCLE1BQU07QUFDSCw4QkFBTSxHQUFHLE1BQU0sSUFBSSxHQUFHLENBQUE7cUJBQ3pCO2lCQUNKOzs7Ozs7Ozs7Ozs7Ozs7O0FBRUQsbUJBQU8sTUFBTSxLQUFLLE9BQU8sQ0FBQTtTQUM1QixDQUFDLENBQUE7S0FDTCxFQUFFLEVBQUUsQ0FBQyxTQUFNLENBQUMsVUFBQyxDQUFDLEVBQUs7QUFDaEIsWUFBSSxDQUFDLENBQUMsT0FBTyxLQUFLLDZDQUE2QyxFQUFFO0FBQzdELGdCQUFJLFVBQVUsR0FBRyxPQUFPLEdBQUcsRUFBRSxHQUFHLEtBQUssQ0FBQTtBQUNyQyxrQkFBTSxrREFBNkIsUUFBUSxnQkFBVyxVQUFVLHVCQUFrQixFQUFFLFFBQUssQ0FBQTtTQUM1RjtBQUNELGNBQU0sQ0FBQyxDQUFBO0tBQ1YsQ0FBQyxDQUFBO0NBQ0wsQ0FBQTs7cUJBRWMsY0FBYyIsImZpbGUiOiIvVXNlcnMvY2hyaXN0aWFuYnJvbWFubi9TaXRlcy9XZWJwcm9qZWt0ZS93ZWJkcml2ZXJqcy9ERVYvbGliL2NvbW1hbmRzL3dhaXRGb3JFbmFibGVkLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKlxuICogV2FpdCBmb3IgYW4gZWxlbWVudCAoc2VsZWN0ZWQgYnkgY3NzIHNlbGVjdG9yKSBmb3IgdGhlIHByb3ZpZGVkIGFtb3VudCBvZlxuICogbWlsbGlzZWNvbmRzIHRvIGJlIChkaXMvZW4pYWJsZWQuIElmIG11bHRpcGxlIGVsZW1lbnRzIGdldCBxdWVyeWllZCBieSBnaXZlblxuICogc2VsZWN0b3IsIGl0IHJldHVybnMgdHJ1ZSAob3IgZmFsc2UgaWYgcmV2ZXJzZSBmbGFnIGlzIHNldCkgaWYgYXQgbGVhc3Qgb25lXG4gKiBlbGVtZW50IGlzIChkaXMvZW4pYWJsZWQuXG4gKlxuICogQHBhcmFtIHtTdHJpbmd9ICAgc2VsZWN0b3IgZWxlbWVudCB0byB3YWl0IGZvclxuICogQHBhcmFtIHtOdW1iZXI9fSAgbXMgICAgICAgdGltZSBpbiBtcyAoZGVmYXVsdDogNTAwKVxuICogQHBhcmFtIHtCb29sZWFuPX0gcmV2ZXJzZSAgaWYgdHJ1ZSBpdCB3YWl0cyBmb3IgdGhlIG9wcG9zaXRlIChkZWZhdWx0OiBmYWxzZSlcbiAqXG4gKiBAdXNlcyBhY3Rpb24vc2VsZWN0b3JFeGVjdXRlQXN5bmMsIHByb3RvY29sL3RpbWVvdXRzQXN5bmNTY3JpcHRcbiAqIEB0eXBlIHV0aWxpdHlcbiAqXG4gKi9cblxuaW1wb3J0IHsgQ29tbWFuZEVycm9yIH0gZnJvbSAnLi4vdXRpbHMvRXJyb3JIYW5kbGVyJ1xuXG5sZXQgd2FpdEZvckVuYWJsZWQgPSBmdW5jdGlvbiAoc2VsZWN0b3IsIG1zLCByZXZlcnNlID0gZmFsc2UpIHtcbiAgICAvKiFcbiAgICAgKiBlbnN1cmUgdGhhdCBtcyBpcyBzZXQgcHJvcGVybHlcbiAgICAgKi9cbiAgICBpZiAodHlwZW9mIG1zICE9PSAnbnVtYmVyJykge1xuICAgICAgICBtcyA9IHRoaXMub3B0aW9ucy53YWl0Zm9yVGltZW91dFxuICAgIH1cblxuICAgIHJldHVybiB0aGlzLndhaXRVbnRpbCgoKSA9PiB7XG4gICAgICAgIHJldHVybiB0aGlzLmlzRW5hYmxlZChzZWxlY3RvcikudGhlbigoaXNFbmFibGVkKSA9PiB7XG4gICAgICAgICAgICBpZiAoIUFycmF5LmlzQXJyYXkoaXNFbmFibGVkKSkge1xuICAgICAgICAgICAgICAgIHJldHVybiBpc0VuYWJsZWQgIT09IHJldmVyc2VcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgdmFyIHJlc3VsdCA9IHJldmVyc2VcbiAgICAgICAgICAgIGZvciAobGV0IHZhbCBvZiBpc0VuYWJsZWQpIHtcbiAgICAgICAgICAgICAgICBpZiAoIXJldmVyc2UpIHtcbiAgICAgICAgICAgICAgICAgICAgcmVzdWx0ID0gcmVzdWx0IHx8IHZhbFxuICAgICAgICAgICAgICAgIH0gZWxzZSB7XG4gICAgICAgICAgICAgICAgICAgIHJlc3VsdCA9IHJlc3VsdCAmJiB2YWxcbiAgICAgICAgICAgICAgICB9XG4gICAgICAgICAgICB9XG5cbiAgICAgICAgICAgIHJldHVybiByZXN1bHQgIT09IHJldmVyc2VcbiAgICAgICAgfSlcbiAgICB9LCBtcykuY2F0Y2goKGUpID0+IHtcbiAgICAgICAgaWYgKGUubWVzc2FnZSA9PT0gJ1Byb21pc2UgbmV2ZXIgcmVzb2x2ZWQgd2l0aCBhbiB0cnV0aHkgdmFsdWUnKSB7XG4gICAgICAgICAgICBsZXQgaXNSZXZlcnNlZCA9IHJldmVyc2UgPyAnJyA6ICdub3QnXG4gICAgICAgICAgICB0aHJvdyBuZXcgQ29tbWFuZEVycm9yKGBlbGVtZW50ICgke3NlbGVjdG9yfSkgc3RpbGwgJHtpc1JldmVyc2VkfSBlbmFibGVkIGFmdGVyICR7bXN9bXNgKVxuICAgICAgICB9XG4gICAgICAgIHRocm93IGVcbiAgICB9KVxufVxuXG5leHBvcnQgZGVmYXVsdCB3YWl0Rm9yRW5hYmxlZFxuIl19