all files / DEV/lib/commands/ waitForSelected.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                                                                                                                                                                           
/**
 *
 * Wait for an option or radio/checkbox element (selected by css selector) for the provided amount of
 * milliseconds to be (un)selected or (un)checked. If multiple elements get queryied by given
 * selector, it returns true (or false if reverse flag is set) if at least one element is (un)selected.
 *
 * @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 waitForSelected = function waitForSelected(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.isSelected(selector).then(function (isSelected) {
            if (!Array.isArray(isSelected)) {
                return isSelected !== reverse;
            }

            var result = reverse;
            var _iteratorNormalCompletion = true;
            var _didIteratorError = false;
            var _iteratorError = undefined;
 
            try {
                for (var _iterator = isSelected[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 + ' selected after ' + ms + 'ms');
        }
        throw e;
    });
};
 
exports['default'] = waitForSelected;
module.exports = exports['default'];
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi9Vc2Vycy9jaHJpc3RpYW5icm9tYW5uL1NpdGVzL1dlYnByb2pla3RlL3dlYmRyaXZlcmpzL0RFVi9saWIvY29tbWFuZHMvd2FpdEZvclNlbGVjdGVkLmpzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiI7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztpQ0FlNkIsdUJBQXVCOztBQUVwRCxJQUFJLGVBQWUsR0FBRyxTQUFsQixlQUFlLENBQWEsUUFBUSxFQUFFLEVBQUUsRUFBbUI7Ozs7O1FBQWpCLE9BQU8seURBQUcsS0FBSzs7Ozs7QUFJekQsUUFBSSxPQUFPLEVBQUUsS0FBSyxRQUFRLEVBQUU7QUFDeEIsVUFBRSxHQUFHLElBQUksQ0FBQyxPQUFPLENBQUMsY0FBYyxDQUFBO0tBQ25DOztBQUVELFdBQU8sSUFBSSxDQUFDLFNBQVMsQ0FBQyxZQUFNO0FBQ3hCLGVBQU8sTUFBSyxVQUFVLENBQUMsUUFBUSxDQUFDLENBQUMsSUFBSSxDQUFDLFVBQUMsVUFBVSxFQUFLO0FBQ2xELGdCQUFJLENBQUMsS0FBSyxDQUFDLE9BQU8sQ0FBQyxVQUFVLENBQUMsRUFBRTtBQUM1Qix1QkFBTyxVQUFVLEtBQUssT0FBTyxDQUFBO2FBQ2hDOztBQUVELGdCQUFJLE1BQU0sR0FBRyxPQUFPLENBQUE7Ozs7OztBQUNwQixxQ0FBZ0IsVUFBVSw4SEFBRTt3QkFBbkIsR0FBRzs7QUFDUix3QkFBSSxDQUFDLE9BQU8sRUFBRTtBQUNWLDhCQUFNLEdBQUcsTUFBTSxJQUFJLEdBQUcsQ0FBQTtxQkFDekIsTUFBTTtBQUNILDhCQUFNLEdBQUcsTUFBTSxJQUFJLEdBQUcsQ0FBQTtxQkFDekI7aUJBQ0o7Ozs7Ozs7Ozs7Ozs7Ozs7QUFFRCxtQkFBTyxNQUFNLEtBQUssT0FBTyxDQUFBO1NBQzVCLENBQUMsQ0FBQTtLQUNMLEVBQUUsRUFBRSxDQUFDLFNBQU0sQ0FBQyxVQUFDLENBQUMsRUFBSztBQUNoQixZQUFJLENBQUMsQ0FBQyxPQUFPLEtBQUssNkNBQTZDLEVBQUU7QUFDN0QsZ0JBQUksVUFBVSxHQUFHLE9BQU8sR0FBRyxFQUFFLEdBQUcsS0FBSyxDQUFBO0FBQ3JDLGtCQUFNLGtEQUE2QixRQUFRLGdCQUFXLFVBQVUsd0JBQW1CLEVBQUUsUUFBSyxDQUFBO1NBQzdGO0FBQ0QsY0FBTSxDQUFDLENBQUE7S0FDVixDQUFDLENBQUE7Q0FDTCxDQUFBOztxQkFFYyxlQUFlIiwiZmlsZSI6Ii9Vc2Vycy9jaHJpc3RpYW5icm9tYW5uL1NpdGVzL1dlYnByb2pla3RlL3dlYmRyaXZlcmpzL0RFVi9saWIvY29tbWFuZHMvd2FpdEZvclNlbGVjdGVkLmpzIiwic291cmNlc0NvbnRlbnQiOlsiLyoqXG4gKlxuICogV2FpdCBmb3IgYW4gb3B0aW9uIG9yIHJhZGlvL2NoZWNrYm94IGVsZW1lbnQgKHNlbGVjdGVkIGJ5IGNzcyBzZWxlY3RvcikgZm9yIHRoZSBwcm92aWRlZCBhbW91bnQgb2ZcbiAqIG1pbGxpc2Vjb25kcyB0byBiZSAodW4pc2VsZWN0ZWQgb3IgKHVuKWNoZWNrZWQuIElmIG11bHRpcGxlIGVsZW1lbnRzIGdldCBxdWVyeWllZCBieSBnaXZlblxuICogc2VsZWN0b3IsIGl0IHJldHVybnMgdHJ1ZSAob3IgZmFsc2UgaWYgcmV2ZXJzZSBmbGFnIGlzIHNldCkgaWYgYXQgbGVhc3Qgb25lIGVsZW1lbnQgaXMgKHVuKXNlbGVjdGVkLlxuICpcbiAqIEBwYXJhbSB7U3RyaW5nfSAgIHNlbGVjdG9yIGVsZW1lbnQgdG8gd2FpdCBmb3JcbiAqIEBwYXJhbSB7TnVtYmVyPX0gIG1zICAgICAgIHRpbWUgaW4gbXMgKGRlZmF1bHQ6IDUwMClcbiAqIEBwYXJhbSB7Qm9vbGVhbj19IHJldmVyc2UgIGlmIHRydWUgaXQgd2FpdHMgZm9yIHRoZSBvcHBvc2l0ZSAoZGVmYXVsdDogZmFsc2UpXG4gKlxuICogQHVzZXMgYWN0aW9uL3NlbGVjdG9yRXhlY3V0ZUFzeW5jLCBwcm90b2NvbC90aW1lb3V0c0FzeW5jU2NyaXB0XG4gKiBAdHlwZSB1dGlsaXR5XG4gKlxuICovXG5cbmltcG9ydCB7IENvbW1hbmRFcnJvciB9IGZyb20gJy4uL3V0aWxzL0Vycm9ySGFuZGxlcidcblxubGV0IHdhaXRGb3JTZWxlY3RlZCA9IGZ1bmN0aW9uIChzZWxlY3RvciwgbXMsIHJldmVyc2UgPSBmYWxzZSkge1xuICAgIC8qIVxuICAgICAqIGVuc3VyZSB0aGF0IG1zIGlzIHNldCBwcm9wZXJseVxuICAgICAqL1xuICAgIGlmICh0eXBlb2YgbXMgIT09ICdudW1iZXInKSB7XG4gICAgICAgIG1zID0gdGhpcy5vcHRpb25zLndhaXRmb3JUaW1lb3V0XG4gICAgfVxuXG4gICAgcmV0dXJuIHRoaXMud2FpdFVudGlsKCgpID0+IHtcbiAgICAgICAgcmV0dXJuIHRoaXMuaXNTZWxlY3RlZChzZWxlY3RvcikudGhlbigoaXNTZWxlY3RlZCkgPT4ge1xuICAgICAgICAgICAgaWYgKCFBcnJheS5pc0FycmF5KGlzU2VsZWN0ZWQpKSB7XG4gICAgICAgICAgICAgICAgcmV0dXJuIGlzU2VsZWN0ZWQgIT09IHJldmVyc2VcbiAgICAgICAgICAgIH1cblxuICAgICAgICAgICAgbGV0IHJlc3VsdCA9IHJldmVyc2VcbiAgICAgICAgICAgIGZvciAobGV0IHZhbCBvZiBpc1NlbGVjdGVkKSB7XG4gICAgICAgICAgICAgICAgaWYgKCFyZXZlcnNlKSB7XG4gICAgICAgICAgICAgICAgICAgIHJlc3VsdCA9IHJlc3VsdCB8fCB2YWxcbiAgICAgICAgICAgICAgICB9IGVsc2Uge1xuICAgICAgICAgICAgICAgICAgICByZXN1bHQgPSByZXN1bHQgJiYgdmFsXG4gICAgICAgICAgICAgICAgfVxuICAgICAgICAgICAgfVxuXG4gICAgICAgICAgICByZXR1cm4gcmVzdWx0ICE9PSByZXZlcnNlXG4gICAgICAgIH0pXG4gICAgfSwgbXMpLmNhdGNoKChlKSA9PiB7XG4gICAgICAgIGlmIChlLm1lc3NhZ2UgPT09ICdQcm9taXNlIG5ldmVyIHJlc29sdmVkIHdpdGggYW4gdHJ1dGh5IHZhbHVlJykge1xuICAgICAgICAgICAgbGV0IGlzUmV2ZXJzZWQgPSByZXZlcnNlID8gJycgOiAnbm90J1xuICAgICAgICAgICAgdGhyb3cgbmV3IENvbW1hbmRFcnJvcihgZWxlbWVudCAoJHtzZWxlY3Rvcn0pIHN0aWxsICR7aXNSZXZlcnNlZH0gc2VsZWN0ZWQgYWZ0ZXIgJHttc31tc2ApXG4gICAgICAgIH1cbiAgICAgICAgdGhyb3cgZVxuICAgIH0pXG59XG5cbmV4cG9ydCBkZWZhdWx0IHdhaXRGb3JTZWxlY3RlZFxuIl19