oxygen-cli 1.37.2 → 1.37.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/CHANGELOG.md CHANGED
@@ -1,5 +1,10 @@
1
1
  # CHANGELOG
2
2
 
3
+ ## v1.37.3 (2024-12-19)
4
+
5
+ #### :beetle: Bug Fix
6
+ * Properly pass BrowserStack capabilities.
7
+
3
8
  ## v1.37.2 (2024-12-04)
4
9
 
5
10
  #### :beetle: Bug Fix
@@ -322,6 +322,10 @@ class Oxygen extends _OxygenEvents.default {
322
322
  }
323
323
 
324
324
  addAttribute(name, value) {
325
+ if (!name || !value) {
326
+ throw new _OxygenError.default(_helper.default.errorCode.SCRIPT_ERROR, "'name' and 'value' arguments are required for ox.addAttribute");
327
+ }
328
+
325
329
  if (this.resultStore && this.resultStore.attributes) {
326
330
  this.resultStore.attributes[name] = value;
327
331
  }
@@ -1065,4 +1069,4 @@ class Oxygen extends _OxygenEvents.default {
1065
1069
  }
1066
1070
 
1067
1071
  exports.default = Oxygen;
1068
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/core/OxygenCore.js"],"names":["Object","defineProperty","global","get","orig","Error","prepareStackTrace","_","stack","err","captureStackTrace","DEFAULT_TIMEOUT","DEFAULT_OPTS","backtrace","compiler","failAmbiguousDefinitions","failFast","ignoreUndefinedDefinitions","name","profile","require","order","snippetSyntax","undefined","snippets","source","strict","tagExpression","tagsInTitle","timeout","MODULE_NAME_MATCH_REGEX","SERVICE_NAME_MATCH_REGEX","DO_NOT_WRAP_METHODS","DEFAULT_CTX","params","vars","env","caps","attributes","DEFAULT_RESULT_STORE","steps","logs","attachments","har","Oxygen","OxygenEvents","constructor","isInitialized","resultStore","ctx","modules","services","repo","capabilities","opts","oxBaseDir","path","join","__dirname","logger","_wrapLogger","_waitStepResultList","init","options","results","assign","cwd","process","keys","length","makeOxGlobal","_loadServices","_loadModules","globalScope","makeContextAndModulesGlobal","disposeModules","status","_disposeModules","e","console","error","dispose","_disposeServices","adjustScriptLine","isInDebugMode","oxutil","result","context","ox","repository","transStep","includes","transName","transaction","duration","step","endTime","STATUS","WARNING","getModulesCapabilities","modCaps","moduleName","module","_getCapabilities","resetResults","onBeforeCase","_iterationStart","onAfterCase","_iterationEnd","addAttribute","bind","addAttachment","value","filePath","fs","existsSync","push","coreUtils","newFileAttachment","loadPageObjectFile","poPath","po","_logger","loggerWrap","info","args","_log","debug","warn","userInfo","ISSUERS","USER","userDebug","userError","userWarn","level","src","DEFAULT_LOGGER_ISSUER","apply","message","stringify","time","getTimeStamp","toUpperCase","msg","shift","emitLog","oxServicesDirPath","resolve","serviceFiles","glob","sync","i","serviceFileName","serviceFilePath","match","serviceName","Array","isArray","service","_loadService","EOL","stacktrace","servicePath","ServiceClass","default","serviceLogger","_loadInternalModules","_loadExternalModules","modulesFolderPath","modules_ext","oxModulesDirPath","moduleFiles","forEach","moduleFileName","startTime","Date","moduleLogger","mod","loadModuleFromFile","_callServicesOnModuleLoaded","_wrapModule","excludeUndefinedMods","Modules","ModuleClass","getOxModulesDir","loadModuleFromClass","wrapper","_this","moduleMethods","some","x","_getAllPropertyNames","methodName","method","Function","OxygenSubModule","indexOf","prototype","slice","call","arguments","getMethodSignature","errorHelper","getOxygenError","_commandWrapper","OxError","cmdName","cmdArgs","retval","cmdFn","publicMethod","startsWith","delay","deasync","sleep","errorCode","MODULE_NOT_INITIALIZED_ERROR","decryptedArgs","_getDecryptedArgsForApply","_populateParametersValue","cmdLocation","_getCommandLocation","emitBeforeCommand","_wrapAsync","_callServicesOnModuleWillDispose","retvalPromise","then","promiseDone","loopWhile","_callServicesOnModuleInitialized","stepResult","done","waitId","_getStepResult","index","splice","emitAfterCommand","isFatal","continueOnError","location","failure","fn","self","Fiber","current","finalVal","Promise","val","catch","future","Future","return","throw","wait","__stack","caller","__filename","getFileName","getLineNumber","getColumnNumber","StepResult","displayName","getStepDisplayName","_lastTransactionName","extra","http","type","ASSERT_PASSED","PASSED","FAILED","action","_isAction","_getStats","stats","SELENIUM_SESSION_TIMEOUT","APPIUM_SESSION_TIMEOUT","getFailureFromError","_takeScreenshotSilent","disableScreenshot","screenshot","key","disposeResult","onModuleLoaded","onModuleInitialized","onModuleWillDispose","_newArgs","arg","_replaceParameterInArgument","getDecryptResult","paramName","hasOwnProperty","paramValue","replace","RegExp","envName","envValue","obj","props","getOwnPropertyNames","prop","getPrototypeOf","_checkStepResult","reject","_waitStepResult","_decryptParameterForApplyInArgument"],"mappings":"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","sourcesContent":["/* eslint-disable no-prototype-builtins */\r\nimport glob from 'glob';\r\nimport path from 'path';\r\nimport fs from 'fs';\r\nimport deasync from 'deasync';\r\nimport Future from 'fibers/future';\r\nimport Fiber from 'fibers';\r\nimport { EOL } from 'os';\r\nimport StepResult from '../model/step-result';\r\nimport OxygenEvents from './OxygenEvents';\r\nimport oxutil from '../lib/util';\r\nimport * as coreUtils from './utils';\r\nimport OxError from '../errors/OxygenError';\r\nimport errorHelper from '../errors/helper';\r\nimport STATUS from '../model/status.js';\r\nimport * as Modules from '../ox_modules/index';\r\n\r\n// setup logger\r\nimport logger, { DEFAULT_LOGGER_ISSUER, ISSUERS } from '../lib/logger';\r\nimport { OxygenSubModule } from './OxygenSubModule';\r\n\r\n/*global __stack*/\r\nObject.defineProperty(global, '__stack', {\r\n    get: function () {\r\n        var orig = Error.prepareStackTrace;\r\n        Error.prepareStackTrace = function (_, stack) { return stack; };\r\n        var err = new Error();\r\n        Error.captureStackTrace(err);\r\n        var stack = err.stack;\r\n        Error.prepareStackTrace = orig;\r\n        return stack;\r\n    }\r\n});\r\n\r\nconst DEFAULT_TIMEOUT = 30000;\r\nconst DEFAULT_OPTS = {\r\n    backtrace: false, // <boolean> show full backtrace for errors\r\n    compiler: [], // <string[]> (\"extension:module\") require files with the given EXTENSION after requiring MODULE (repeatable)\r\n    failAmbiguousDefinitions: false, // <boolean> treat ambiguous definitions as errors\r\n    failFast: false, // <boolean> abort the run on first failure\r\n    ignoreUndefinedDefinitions: false, // <boolean> treat undefined definitions as warnings\r\n    name: [], // <REGEXP[]> only execute the scenarios with name matching the expression (repeatable)\r\n    profile: [], // <string> (name) specify the profile to use\r\n    require: [], // <string> (file/dir/glob) require files before executing features\r\n    order: 'defined', // <string> switch between deterministic  and random feature execution. Either \"defined\", \"random\" or \"random:42\" whereas 42 is the seed for randomization\r\n    snippetSyntax: undefined, // <string> specify a custom snippet syntax\r\n    snippets: true, // <boolean> hide step definition snippets for pending steps\r\n    source: true, // <boolean> hide source uris\r\n    strict: false, // <boolean> fail if there are any undefined or pending steps\r\n    tagExpression: '', // <string> (expression) only execute the features or scenarios with tags matching the expression\r\n    tagsInTitle: false, // <boolean> add cucumber tags to feature or scenario name\r\n    timeout: DEFAULT_TIMEOUT // <number> timeout for step definitions in milliseconds\r\n};\r\nconst MODULE_NAME_MATCH_REGEX = /^module-(.+?)\\.js$/;\r\nconst SERVICE_NAME_MATCH_REGEX = /^service-(.+?)\\.js$/;\r\nconst DO_NOT_WRAP_METHODS = ['driver', 'getDriver'];\r\n\r\nconst DEFAULT_CTX = {\r\n    params: {},\r\n    vars: {},\r\n    env: {},\r\n    caps: {},\r\n    attributes: {},\r\n};\r\nconst DEFAULT_RESULT_STORE = {\r\n    steps: [],\r\n    logs: [],\r\n    attachments: [],\r\n    har: null,\r\n    attributes: {}\r\n};\r\n\r\nexport default class Oxygen extends OxygenEvents {\r\n    constructor () {\r\n        super();\r\n        this.isInitialized = false;\r\n        this.resultStore = { ...DEFAULT_RESULT_STORE };\r\n        this.ctx = { ...DEFAULT_CTX };\r\n        this.modules = {};\r\n        this.services = {};\r\n        this.repo = {};\r\n        this.capabilities = null;\r\n        this.opts = null;\r\n        this.oxBaseDir = path.join(__dirname, '../');\r\n        this.logger = this._wrapLogger(logger('Oxygen'));\r\n        this._waitStepResultList = [];\r\n    }\r\n\r\n    async init(options, caps, ctx = {}, results = {}) {\r\n        this.opts = Object.assign(DEFAULT_OPTS, options);\r\n        this.cwd = this.opts.cwd || process.cwd();\r\n        this.ctx = Object.assign(DEFAULT_CTX, ctx || {});\r\n        this.ctx.caps = { ...ctx.caps || {}, ...caps, };\r\n        this.resultStore = Object.assign(DEFAULT_RESULT_STORE, results || {});\r\n        this.capabilities = this.ctx.caps = caps;\r\n\r\n        if (ctx.attributes && (!results.attributes || !Object.keys(results.attributes).length)) {\r\n            this.resultStore.attributes = { ...ctx.attributes };\r\n        }\r\n\r\n        // define 'ox' object in global JS scope\r\n        // we will use this object to access Oxygen modules and test context from modules used in the test (if any)        \r\n        this.makeOxGlobal();\r\n        // load services\r\n        this._loadServices();\r\n        // load modules\r\n        this._loadModules();\r\n        // if options.makeModulesGlobal is true or undefined than define 'ctx' content and each module in global scope\r\n        if (typeof options.globalScope === 'undefined' || options.globalScope === true) {\r\n            this.makeContextAndModulesGlobal();\r\n        }\r\n        this.isInitialized = true;\r\n    }\r\n\r\n    async disposeModules(status = null) {\r\n        try {\r\n            await this._disposeModules(status);\r\n        }\r\n        catch (e) {\r\n            console.error('Failed to dispose modules: ', e);\r\n            throw e;\r\n        }\r\n    }\r\n\r\n    async dispose(status = null) {\r\n        try {\r\n            await this._disposeModules(status);\r\n            await this._disposeServices();\r\n            this.isInitialized = false;\r\n        }\r\n        catch (e) {\r\n            this.isInitialized = false;\r\n            console.error('Failed to dispose: ', e);\r\n            throw e;\r\n        }\r\n    }\r\n\r\n    get adjustScriptLine() {\r\n        const isInDebugMode = oxutil.isInDebugMode();\r\n        // add extra line if we are running in debugger mode (V8 debugger adds an extra line at the beginning of the file)\r\n        const result = isInDebugMode ? -1 : 0;\r\n        return result;\r\n    }\r\n\r\n    get context() {\r\n        return this.ctx;\r\n    }\r\n\r\n    set context(ctx) {\r\n        this.ctx = ctx;\r\n        if (global.ox) {\r\n            global.ox.ctx = ctx;\r\n            if (typeof this.opts.globalScope === 'undefined' || this.opts.globalScope === true) {\r\n                // update \"params\" and \"env\" in \"ox\" global variable\r\n                global.params = ctx.params || {};\r\n                global.env = ctx.env || {};\r\n                global.attributes = ctx.attributes || {};\r\n            }\r\n        }\r\n    }\r\n\r\n    get repository() {\r\n        return this.repo;\r\n    }\r\n\r\n    set repository(repo) {\r\n        this.repo = repo;\r\n        if (global.ox) {\r\n            global.ox.repo = repo;\r\n        }\r\n    }\r\n\r\n    get results() {\r\n        // calculate time for the transaction itself - summary of durations for all the steps in this transaction\r\n        // also adjust transaction end time to much end time for the last executed step within this transaction.\r\n        for (const transStep of this.resultStore.steps) {\r\n            if (transStep.name.includes('.transaction')) {\r\n                const transName = transStep.transaction;\r\n                transStep.duration = 0;\r\n                for (const step of this.resultStore.steps) {\r\n                    // step belongs to the current transaction & is not the transaction step\r\n                    if (step.transaction === transName && step !== transStep) {\r\n                        transStep.duration += step.duration;\r\n                        if (step.endTime > transStep.endTime) {\r\n                            transStep.endTime = step.endTime;\r\n                        }\r\n\r\n                        // update transaction status to warning if at least one of steps has warning status\r\n                        if (step.status === STATUS.WARNING) {\r\n                            transStep.status = STATUS.WARNING;\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        return this.resultStore;\r\n    }\r\n\r\n    getModulesCapabilities() {\r\n        if (!this.modules) {\r\n            return null;\r\n        }\r\n        const modCaps = {};\r\n        for (let moduleName in this.modules) {\r\n            const module = this.modules[moduleName];\r\n            if (module.name && module._getCapabilities && typeof module._getCapabilities === 'function') {\r\n                const caps = module._getCapabilities();\r\n                // store only non-empty caps per module that has this.caps property\r\n                if (caps && typeof caps === 'object' && Object.keys(caps).length > 0) {\r\n                    modCaps[module.name] = caps;\r\n                }\r\n            }\r\n        }\r\n        return modCaps;\r\n    }\r\n\r\n    resetResults() {\r\n        this.resultStore.steps = [];\r\n        this.resultStore.logs = [];\r\n        this.resultStore.attachments = [];\r\n        this.har = null;\r\n    }\r\n\r\n    async onBeforeCase(context) {\r\n        for (let moduleName in this.modules) {\r\n            const module = this.modules[moduleName];\r\n            if (!module) {\r\n                continue;\r\n            }\r\n            try {\r\n                module.onBeforeCase && await module.onBeforeCase(context);\r\n                module._iterationStart && await module._iterationStart();\r\n            }\r\n            catch (e) {\r\n                this.logger.error(`Failed to call \"onBeforeCase\" method of ${moduleName} module.`, e);\r\n            }\r\n        }\r\n    }\r\n\r\n    async onAfterCase(error = null) {\r\n        for (let moduleName in this.modules) {\r\n            const module = this.modules[moduleName];\r\n            if (!module) {\r\n                continue;\r\n            }\r\n            try {\r\n                // await for avoid stuck on *.dispose call\r\n                module.onAfterCase && await module.onAfterCase(error);\r\n                module._iterationEnd && await module._iterationEnd(error);\r\n            }\r\n            catch (e) {\r\n                this.logger.error(`Failed to call \"onAfterCase\" method of ${moduleName} module.`, e);\r\n            }\r\n        }\r\n    }\r\n\r\n    makeOxGlobal() {\r\n        if (!global.ox) {\r\n            global.ox = {\r\n                modules: this.modules,\r\n                ctx: this.ctx,\r\n                options: this.opts,\r\n                caps: this.capabilities,\r\n                resultStore: this.resultStore,\r\n                addAttribute: this.addAttribute.bind(this),\r\n                addAttachment: this.addAttachment.bind(this),\r\n            };\r\n\r\n            global.vars = this.ctx.vars;\r\n        }\r\n    }\r\n\r\n    makeContextAndModulesGlobal() {\r\n        // make sure 'ox' is already global\r\n        if (global.ox) {\r\n            // expose modules as global variables\r\n            for (let moduleName in this.modules) {\r\n                if (!global[moduleName]) {\r\n                    global[moduleName] = this.modules[moduleName];\r\n                }\r\n            }\r\n            // expose \"ctx\", \"params\" and \"env\" as global variables\r\n            global.params = global.ox.ctx.params;\r\n            global.env = global.ox.ctx.env;\r\n            global.ctx = global.ox.ctx;\r\n            global.attributes = global.ox.ctx.attributes || {};\r\n        }\r\n    }\r\n\r\n    addAttribute(name, value) {\r\n        if (this.resultStore && this.resultStore.attributes) {\r\n            this.resultStore.attributes[name] = value;\r\n        }\r\n    }\r\n\r\n    addAttachment(filePath) {\r\n        if (!this.resultStore) {\r\n            return;\r\n        }\r\n\r\n        if (!fs.existsSync(filePath)) {\r\n            console.err(`File ${filePath} doesn't exist`);\r\n            return;\r\n        }\r\n\r\n        if (!this.resultStore.attachments) {\r\n            this.resultStore.attachments = [];\r\n        }\r\n        this.resultStore.attachments.push(\r\n            coreUtils.newFileAttachment(filePath)\r\n        );\r\n    }\r\n\r\n    loadPageObjectFile(poPath) {\r\n        if (!poPath) {\r\n            return;\r\n        }\r\n        try {\r\n            const po = require(poPath);\r\n            // set page object repository as the main one\r\n            this.repository = po;\r\n            if (typeof this.opts.globalScope === 'undefined' || this.opts.globalScope === true) {\r\n                global.po = po;\r\n            }\r\n        }\r\n        catch (e) {\r\n            // ignore error\r\n            if (typeof this.opts.globalScope === 'undefined' || this.opts.globalScope === true) {\r\n                global.po = {};\r\n            }\r\n        }\r\n    }\r\n\r\n    /*\r\n     * Private Methods\r\n     */\r\n    _wrapLogger(_logger) {\r\n        const loggerWrap = {\r\n            info: (...args) => this._log(_logger, 'info', args),\r\n            debug: (...args) => this._log(_logger, 'debug', args),\r\n            error: (...args) => this._log(_logger, 'error', args),\r\n            warn: (...args) => this._log(_logger, 'warn', args),\r\n            userInfo: (...args) => this._log(_logger, 'info', args, ISSUERS.USER),\r\n            userDebug: (...args) => this._log(_logger, 'debug', args, ISSUERS.USER),\r\n            userError: (...args) => this._log(_logger, 'error', args, ISSUERS.USER),\r\n            userWarn: (...args) => this._log(_logger, 'warn', args, ISSUERS.USER),\r\n        };\r\n        return loggerWrap;\r\n    }\r\n\r\n    _log(_logger, level, args, src = DEFAULT_LOGGER_ISSUER) {\r\n        if (!_logger[level]) {\r\n            return;\r\n        }\r\n        _logger[level].apply(_logger, args);\r\n\r\n        const message = oxutil.stringify(args, 2);\r\n        const time = oxutil.getTimeStamp();\r\n        // add the log entry to the result store\r\n        if (this.resultStore && this.resultStore.logs) {\r\n            this.resultStore.logs.push({\r\n                time: time,\r\n                level: level.toUpperCase(),\r\n                msg: message,\r\n                src: src\r\n            });\r\n        }\r\n        // remove first argument, if it's a message\r\n        args = message ? args.shift() : args;\r\n        this.emitLog(time, level, message, args, src);\r\n    }\r\n\r\n    _loadServices() {\r\n        const oxServicesDirPath = path.resolve(this.oxBaseDir, './ox_services');\r\n        const serviceFiles = glob.sync('service-*.js', { cwd: oxServicesDirPath });\r\n        // initialize all services\r\n        this.logger.debug('Loading services...');\r\n\r\n        for (var i = 0; i < serviceFiles.length; i++) {\r\n            const serviceFileName = serviceFiles[i];\r\n            const serviceFilePath = path.join(oxServicesDirPath, serviceFileName);\r\n            const result = serviceFileName.match(SERVICE_NAME_MATCH_REGEX);\r\n            const serviceName = result[1];\r\n\r\n            // this.opts.services = undefined in single file mode\r\n            if (Array.isArray(this.opts.services) && !this.opts.services.includes(serviceName)) {\r\n                continue;\r\n            }\r\n\r\n            try {\r\n                this.logger.debug('Loading service: ' + serviceName);\r\n                const service = this._loadService(serviceName, serviceFilePath);\r\n                service.init();\r\n                this.services[serviceName] = service;\r\n            } catch (e) {\r\n                this.logger.error('Error initializing service \"' + serviceName + '\": ' + e.message + EOL + (e.stacktrace ? e.stacktrace : ''));\r\n            }\r\n        }\r\n    }\r\n    _loadService(serviceName, servicePath) {\r\n        let ServiceClass = require(servicePath);\r\n        // ES6 class will be under 'default' property\r\n        if (ServiceClass.default) {\r\n            ServiceClass = ServiceClass.default;\r\n        }\r\n        const serviceLogger = this._wrapLogger(logger(`Service:${serviceName}`));\r\n        return new ServiceClass(this.opts, this.ctx, this.resultStore, serviceLogger);\r\n    }\r\n\r\n    _loadModules() {\r\n        this.logger.debug('Loading internal modules...');\r\n        this._loadInternalModules();\r\n        this.logger.debug('Loading external modules...');\r\n        this._loadExternalModules();\r\n    }\r\n\r\n    _loadExternalModules() {\r\n        let modulesFolderPath = './modules';\r\n        if (this.opts.modules_ext && typeof this.opts.modules_ext === 'string') {\r\n            modulesFolderPath = this.opts.modules_ext;\r\n        }\r\n        //const oxModulesDirPath = path.resolve(this.oxBaseDir, './ox_modules');\r\n        const oxModulesDirPath = path.resolve(this.cwd, modulesFolderPath);\r\n        if (!fs.existsSync(oxModulesDirPath)) {\r\n            return false;\r\n        }\r\n        let moduleFiles = [];\r\n        // if particular module names are defined in the config, then load only these modules\r\n        if (Array.isArray(this.opts.modules) && this.opts.modules.length > 0) {\r\n            this.opts.modules.forEach(moduleName => moduleFiles.push(`module-${moduleName}.js`));\r\n        }\r\n        // otherwise, load all available modules (might be more time consuming)\r\n        else {\r\n            moduleFiles = glob.sync('module-*.js', { cwd: oxModulesDirPath });\r\n        }\r\n        // initialize all modules        \r\n        for (let moduleFileName of moduleFiles) {\r\n            // extract name from the module file name based on module name pattern\r\n            const moduleName = moduleFileName.match(MODULE_NAME_MATCH_REGEX)[1];\r\n            try {\r\n                const startTime = new Date();\r\n                // initialize new logger for the module\r\n                const moduleLogger = this._wrapLogger(logger(`Module:${moduleName}`));\r\n                // initialize new module instance\r\n                const mod = coreUtils.loadModuleFromFile(moduleName, moduleFileName, moduleLogger, oxModulesDirPath, this);\r\n                // call onModuleLoaded hook\r\n                this._callServicesOnModuleLoaded(mod);\r\n                // add the module to the module list\r\n                this.modules[moduleName] = global.ox.modules[moduleName] = this._wrapModule(moduleName, mod);\r\n                // wrap up\r\n                const endTime = new Date();\r\n                const duration = (endTime - startTime) / 1000;\r\n                this.logger.debug('Loading module: ' + moduleName + ' [ ' + duration + ' sec ]');\r\n            } catch (e) {\r\n                this.logger.error('Error initializing module \"' + moduleName + '\": ' + e.message + EOL + (e.stacktrace ? e.stacktrace : ''));\r\n                // ignore any module that failed to load, except Web and Mob modules\r\n                // without Mob and Web modules loaded, the initialization process shall fail\r\n                if (moduleName === 'web' || moduleName === 'mob') {\r\n                    break;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    _loadInternalModules() {\r\n        // if `modules` is empty or undefined in oxygen.conf then load all modules\r\n        // otherwise, load only those implicitly defined\r\n        const excludeUndefinedMods = this.opts.modules && this.opts.modules.length > 0;\r\n\r\n        for (let moduleName of Object.keys(Modules)) {\r\n            if (excludeUndefinedMods && !this.opts.modules.includes(moduleName)) {\r\n                continue;\r\n            }\r\n            const ModuleClass = Modules[moduleName];\r\n            const oxModulesDirPath = oxutil.getOxModulesDir();\r\n            try {\r\n                const startTime = new Date();\r\n                // initialize new logger for the module\r\n                const moduleLogger = this._wrapLogger(logger(`Module:${moduleName}`));\r\n                // initialize new module instance\r\n                const mod = coreUtils.loadModuleFromClass(moduleName, ModuleClass, moduleLogger, oxModulesDirPath, this);\r\n                // call onModuleLoaded hook\r\n                this._callServicesOnModuleLoaded(mod);\r\n                // add the module to the module list\r\n                this.modules[moduleName] = global.ox.modules[moduleName] = this._wrapModule(moduleName, mod);\r\n                // wrap up\r\n                const endTime = new Date();\r\n                const duration = (endTime - startTime) / 1000;\r\n                this.logger.debug('Loading module: ' + moduleName + ' [ ' + duration + ' sec ]');\r\n            } catch (e) {\r\n                this.logger.error('Error initializing module \"' + moduleName + '\": ' + e.message + EOL + (e.stacktrace ? e.stacktrace : ''));\r\n                // ignore any module that failed to load, except Web and Mob modules\r\n                // without Mob and Web modules loaded, the initialization process shall fail\r\n                if (moduleName === 'web' || moduleName === 'mob') {\r\n                    break;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    _wrapModule(name, module) {\r\n        if (!module) {\r\n            return undefined;\r\n        }\r\n        const wrapper = {\r\n            name: name\r\n        };\r\n        const _this = this;\r\n        let moduleMethods = Object.keys(module);\r\n        if (!moduleMethods.some(x => x=== 'exports')) {\r\n            moduleMethods = this._getAllPropertyNames(module);\r\n        }\r\n        for (let methodName of moduleMethods) {\r\n            const method = module[methodName];\r\n            // ignore any module property that is not a function or a OxygenSubModule\r\n            if ((!(method instanceof Function) && !(method instanceof OxygenSubModule) && typeof method !== 'function') || methodName === 'exports' || methodName === '_compile') {\r\n                continue;\r\n            }\r\n            // map and wrap sub-module methods (recursive call to _wrapModule)\r\n            if (method instanceof OxygenSubModule) {\r\n                wrapper[methodName] = this._wrapModule(`${name}.${methodName}`, method);\r\n            }\r\n            // do not wrap methods\r\n            else if (DO_NOT_WRAP_METHODS.includes(methodName)) {\r\n                // === 'driver' || methodName === 'getDriver'\r\n                wrapper[methodName] = module[methodName].bind(module);\r\n            }\r\n            // private methods and event handlers\r\n            else if (methodName.indexOf('_') === 0 || methodName.indexOf('on') === 0) {\r\n                wrapper[methodName] = function() {\r\n                    var args = Array.prototype.slice.call(arguments);\r\n\r\n                    _this.logger.debug('Executing: ' + oxutil.getMethodSignature(name, methodName, args));\r\n\r\n                    try {\r\n                        return module[methodName].apply(module, args);\r\n                    } catch (e) {\r\n                        throw errorHelper.getOxygenError(e, name, methodName, args);\r\n                    }\r\n                };\r\n            }\r\n            else {\r\n                // create an internal _getCapabilities method for internal Oxygen Core use\r\n                // calling _getCapabilities method won't be visible in the test results\r\n                if (methodName === 'getCapabilities') {\r\n                    wrapper['_getCapabilities'] = method.bind(module);\r\n                }\r\n                wrapper[methodName] = (...args) => {\r\n                    try {\r\n                        return _this._commandWrapper(methodName, args, module, name);\r\n                    }\r\n                    catch (e) {\r\n                        if (e instanceof OxError) {\r\n                            //console.log('Throwing again:', e)\r\n                            throw e;\r\n                        }\r\n                        throw errorHelper.getOxygenError(e, name, methodName, args);\r\n                    }\r\n                };\r\n            }\r\n        }\r\n        return wrapper;\r\n    }\r\n\r\n    _commandWrapper(cmdName, cmdArgs, module, moduleName) {\r\n        if (!module || !module[cmdName]) {\r\n            return undefined;\r\n        }\r\n\r\n        let retval = null;\r\n        let error = null;\r\n        const cmdFn = module[cmdName];\r\n        const publicMethod = !cmdName.startsWith('_') && cmdName !== 'dispose';\r\n\r\n        // delay the command execution if required\r\n        if (\r\n            this.opts.delay &&\r\n            publicMethod &&\r\n            cmdName !== 'init' &&\r\n            cmdName !== 'transaction'\r\n        ) {\r\n            deasync.sleep(this.opts.delay * 1000);\r\n        }\r\n\r\n        // throw if a command executed on unitialized module (except internal methods and a few other)\r\n        if (!module.isInitialized && publicMethod && cmdName !== 'init' && cmdName !== 'transaction') {\r\n            throw new OxError(errorHelper.errorCode.MODULE_NOT_INITIALIZED_ERROR, 'Missing ' + moduleName + '.init()');\r\n        }\r\n\r\n        // dectypt arguments\r\n        let decryptedArgs = this._getDecryptedArgsForApply(cmdArgs, moduleName);\r\n        decryptedArgs = this._populateParametersValue(decryptedArgs);\r\n\r\n        // replace parameters in method arguments with corresponding values\r\n        cmdArgs = this._populateParametersValue(cmdArgs);\r\n        // start measuring method execution time\r\n        const startTime = oxutil.getTimeStamp();\r\n\r\n        // add command location information (e.g. file name and command line)\r\n        let cmdLocation = null;\r\n        // do not report results or line updates on internal methods (started with '_')\r\n        if (publicMethod) {\r\n            cmdLocation = this._getCommandLocation();\r\n            this.emitBeforeCommand(cmdName, moduleName, cmdFn, cmdArgs, this.ctx, cmdLocation, startTime);\r\n        }\r\n\r\n        this.logger.debug('Executing: ' + oxutil.getMethodSignature(moduleName, cmdName, cmdArgs));\r\n\r\n        try {\r\n            // emit before events\r\n            if (cmdName === 'dispose') {\r\n                this._wrapAsync(this._callServicesOnModuleWillDispose).apply(this, [module]);\r\n            }\r\n\r\n            const retvalPromise = this._wrapAsync(module[cmdName]).apply(module, decryptedArgs);\r\n\r\n            if (retvalPromise && retvalPromise.then) {\r\n                let promiseDone = false;\r\n\r\n                retvalPromise.then((value) => {\r\n\r\n                    retval = value;\r\n                    promiseDone = true;\r\n                }, (e) => {\r\n                    error = e;\r\n                    promiseDone = true;\r\n                });\r\n\r\n                deasync.loopWhile(() => !promiseDone);\r\n            } else {\r\n                retval = retvalPromise;\r\n            }\r\n\r\n            if (cmdName === 'init') {\r\n                this._wrapAsync(this._callServicesOnModuleInitialized).apply(this, [module]);\r\n            }\r\n\r\n        } catch (e) {\r\n            if (e && e.message && typeof e.message === 'string' && e.message.includes('invalid session id')) {\r\n                // ignore\r\n                return;\r\n            } else {\r\n                // do nothing if error ocurred after the module was disposed (or in a process of being disposed)\r\n                // except for init methods of course\r\n                if (module &&\r\n                    (typeof module.isInitialized === 'boolean' && !module.isInitialized)\r\n                    && cmdName !== 'init') {\r\n                    return;\r\n                }\r\n                //console.log('==== error ====', e)\r\n                error = errorHelper.getOxygenError(e, moduleName, cmdName, cmdArgs);\r\n            }\r\n        }\r\n\r\n        const endTime = oxutil.getTimeStamp();\r\n\r\n        let stepResult;\r\n        let done = false;\r\n\r\n        if (publicMethod) {\r\n            const waitId = +new Date();\r\n            this._waitStepResultList.push(waitId);\r\n\r\n            stepResult = this._getStepResult(module, moduleName, cmdName, cmdArgs, cmdLocation, startTime, endTime, retval, error);\r\n\r\n            const index = this._waitStepResultList.indexOf(waitId);\r\n            this._waitStepResultList.splice(index, 1);\r\n\r\n            //stepResult.location = cmdLocation;\r\n\r\n            this.resultStore.steps.push(stepResult);\r\n            this.emitAfterCommand(cmdName, moduleName, cmdFn, cmdArgs, this.ctx, cmdLocation, endTime, stepResult);\r\n            done = true;\r\n        }\r\n\r\n        if (error && error.isFatal && !this.opts.continueOnError) {\r\n            if (!error.location && cmdLocation) {\r\n                error.location = cmdLocation;\r\n            }\r\n\r\n            if (stepResult && stepResult.failure && stepResult.failure.location) {\r\n                error.location = stepResult.failure.location;\r\n            }\r\n\r\n            throw error;\r\n        }\r\n\r\n        if (!publicMethod) {\r\n            done = true;\r\n        }\r\n\r\n        deasync.loopWhile(() => !done && !error);\r\n\r\n        return retval;\r\n    }\r\n\r\n    _wrapAsync (fn, context) {\r\n        return function (...args) {\r\n            var self = context || this;\r\n            // if the current code is not running inside the Fiber context, then run async code as sync using deasync module\r\n            if (!Fiber.current) {\r\n                const retval = fn.apply(self, args);\r\n\r\n                let done = false;\r\n                let error = null;\r\n                let finalVal = null;\r\n\r\n                if (retval && retval.then) {\r\n                    Promise.resolve(retval)\r\n                    .then((val) => {\r\n                        finalVal = val;\r\n                        done = true;\r\n                    })\r\n                    .catch((e) => {\r\n                        error = e;\r\n                        done = true;\r\n                    });\r\n                } else {\r\n                    finalVal = retval;\r\n                    done = true;\r\n                }\r\n\r\n                try {\r\n                    deasync.loopWhile(() => !done && !error);\r\n                }\r\n                catch (e) {\r\n\r\n                    if (e && e.message && typeof e.message === 'string' && e.message.includes('readyState')) {\r\n                        return undefined;\r\n                    }\r\n\r\n                    // ignore this error as it usually happens \r\n                    // when Oxygen is disposed and process is being killed\r\n                    this.logger.error('deasync.loopWhile() failed:', e);\r\n                    return undefined;\r\n                }\r\n\r\n                if (!error) {\r\n                    return finalVal;\r\n                }\r\n                throw error;\r\n            }\r\n\r\n            let error = null;\r\n            let done = false;\r\n            let retval = null;\r\n\r\n            try {\r\n\r\n                // otherwise, if we are inside the Fiber context, then use Fiber's Future\r\n                const future = new Future();\r\n                var result = fn.apply(self, args);\r\n                if (result && typeof result.then === 'function') {\r\n                    result.then((val) => future.return(val), (err) => future.throw(err));\r\n                    return future.wait();\r\n                }\r\n                return result;\r\n\r\n            } catch (e) {\r\n                error = e;\r\n            }\r\n\r\n            deasync.loopWhile(() => !done && !error);\r\n\r\n            if (!error) {\r\n                return retval;\r\n            }\r\n            throw error;\r\n        };\r\n    }\r\n\r\n    // retrieve current line and function name from the call stack\r\n    _getCommandLocation() {\r\n        const stack = __stack;\r\n        let caller = null;\r\n        for (let call of stack) {\r\n            if (__filename === call.getFileName()) {\r\n                continue;\r\n            }\r\n            // return the first caller, which is not the current file\r\n            caller = call;\r\n            break;\r\n        }\r\n        if (caller) {\r\n            return `${caller.getFileName()}:${caller.getLineNumber() + this.adjustScriptLine}:${caller.getColumnNumber()}`;\r\n        }\r\n        return null;\r\n    }\r\n\r\n    _getStepResult(module, moduleName, methodName, args, location, startTime, endTime, retval, err) {\r\n        var step = new StepResult();\r\n\r\n        const displayName =\r\n            (module.getStepDisplayName && module.getStepDisplayName(methodName, args, retval, err)) ||\r\n            oxutil.getMethodSignature(moduleName, methodName, args);\r\n\r\n        step.name = displayName;\r\n        step.transaction = global._lastTransactionName || null;                   // FIXME: why is this here if it's already populated in rs?\r\n        step.location = location;\r\n        // module.extra is reseted for each step, so we must clone it\r\n        step.extra = { ...module.extra };\r\n        if (module.extra && module.extra.http) {\r\n            step.type = 'http';\r\n        }\r\n\r\n        if (err && err.type && err.type === errorHelper.errorCode.ASSERT_PASSED) {\r\n            step.status = STATUS.PASSED;\r\n        }\r\n        else {\r\n            // determine step status\r\n            if (err) {\r\n                if (err.isFatal) {\r\n                    step.status = STATUS.FAILED;\r\n                }\r\n                else {\r\n                    step.status = STATUS.WARNING;\r\n                }\r\n            }\r\n            else if (moduleName === 'log' && methodName === 'warn') {\r\n                step.status = STATUS.WARNING;\r\n            }\r\n            else {\r\n                step.status = STATUS.PASSED;\r\n            }\r\n        }\r\n\r\n        step.action = (typeof module._isAction === 'function' ? module._isAction(methodName) : false);\r\n        step.startTime = startTime;\r\n        step.endTime = endTime;\r\n        step.duration = endTime - startTime;\r\n\r\n        if (typeof module._getStats === 'function') {\r\n            step.stats = module._getStats(methodName);\r\n        } else {\r\n            step.stats = {};\r\n        }\r\n\r\n        if (err) {\r\n            if (err && err.type && err.type === errorHelper.errorCode.ASSERT_PASSED) {\r\n                //ignore\r\n            } else if (err && err.type && (err.type === errorHelper.errorCode.SELENIUM_SESSION_TIMEOUT || err.type === errorHelper.errorCode.APPIUM_SESSION_TIMEOUT)) {\r\n                //ignore\r\n            } else {\r\n                step.failure = errorHelper.getFailureFromError(err);\r\n                step.failure.location = location;\r\n                // let the module decide whether a screenshot should be taken on error or not\r\n\r\n                if (typeof module._takeScreenshotSilent === 'function' && !this.opts.disableScreenshot) {\r\n                    try {\r\n                        step.screenshot = module._takeScreenshotSilent(methodName);\r\n                    }\r\n                    catch (e) {\r\n                        // If we are here, we were unable to get a screenshot\r\n                        // Try to wait for a moment (in Perfecto Cloud, the screenshot might not be immidiately available)\r\n                        deasync.sleep(1000);\r\n                        try {\r\n                            step.screenshot = module._takeScreenshotSilent(methodName);\r\n                        }\r\n                        catch (e) {\r\n                            // FIXME: indicate to user that an attempt to take a screenshot has failed\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        return step;\r\n    }\r\n\r\n    async _disposeServices() {\r\n        if (!this.services || typeof this.services !== 'object') {\r\n            return false;\r\n        }\r\n        for (let key in this.services) {\r\n            const service = this.services[key];\r\n            if (service.dispose) {\r\n                try {\r\n                    await service.dispose();\r\n                }\r\n                catch (e) {\r\n                    // ignore service disposal error\r\n                    this.logger.error(`Failed to dispose service '${key}':`, e);\r\n                }\r\n            }\r\n        }\r\n        return true;\r\n    }\r\n\r\n    async _disposeModules(status = null) {\r\n        if (!this.modules || typeof this.modules !== 'object') {\r\n            return false;\r\n        }\r\n        for (let key in this.modules) {\r\n            const mod = this.modules[key];\r\n\r\n            if (mod.dispose) {\r\n                try {\r\n                    const disposeResult = mod.dispose(status);\r\n                    if (disposeResult && typeof disposeResult.then === 'function') {\r\n                        // probably a promise\r\n                        await disposeResult();\r\n                    }\r\n                }\r\n                catch (e) {\r\n                    // ignore module disposal error \r\n                    this.logger.error(`Failed to dispose module '${key}': `, e);\r\n                }\r\n            }\r\n        }\r\n        return true;\r\n    }\r\n    /*\r\n     * Services Event Emitters\r\n     */\r\n    _callServicesOnModuleLoaded(module) {\r\n        for (let serviceName in this.services) {\r\n            const service = this.services[serviceName];\r\n            if (!service) {\r\n                continue;\r\n            }\r\n            try {\r\n                service.onModuleLoaded(module);\r\n            }\r\n            catch (e) {\r\n                this.logger.error(`Failed to call \"onModuleLoaded\" method of ${serviceName} service.`, e);\r\n            }\r\n        }\r\n    }\r\n    async _callServicesOnModuleInitialized(module) {\r\n        for (let serviceName in this.services) {\r\n            const service = this.services[serviceName];\r\n            if (!service) {\r\n                continue;\r\n            }\r\n            try {\r\n                await service.onModuleInitialized(module);\r\n            }\r\n            catch (e) {\r\n                this.logger.error(`Failed to call \"onModuleInitialized\" method of ${serviceName} service.`, e);\r\n            }\r\n        }\r\n    }\r\n    async _callServicesOnModuleWillDispose(module) {\r\n        if (!this || !this.services) {\r\n            return;\r\n        }\r\n        for (let serviceName in this.services) {\r\n            const service = this.services[serviceName];\r\n            if (!service) {\r\n                continue;\r\n            }\r\n            try {\r\n                if (service.onModuleWillDispose) {\r\n                    service.onModuleWillDispose(module);\r\n                }\r\n            }\r\n            catch (e) {\r\n                this.logger.error(`Failed to call \"onModuleWillDispose\" method of ${serviceName} service.`, e);\r\n            }\r\n        }\r\n    }\r\n    _populateParametersValue(args) {\r\n        if (!args || !Array.isArray(args) || args.length == 0) {\r\n            return args;\r\n        }\r\n        const _newArgs = [];\r\n        for (let arg of args) {\r\n            _newArgs.push(this._replaceParameterInArgument(arg));\r\n        }\r\n        return _newArgs;\r\n    }\r\n    _replaceParameterInArgument(arg) {\r\n        if (arg && typeof arg.getDecryptResult === 'function') {\r\n            return 'ENCRYPTED';\r\n        }\r\n\r\n        if (!arg || typeof arg !== 'string') {\r\n            return arg;\r\n        }\r\n        // replace user parameters with values\r\n        // note: user parameter with the same name takes precedence over environment variable\r\n        for (let paramName in this.ctx.params) {\r\n            if (this.ctx.params.hasOwnProperty(paramName))\r\n            {\r\n                const paramValue = this.ctx.params[paramName];\r\n                arg = arg.replace(new RegExp('\\\\${' + paramName + '}', 'g'), paramValue);\r\n            }\r\n        }\r\n        // replace environment variables with values\r\n        for (let envName in this.ctx.env) {\r\n            if (this.ctx.env.hasOwnProperty(envName))\r\n            {\r\n                const envValue = this.ctx.env[envName];\r\n                arg = arg.replace(new RegExp('\\\\${' + envName + '}', 'g'), envValue);\r\n            }\r\n        }\r\n        return arg;\r\n    }\r\n    _getAllPropertyNames( obj ) {\r\n        const props = [];\r\n\r\n        do {\r\n            Object.getOwnPropertyNames( obj ).forEach(function ( prop ) {\r\n                if ( props.indexOf( prop ) === -1 ) {\r\n                    props.push( prop );\r\n                }\r\n            });\r\n            // eslint-disable-next-line no-cond-assign\r\n        } while ( obj = Object.getPrototypeOf( obj ) );\r\n\r\n        return props;\r\n    }\r\n\r\n    _checkStepResult(resolve, reject) {\r\n        if (this._waitStepResultList.length === 0) {\r\n            resolve();\r\n        } else {\r\n            this._checkStepResult(resolve, reject);\r\n        }\r\n    }\r\n\r\n    _waitStepResult() {\r\n        return new Promise((resolve, reject) => {\r\n            this._checkStepResult(resolve, reject);\r\n        });\r\n    }\r\n\r\n    _getDecryptedArgsForApply(args, moduleName) {\r\n        if (!args || !Array.isArray(args) || args.length == 0) {\r\n            return args;\r\n        }\r\n        const _newArgs = [];\r\n        for (let arg of args) {\r\n            _newArgs.push(this._decryptParameterForApplyInArgument(arg, moduleName));\r\n        }\r\n        return _newArgs;\r\n    }\r\n\r\n    _decryptParameterForApplyInArgument(arg, moduleName) {\r\n        if (arg && typeof arg.getDecryptResult === 'function') {\r\n            if (moduleName === 'log') {\r\n                return 'ENCRYPTED';\r\n            } else {\r\n                return arg.getDecryptResult();\r\n            }\r\n        }\r\n\r\n        return arg;\r\n    }\r\n}\r\n"]}
1072
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/core/OxygenCore.js"],"names":["Object","defineProperty","global","get","orig","Error","prepareStackTrace","_","stack","err","captureStackTrace","DEFAULT_TIMEOUT","DEFAULT_OPTS","backtrace","compiler","failAmbiguousDefinitions","failFast","ignoreUndefinedDefinitions","name","profile","require","order","snippetSyntax","undefined","snippets","source","strict","tagExpression","tagsInTitle","timeout","MODULE_NAME_MATCH_REGEX","SERVICE_NAME_MATCH_REGEX","DO_NOT_WRAP_METHODS","DEFAULT_CTX","params","vars","env","caps","attributes","DEFAULT_RESULT_STORE","steps","logs","attachments","har","Oxygen","OxygenEvents","constructor","isInitialized","resultStore","ctx","modules","services","repo","capabilities","opts","oxBaseDir","path","join","__dirname","logger","_wrapLogger","_waitStepResultList","init","options","results","assign","cwd","process","keys","length","makeOxGlobal","_loadServices","_loadModules","globalScope","makeContextAndModulesGlobal","disposeModules","status","_disposeModules","e","console","error","dispose","_disposeServices","adjustScriptLine","isInDebugMode","oxutil","result","context","ox","repository","transStep","includes","transName","transaction","duration","step","endTime","STATUS","WARNING","getModulesCapabilities","modCaps","moduleName","module","_getCapabilities","resetResults","onBeforeCase","_iterationStart","onAfterCase","_iterationEnd","addAttribute","bind","addAttachment","value","OxError","errorHelper","errorCode","SCRIPT_ERROR","filePath","fs","existsSync","push","coreUtils","newFileAttachment","loadPageObjectFile","poPath","po","_logger","loggerWrap","info","args","_log","debug","warn","userInfo","ISSUERS","USER","userDebug","userError","userWarn","level","src","DEFAULT_LOGGER_ISSUER","apply","message","stringify","time","getTimeStamp","toUpperCase","msg","shift","emitLog","oxServicesDirPath","resolve","serviceFiles","glob","sync","i","serviceFileName","serviceFilePath","match","serviceName","Array","isArray","service","_loadService","EOL","stacktrace","servicePath","ServiceClass","default","serviceLogger","_loadInternalModules","_loadExternalModules","modulesFolderPath","modules_ext","oxModulesDirPath","moduleFiles","forEach","moduleFileName","startTime","Date","moduleLogger","mod","loadModuleFromFile","_callServicesOnModuleLoaded","_wrapModule","excludeUndefinedMods","Modules","ModuleClass","getOxModulesDir","loadModuleFromClass","wrapper","_this","moduleMethods","some","x","_getAllPropertyNames","methodName","method","Function","OxygenSubModule","indexOf","prototype","slice","call","arguments","getMethodSignature","getOxygenError","_commandWrapper","cmdName","cmdArgs","retval","cmdFn","publicMethod","startsWith","delay","deasync","sleep","MODULE_NOT_INITIALIZED_ERROR","decryptedArgs","_getDecryptedArgsForApply","_populateParametersValue","cmdLocation","_getCommandLocation","emitBeforeCommand","_wrapAsync","_callServicesOnModuleWillDispose","retvalPromise","then","promiseDone","loopWhile","_callServicesOnModuleInitialized","stepResult","done","waitId","_getStepResult","index","splice","emitAfterCommand","isFatal","continueOnError","location","failure","fn","self","Fiber","current","finalVal","Promise","val","catch","future","Future","return","throw","wait","__stack","caller","__filename","getFileName","getLineNumber","getColumnNumber","StepResult","displayName","getStepDisplayName","_lastTransactionName","extra","http","type","ASSERT_PASSED","PASSED","FAILED","action","_isAction","_getStats","stats","SELENIUM_SESSION_TIMEOUT","APPIUM_SESSION_TIMEOUT","getFailureFromError","_takeScreenshotSilent","disableScreenshot","screenshot","key","disposeResult","onModuleLoaded","onModuleInitialized","onModuleWillDispose","_newArgs","arg","_replaceParameterInArgument","getDecryptResult","paramName","hasOwnProperty","paramValue","replace","RegExp","envName","envValue","obj","props","getOwnPropertyNames","prop","getPrototypeOf","_checkStepResult","reject","_waitStepResult","_decryptParameterForApplyInArgument"],"mappings":"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","sourcesContent":["/* eslint-disable no-prototype-builtins */\r\nimport glob from 'glob';\r\nimport path from 'path';\r\nimport fs from 'fs';\r\nimport deasync from 'deasync';\r\nimport Future from 'fibers/future';\r\nimport Fiber from 'fibers';\r\nimport { EOL } from 'os';\r\nimport StepResult from '../model/step-result';\r\nimport OxygenEvents from './OxygenEvents';\r\nimport oxutil from '../lib/util';\r\nimport * as coreUtils from './utils';\r\nimport OxError from '../errors/OxygenError';\r\nimport errorHelper from '../errors/helper';\r\nimport STATUS from '../model/status.js';\r\nimport * as Modules from '../ox_modules/index';\r\n\r\n// setup logger\r\nimport logger, { DEFAULT_LOGGER_ISSUER, ISSUERS } from '../lib/logger';\r\nimport { OxygenSubModule } from './OxygenSubModule';\r\n\r\n/*global __stack*/\r\nObject.defineProperty(global, '__stack', {\r\n    get: function () {\r\n        var orig = Error.prepareStackTrace;\r\n        Error.prepareStackTrace = function (_, stack) { return stack; };\r\n        var err = new Error();\r\n        Error.captureStackTrace(err);\r\n        var stack = err.stack;\r\n        Error.prepareStackTrace = orig;\r\n        return stack;\r\n    }\r\n});\r\n\r\nconst DEFAULT_TIMEOUT = 30000;\r\nconst DEFAULT_OPTS = {\r\n    backtrace: false, // <boolean> show full backtrace for errors\r\n    compiler: [], // <string[]> (\"extension:module\") require files with the given EXTENSION after requiring MODULE (repeatable)\r\n    failAmbiguousDefinitions: false, // <boolean> treat ambiguous definitions as errors\r\n    failFast: false, // <boolean> abort the run on first failure\r\n    ignoreUndefinedDefinitions: false, // <boolean> treat undefined definitions as warnings\r\n    name: [], // <REGEXP[]> only execute the scenarios with name matching the expression (repeatable)\r\n    profile: [], // <string> (name) specify the profile to use\r\n    require: [], // <string> (file/dir/glob) require files before executing features\r\n    order: 'defined', // <string> switch between deterministic  and random feature execution. Either \"defined\", \"random\" or \"random:42\" whereas 42 is the seed for randomization\r\n    snippetSyntax: undefined, // <string> specify a custom snippet syntax\r\n    snippets: true, // <boolean> hide step definition snippets for pending steps\r\n    source: true, // <boolean> hide source uris\r\n    strict: false, // <boolean> fail if there are any undefined or pending steps\r\n    tagExpression: '', // <string> (expression) only execute the features or scenarios with tags matching the expression\r\n    tagsInTitle: false, // <boolean> add cucumber tags to feature or scenario name\r\n    timeout: DEFAULT_TIMEOUT // <number> timeout for step definitions in milliseconds\r\n};\r\nconst MODULE_NAME_MATCH_REGEX = /^module-(.+?)\\.js$/;\r\nconst SERVICE_NAME_MATCH_REGEX = /^service-(.+?)\\.js$/;\r\nconst DO_NOT_WRAP_METHODS = ['driver', 'getDriver'];\r\n\r\nconst DEFAULT_CTX = {\r\n    params: {},\r\n    vars: {},\r\n    env: {},\r\n    caps: {},\r\n    attributes: {},\r\n};\r\nconst DEFAULT_RESULT_STORE = {\r\n    steps: [],\r\n    logs: [],\r\n    attachments: [],\r\n    har: null,\r\n    attributes: {}\r\n};\r\n\r\nexport default class Oxygen extends OxygenEvents {\r\n    constructor () {\r\n        super();\r\n        this.isInitialized = false;\r\n        this.resultStore = { ...DEFAULT_RESULT_STORE };\r\n        this.ctx = { ...DEFAULT_CTX };\r\n        this.modules = {};\r\n        this.services = {};\r\n        this.repo = {};\r\n        this.capabilities = null;\r\n        this.opts = null;\r\n        this.oxBaseDir = path.join(__dirname, '../');\r\n        this.logger = this._wrapLogger(logger('Oxygen'));\r\n        this._waitStepResultList = [];\r\n    }\r\n\r\n    async init(options, caps, ctx = {}, results = {}) {\r\n        this.opts = Object.assign(DEFAULT_OPTS, options);\r\n        this.cwd = this.opts.cwd || process.cwd();\r\n        this.ctx = Object.assign(DEFAULT_CTX, ctx || {});\r\n        this.ctx.caps = { ...ctx.caps || {}, ...caps, };\r\n        this.resultStore = Object.assign(DEFAULT_RESULT_STORE, results || {});\r\n        this.capabilities = this.ctx.caps = caps;\r\n\r\n        if (ctx.attributes && (!results.attributes || !Object.keys(results.attributes).length)) {\r\n            this.resultStore.attributes = { ...ctx.attributes };\r\n        }\r\n\r\n        // define 'ox' object in global JS scope\r\n        // we will use this object to access Oxygen modules and test context from modules used in the test (if any)        \r\n        this.makeOxGlobal();\r\n        // load services\r\n        this._loadServices();\r\n        // load modules\r\n        this._loadModules();\r\n        // if options.makeModulesGlobal is true or undefined than define 'ctx' content and each module in global scope\r\n        if (typeof options.globalScope === 'undefined' || options.globalScope === true) {\r\n            this.makeContextAndModulesGlobal();\r\n        }\r\n        this.isInitialized = true;\r\n    }\r\n\r\n    async disposeModules(status = null) {\r\n        try {\r\n            await this._disposeModules(status);\r\n        }\r\n        catch (e) {\r\n            console.error('Failed to dispose modules: ', e);\r\n            throw e;\r\n        }\r\n    }\r\n\r\n    async dispose(status = null) {\r\n        try {\r\n            await this._disposeModules(status);\r\n            await this._disposeServices();\r\n            this.isInitialized = false;\r\n        }\r\n        catch (e) {\r\n            this.isInitialized = false;\r\n            console.error('Failed to dispose: ', e);\r\n            throw e;\r\n        }\r\n    }\r\n\r\n    get adjustScriptLine() {\r\n        const isInDebugMode = oxutil.isInDebugMode();\r\n        // add extra line if we are running in debugger mode (V8 debugger adds an extra line at the beginning of the file)\r\n        const result = isInDebugMode ? -1 : 0;\r\n        return result;\r\n    }\r\n\r\n    get context() {\r\n        return this.ctx;\r\n    }\r\n\r\n    set context(ctx) {\r\n        this.ctx = ctx;\r\n        if (global.ox) {\r\n            global.ox.ctx = ctx;\r\n            if (typeof this.opts.globalScope === 'undefined' || this.opts.globalScope === true) {\r\n                // update \"params\" and \"env\" in \"ox\" global variable\r\n                global.params = ctx.params || {};\r\n                global.env = ctx.env || {};\r\n                global.attributes = ctx.attributes || {};\r\n            }\r\n        }\r\n    }\r\n\r\n    get repository() {\r\n        return this.repo;\r\n    }\r\n\r\n    set repository(repo) {\r\n        this.repo = repo;\r\n        if (global.ox) {\r\n            global.ox.repo = repo;\r\n        }\r\n    }\r\n\r\n    get results() {\r\n        // calculate time for the transaction itself - summary of durations for all the steps in this transaction\r\n        // also adjust transaction end time to much end time for the last executed step within this transaction.\r\n        for (const transStep of this.resultStore.steps) {\r\n            if (transStep.name.includes('.transaction')) {\r\n                const transName = transStep.transaction;\r\n                transStep.duration = 0;\r\n                for (const step of this.resultStore.steps) {\r\n                    // step belongs to the current transaction & is not the transaction step\r\n                    if (step.transaction === transName && step !== transStep) {\r\n                        transStep.duration += step.duration;\r\n                        if (step.endTime > transStep.endTime) {\r\n                            transStep.endTime = step.endTime;\r\n                        }\r\n\r\n                        // update transaction status to warning if at least one of steps has warning status\r\n                        if (step.status === STATUS.WARNING) {\r\n                            transStep.status = STATUS.WARNING;\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        return this.resultStore;\r\n    }\r\n\r\n    getModulesCapabilities() {\r\n        if (!this.modules) {\r\n            return null;\r\n        }\r\n        const modCaps = {};\r\n        for (let moduleName in this.modules) {\r\n            const module = this.modules[moduleName];\r\n            if (module.name && module._getCapabilities && typeof module._getCapabilities === 'function') {\r\n                const caps = module._getCapabilities();\r\n                // store only non-empty caps per module that has this.caps property\r\n                if (caps && typeof caps === 'object' && Object.keys(caps).length > 0) {\r\n                    modCaps[module.name] = caps;\r\n                }\r\n            }\r\n        }\r\n        return modCaps;\r\n    }\r\n\r\n    resetResults() {\r\n        this.resultStore.steps = [];\r\n        this.resultStore.logs = [];\r\n        this.resultStore.attachments = [];\r\n        this.har = null;\r\n    }\r\n\r\n    async onBeforeCase(context) {\r\n        for (let moduleName in this.modules) {\r\n            const module = this.modules[moduleName];\r\n            if (!module) {\r\n                continue;\r\n            }\r\n            try {\r\n                module.onBeforeCase && await module.onBeforeCase(context);\r\n                module._iterationStart && await module._iterationStart();\r\n            }\r\n            catch (e) {\r\n                this.logger.error(`Failed to call \"onBeforeCase\" method of ${moduleName} module.`, e);\r\n            }\r\n        }\r\n    }\r\n\r\n    async onAfterCase(error = null) {\r\n        for (let moduleName in this.modules) {\r\n            const module = this.modules[moduleName];\r\n            if (!module) {\r\n                continue;\r\n            }\r\n            try {\r\n                // await for avoid stuck on *.dispose call\r\n                module.onAfterCase && await module.onAfterCase(error);\r\n                module._iterationEnd && await module._iterationEnd(error);\r\n            }\r\n            catch (e) {\r\n                this.logger.error(`Failed to call \"onAfterCase\" method of ${moduleName} module.`, e);\r\n            }\r\n        }\r\n    }\r\n\r\n    makeOxGlobal() {\r\n        if (!global.ox) {\r\n            global.ox = {\r\n                modules: this.modules,\r\n                ctx: this.ctx,\r\n                options: this.opts,\r\n                caps: this.capabilities,\r\n                resultStore: this.resultStore,\r\n                addAttribute: this.addAttribute.bind(this),\r\n                addAttachment: this.addAttachment.bind(this),\r\n            };\r\n\r\n            global.vars = this.ctx.vars;\r\n        }\r\n    }\r\n\r\n    makeContextAndModulesGlobal() {\r\n        // make sure 'ox' is already global\r\n        if (global.ox) {\r\n            // expose modules as global variables\r\n            for (let moduleName in this.modules) {\r\n                if (!global[moduleName]) {\r\n                    global[moduleName] = this.modules[moduleName];\r\n                }\r\n            }\r\n            // expose \"ctx\", \"params\" and \"env\" as global variables\r\n            global.params = global.ox.ctx.params;\r\n            global.env = global.ox.ctx.env;\r\n            global.ctx = global.ox.ctx;\r\n            global.attributes = global.ox.ctx.attributes || {};\r\n        }\r\n    }\r\n\r\n    addAttribute(name, value) {\r\n        if (!name || !value) {\r\n            throw new OxError(errorHelper.errorCode.SCRIPT_ERROR, \"'name' and 'value' arguments are required for ox.addAttribute\");\r\n        }\r\n\r\n        if (this.resultStore && this.resultStore.attributes) {\r\n            this.resultStore.attributes[name] = value;\r\n        }\r\n    }\r\n\r\n    addAttachment(filePath) {\r\n        if (!this.resultStore) {\r\n            return;\r\n        }\r\n\r\n        if (!fs.existsSync(filePath)) {\r\n            console.err(`File ${filePath} doesn't exist`);\r\n            return;\r\n        }\r\n\r\n        if (!this.resultStore.attachments) {\r\n            this.resultStore.attachments = [];\r\n        }\r\n        this.resultStore.attachments.push(\r\n            coreUtils.newFileAttachment(filePath)\r\n        );\r\n    }\r\n\r\n    loadPageObjectFile(poPath) {\r\n        if (!poPath) {\r\n            return;\r\n        }\r\n        try {\r\n            const po = require(poPath);\r\n            // set page object repository as the main one\r\n            this.repository = po;\r\n            if (typeof this.opts.globalScope === 'undefined' || this.opts.globalScope === true) {\r\n                global.po = po;\r\n            }\r\n        }\r\n        catch (e) {\r\n            // ignore error\r\n            if (typeof this.opts.globalScope === 'undefined' || this.opts.globalScope === true) {\r\n                global.po = {};\r\n            }\r\n        }\r\n    }\r\n\r\n    /*\r\n     * Private Methods\r\n     */\r\n    _wrapLogger(_logger) {\r\n        const loggerWrap = {\r\n            info: (...args) => this._log(_logger, 'info', args),\r\n            debug: (...args) => this._log(_logger, 'debug', args),\r\n            error: (...args) => this._log(_logger, 'error', args),\r\n            warn: (...args) => this._log(_logger, 'warn', args),\r\n            userInfo: (...args) => this._log(_logger, 'info', args, ISSUERS.USER),\r\n            userDebug: (...args) => this._log(_logger, 'debug', args, ISSUERS.USER),\r\n            userError: (...args) => this._log(_logger, 'error', args, ISSUERS.USER),\r\n            userWarn: (...args) => this._log(_logger, 'warn', args, ISSUERS.USER),\r\n        };\r\n        return loggerWrap;\r\n    }\r\n\r\n    _log(_logger, level, args, src = DEFAULT_LOGGER_ISSUER) {\r\n        if (!_logger[level]) {\r\n            return;\r\n        }\r\n        _logger[level].apply(_logger, args);\r\n\r\n        const message = oxutil.stringify(args, 2);\r\n        const time = oxutil.getTimeStamp();\r\n        // add the log entry to the result store\r\n        if (this.resultStore && this.resultStore.logs) {\r\n            this.resultStore.logs.push({\r\n                time: time,\r\n                level: level.toUpperCase(),\r\n                msg: message,\r\n                src: src\r\n            });\r\n        }\r\n        // remove first argument, if it's a message\r\n        args = message ? args.shift() : args;\r\n        this.emitLog(time, level, message, args, src);\r\n    }\r\n\r\n    _loadServices() {\r\n        const oxServicesDirPath = path.resolve(this.oxBaseDir, './ox_services');\r\n        const serviceFiles = glob.sync('service-*.js', { cwd: oxServicesDirPath });\r\n        // initialize all services\r\n        this.logger.debug('Loading services...');\r\n\r\n        for (var i = 0; i < serviceFiles.length; i++) {\r\n            const serviceFileName = serviceFiles[i];\r\n            const serviceFilePath = path.join(oxServicesDirPath, serviceFileName);\r\n            const result = serviceFileName.match(SERVICE_NAME_MATCH_REGEX);\r\n            const serviceName = result[1];\r\n\r\n            // this.opts.services = undefined in single file mode\r\n            if (Array.isArray(this.opts.services) && !this.opts.services.includes(serviceName)) {\r\n                continue;\r\n            }\r\n\r\n            try {\r\n                this.logger.debug('Loading service: ' + serviceName);\r\n                const service = this._loadService(serviceName, serviceFilePath);\r\n                service.init();\r\n                this.services[serviceName] = service;\r\n            } catch (e) {\r\n                this.logger.error('Error initializing service \"' + serviceName + '\": ' + e.message + EOL + (e.stacktrace ? e.stacktrace : ''));\r\n            }\r\n        }\r\n    }\r\n    _loadService(serviceName, servicePath) {\r\n        let ServiceClass = require(servicePath);\r\n        // ES6 class will be under 'default' property\r\n        if (ServiceClass.default) {\r\n            ServiceClass = ServiceClass.default;\r\n        }\r\n        const serviceLogger = this._wrapLogger(logger(`Service:${serviceName}`));\r\n        return new ServiceClass(this.opts, this.ctx, this.resultStore, serviceLogger);\r\n    }\r\n\r\n    _loadModules() {\r\n        this.logger.debug('Loading internal modules...');\r\n        this._loadInternalModules();\r\n        this.logger.debug('Loading external modules...');\r\n        this._loadExternalModules();\r\n    }\r\n\r\n    _loadExternalModules() {\r\n        let modulesFolderPath = './modules';\r\n        if (this.opts.modules_ext && typeof this.opts.modules_ext === 'string') {\r\n            modulesFolderPath = this.opts.modules_ext;\r\n        }\r\n        //const oxModulesDirPath = path.resolve(this.oxBaseDir, './ox_modules');\r\n        const oxModulesDirPath = path.resolve(this.cwd, modulesFolderPath);\r\n        if (!fs.existsSync(oxModulesDirPath)) {\r\n            return false;\r\n        }\r\n        let moduleFiles = [];\r\n        // if particular module names are defined in the config, then load only these modules\r\n        if (Array.isArray(this.opts.modules) && this.opts.modules.length > 0) {\r\n            this.opts.modules.forEach(moduleName => moduleFiles.push(`module-${moduleName}.js`));\r\n        }\r\n        // otherwise, load all available modules (might be more time consuming)\r\n        else {\r\n            moduleFiles = glob.sync('module-*.js', { cwd: oxModulesDirPath });\r\n        }\r\n        // initialize all modules        \r\n        for (let moduleFileName of moduleFiles) {\r\n            // extract name from the module file name based on module name pattern\r\n            const moduleName = moduleFileName.match(MODULE_NAME_MATCH_REGEX)[1];\r\n            try {\r\n                const startTime = new Date();\r\n                // initialize new logger for the module\r\n                const moduleLogger = this._wrapLogger(logger(`Module:${moduleName}`));\r\n                // initialize new module instance\r\n                const mod = coreUtils.loadModuleFromFile(moduleName, moduleFileName, moduleLogger, oxModulesDirPath, this);\r\n                // call onModuleLoaded hook\r\n                this._callServicesOnModuleLoaded(mod);\r\n                // add the module to the module list\r\n                this.modules[moduleName] = global.ox.modules[moduleName] = this._wrapModule(moduleName, mod);\r\n                // wrap up\r\n                const endTime = new Date();\r\n                const duration = (endTime - startTime) / 1000;\r\n                this.logger.debug('Loading module: ' + moduleName + ' [ ' + duration + ' sec ]');\r\n            } catch (e) {\r\n                this.logger.error('Error initializing module \"' + moduleName + '\": ' + e.message + EOL + (e.stacktrace ? e.stacktrace : ''));\r\n                // ignore any module that failed to load, except Web and Mob modules\r\n                // without Mob and Web modules loaded, the initialization process shall fail\r\n                if (moduleName === 'web' || moduleName === 'mob') {\r\n                    break;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    _loadInternalModules() {\r\n        // if `modules` is empty or undefined in oxygen.conf then load all modules\r\n        // otherwise, load only those implicitly defined\r\n        const excludeUndefinedMods = this.opts.modules && this.opts.modules.length > 0;\r\n\r\n        for (let moduleName of Object.keys(Modules)) {\r\n            if (excludeUndefinedMods && !this.opts.modules.includes(moduleName)) {\r\n                continue;\r\n            }\r\n            const ModuleClass = Modules[moduleName];\r\n            const oxModulesDirPath = oxutil.getOxModulesDir();\r\n            try {\r\n                const startTime = new Date();\r\n                // initialize new logger for the module\r\n                const moduleLogger = this._wrapLogger(logger(`Module:${moduleName}`));\r\n                // initialize new module instance\r\n                const mod = coreUtils.loadModuleFromClass(moduleName, ModuleClass, moduleLogger, oxModulesDirPath, this);\r\n                // call onModuleLoaded hook\r\n                this._callServicesOnModuleLoaded(mod);\r\n                // add the module to the module list\r\n                this.modules[moduleName] = global.ox.modules[moduleName] = this._wrapModule(moduleName, mod);\r\n                // wrap up\r\n                const endTime = new Date();\r\n                const duration = (endTime - startTime) / 1000;\r\n                this.logger.debug('Loading module: ' + moduleName + ' [ ' + duration + ' sec ]');\r\n            } catch (e) {\r\n                this.logger.error('Error initializing module \"' + moduleName + '\": ' + e.message + EOL + (e.stacktrace ? e.stacktrace : ''));\r\n                // ignore any module that failed to load, except Web and Mob modules\r\n                // without Mob and Web modules loaded, the initialization process shall fail\r\n                if (moduleName === 'web' || moduleName === 'mob') {\r\n                    break;\r\n                }\r\n            }\r\n        }\r\n    }\r\n\r\n    _wrapModule(name, module) {\r\n        if (!module) {\r\n            return undefined;\r\n        }\r\n        const wrapper = {\r\n            name: name\r\n        };\r\n        const _this = this;\r\n        let moduleMethods = Object.keys(module);\r\n        if (!moduleMethods.some(x => x=== 'exports')) {\r\n            moduleMethods = this._getAllPropertyNames(module);\r\n        }\r\n        for (let methodName of moduleMethods) {\r\n            const method = module[methodName];\r\n            // ignore any module property that is not a function or a OxygenSubModule\r\n            if ((!(method instanceof Function) && !(method instanceof OxygenSubModule) && typeof method !== 'function') || methodName === 'exports' || methodName === '_compile') {\r\n                continue;\r\n            }\r\n            // map and wrap sub-module methods (recursive call to _wrapModule)\r\n            if (method instanceof OxygenSubModule) {\r\n                wrapper[methodName] = this._wrapModule(`${name}.${methodName}`, method);\r\n            }\r\n            // do not wrap methods\r\n            else if (DO_NOT_WRAP_METHODS.includes(methodName)) {\r\n                // === 'driver' || methodName === 'getDriver'\r\n                wrapper[methodName] = module[methodName].bind(module);\r\n            }\r\n            // private methods and event handlers\r\n            else if (methodName.indexOf('_') === 0 || methodName.indexOf('on') === 0) {\r\n                wrapper[methodName] = function() {\r\n                    var args = Array.prototype.slice.call(arguments);\r\n\r\n                    _this.logger.debug('Executing: ' + oxutil.getMethodSignature(name, methodName, args));\r\n\r\n                    try {\r\n                        return module[methodName].apply(module, args);\r\n                    } catch (e) {\r\n                        throw errorHelper.getOxygenError(e, name, methodName, args);\r\n                    }\r\n                };\r\n            }\r\n            else {\r\n                // create an internal _getCapabilities method for internal Oxygen Core use\r\n                // calling _getCapabilities method won't be visible in the test results\r\n                if (methodName === 'getCapabilities') {\r\n                    wrapper['_getCapabilities'] = method.bind(module);\r\n                }\r\n                wrapper[methodName] = (...args) => {\r\n                    try {\r\n                        return _this._commandWrapper(methodName, args, module, name);\r\n                    }\r\n                    catch (e) {\r\n                        if (e instanceof OxError) {\r\n                            //console.log('Throwing again:', e)\r\n                            throw e;\r\n                        }\r\n                        throw errorHelper.getOxygenError(e, name, methodName, args);\r\n                    }\r\n                };\r\n            }\r\n        }\r\n        return wrapper;\r\n    }\r\n\r\n    _commandWrapper(cmdName, cmdArgs, module, moduleName) {\r\n        if (!module || !module[cmdName]) {\r\n            return undefined;\r\n        }\r\n\r\n        let retval = null;\r\n        let error = null;\r\n        const cmdFn = module[cmdName];\r\n        const publicMethod = !cmdName.startsWith('_') && cmdName !== 'dispose';\r\n\r\n        // delay the command execution if required\r\n        if (\r\n            this.opts.delay &&\r\n            publicMethod &&\r\n            cmdName !== 'init' &&\r\n            cmdName !== 'transaction'\r\n        ) {\r\n            deasync.sleep(this.opts.delay * 1000);\r\n        }\r\n\r\n        // throw if a command executed on unitialized module (except internal methods and a few other)\r\n        if (!module.isInitialized && publicMethod && cmdName !== 'init' && cmdName !== 'transaction') {\r\n            throw new OxError(errorHelper.errorCode.MODULE_NOT_INITIALIZED_ERROR, 'Missing ' + moduleName + '.init()');\r\n        }\r\n\r\n        // dectypt arguments\r\n        let decryptedArgs = this._getDecryptedArgsForApply(cmdArgs, moduleName);\r\n        decryptedArgs = this._populateParametersValue(decryptedArgs);\r\n\r\n        // replace parameters in method arguments with corresponding values\r\n        cmdArgs = this._populateParametersValue(cmdArgs);\r\n        // start measuring method execution time\r\n        const startTime = oxutil.getTimeStamp();\r\n\r\n        // add command location information (e.g. file name and command line)\r\n        let cmdLocation = null;\r\n        // do not report results or line updates on internal methods (started with '_')\r\n        if (publicMethod) {\r\n            cmdLocation = this._getCommandLocation();\r\n            this.emitBeforeCommand(cmdName, moduleName, cmdFn, cmdArgs, this.ctx, cmdLocation, startTime);\r\n        }\r\n\r\n        this.logger.debug('Executing: ' + oxutil.getMethodSignature(moduleName, cmdName, cmdArgs));\r\n\r\n        try {\r\n            // emit before events\r\n            if (cmdName === 'dispose') {\r\n                this._wrapAsync(this._callServicesOnModuleWillDispose).apply(this, [module]);\r\n            }\r\n\r\n            const retvalPromise = this._wrapAsync(module[cmdName]).apply(module, decryptedArgs);\r\n\r\n            if (retvalPromise && retvalPromise.then) {\r\n                let promiseDone = false;\r\n\r\n                retvalPromise.then((value) => {\r\n\r\n                    retval = value;\r\n                    promiseDone = true;\r\n                }, (e) => {\r\n                    error = e;\r\n                    promiseDone = true;\r\n                });\r\n\r\n                deasync.loopWhile(() => !promiseDone);\r\n            } else {\r\n                retval = retvalPromise;\r\n            }\r\n\r\n            if (cmdName === 'init') {\r\n                this._wrapAsync(this._callServicesOnModuleInitialized).apply(this, [module]);\r\n            }\r\n\r\n        } catch (e) {\r\n            if (e && e.message && typeof e.message === 'string' && e.message.includes('invalid session id')) {\r\n                // ignore\r\n                return;\r\n            } else {\r\n                // do nothing if error ocurred after the module was disposed (or in a process of being disposed)\r\n                // except for init methods of course\r\n                if (module &&\r\n                    (typeof module.isInitialized === 'boolean' && !module.isInitialized)\r\n                    && cmdName !== 'init') {\r\n                    return;\r\n                }\r\n                //console.log('==== error ====', e)\r\n                error = errorHelper.getOxygenError(e, moduleName, cmdName, cmdArgs);\r\n            }\r\n        }\r\n\r\n        const endTime = oxutil.getTimeStamp();\r\n\r\n        let stepResult;\r\n        let done = false;\r\n\r\n        if (publicMethod) {\r\n            const waitId = +new Date();\r\n            this._waitStepResultList.push(waitId);\r\n\r\n            stepResult = this._getStepResult(module, moduleName, cmdName, cmdArgs, cmdLocation, startTime, endTime, retval, error);\r\n\r\n            const index = this._waitStepResultList.indexOf(waitId);\r\n            this._waitStepResultList.splice(index, 1);\r\n\r\n            //stepResult.location = cmdLocation;\r\n\r\n            this.resultStore.steps.push(stepResult);\r\n            this.emitAfterCommand(cmdName, moduleName, cmdFn, cmdArgs, this.ctx, cmdLocation, endTime, stepResult);\r\n            done = true;\r\n        }\r\n\r\n        if (error && error.isFatal && !this.opts.continueOnError) {\r\n            if (!error.location && cmdLocation) {\r\n                error.location = cmdLocation;\r\n            }\r\n\r\n            if (stepResult && stepResult.failure && stepResult.failure.location) {\r\n                error.location = stepResult.failure.location;\r\n            }\r\n\r\n            throw error;\r\n        }\r\n\r\n        if (!publicMethod) {\r\n            done = true;\r\n        }\r\n\r\n        deasync.loopWhile(() => !done && !error);\r\n\r\n        return retval;\r\n    }\r\n\r\n    _wrapAsync (fn, context) {\r\n        return function (...args) {\r\n            var self = context || this;\r\n            // if the current code is not running inside the Fiber context, then run async code as sync using deasync module\r\n            if (!Fiber.current) {\r\n                const retval = fn.apply(self, args);\r\n\r\n                let done = false;\r\n                let error = null;\r\n                let finalVal = null;\r\n\r\n                if (retval && retval.then) {\r\n                    Promise.resolve(retval)\r\n                    .then((val) => {\r\n                        finalVal = val;\r\n                        done = true;\r\n                    })\r\n                    .catch((e) => {\r\n                        error = e;\r\n                        done = true;\r\n                    });\r\n                } else {\r\n                    finalVal = retval;\r\n                    done = true;\r\n                }\r\n\r\n                try {\r\n                    deasync.loopWhile(() => !done && !error);\r\n                }\r\n                catch (e) {\r\n\r\n                    if (e && e.message && typeof e.message === 'string' && e.message.includes('readyState')) {\r\n                        return undefined;\r\n                    }\r\n\r\n                    // ignore this error as it usually happens \r\n                    // when Oxygen is disposed and process is being killed\r\n                    this.logger.error('deasync.loopWhile() failed:', e);\r\n                    return undefined;\r\n                }\r\n\r\n                if (!error) {\r\n                    return finalVal;\r\n                }\r\n                throw error;\r\n            }\r\n\r\n            let error = null;\r\n            let done = false;\r\n            let retval = null;\r\n\r\n            try {\r\n\r\n                // otherwise, if we are inside the Fiber context, then use Fiber's Future\r\n                const future = new Future();\r\n                var result = fn.apply(self, args);\r\n                if (result && typeof result.then === 'function') {\r\n                    result.then((val) => future.return(val), (err) => future.throw(err));\r\n                    return future.wait();\r\n                }\r\n                return result;\r\n\r\n            } catch (e) {\r\n                error = e;\r\n            }\r\n\r\n            deasync.loopWhile(() => !done && !error);\r\n\r\n            if (!error) {\r\n                return retval;\r\n            }\r\n            throw error;\r\n        };\r\n    }\r\n\r\n    // retrieve current line and function name from the call stack\r\n    _getCommandLocation() {\r\n        const stack = __stack;\r\n        let caller = null;\r\n        for (let call of stack) {\r\n            if (__filename === call.getFileName()) {\r\n                continue;\r\n            }\r\n            // return the first caller, which is not the current file\r\n            caller = call;\r\n            break;\r\n        }\r\n        if (caller) {\r\n            return `${caller.getFileName()}:${caller.getLineNumber() + this.adjustScriptLine}:${caller.getColumnNumber()}`;\r\n        }\r\n        return null;\r\n    }\r\n\r\n    _getStepResult(module, moduleName, methodName, args, location, startTime, endTime, retval, err) {\r\n        var step = new StepResult();\r\n\r\n        const displayName =\r\n            (module.getStepDisplayName && module.getStepDisplayName(methodName, args, retval, err)) ||\r\n            oxutil.getMethodSignature(moduleName, methodName, args);\r\n\r\n        step.name = displayName;\r\n        step.transaction = global._lastTransactionName || null;                   // FIXME: why is this here if it's already populated in rs?\r\n        step.location = location;\r\n        // module.extra is reseted for each step, so we must clone it\r\n        step.extra = { ...module.extra };\r\n        if (module.extra && module.extra.http) {\r\n            step.type = 'http';\r\n        }\r\n\r\n        if (err && err.type && err.type === errorHelper.errorCode.ASSERT_PASSED) {\r\n            step.status = STATUS.PASSED;\r\n        }\r\n        else {\r\n            // determine step status\r\n            if (err) {\r\n                if (err.isFatal) {\r\n                    step.status = STATUS.FAILED;\r\n                }\r\n                else {\r\n                    step.status = STATUS.WARNING;\r\n                }\r\n            }\r\n            else if (moduleName === 'log' && methodName === 'warn') {\r\n                step.status = STATUS.WARNING;\r\n            }\r\n            else {\r\n                step.status = STATUS.PASSED;\r\n            }\r\n        }\r\n\r\n        step.action = (typeof module._isAction === 'function' ? module._isAction(methodName) : false);\r\n        step.startTime = startTime;\r\n        step.endTime = endTime;\r\n        step.duration = endTime - startTime;\r\n\r\n        if (typeof module._getStats === 'function') {\r\n            step.stats = module._getStats(methodName);\r\n        } else {\r\n            step.stats = {};\r\n        }\r\n\r\n        if (err) {\r\n            if (err && err.type && err.type === errorHelper.errorCode.ASSERT_PASSED) {\r\n                //ignore\r\n            } else if (err && err.type && (err.type === errorHelper.errorCode.SELENIUM_SESSION_TIMEOUT || err.type === errorHelper.errorCode.APPIUM_SESSION_TIMEOUT)) {\r\n                //ignore\r\n            } else {\r\n                step.failure = errorHelper.getFailureFromError(err);\r\n                step.failure.location = location;\r\n                // let the module decide whether a screenshot should be taken on error or not\r\n\r\n                if (typeof module._takeScreenshotSilent === 'function' && !this.opts.disableScreenshot) {\r\n                    try {\r\n                        step.screenshot = module._takeScreenshotSilent(methodName);\r\n                    }\r\n                    catch (e) {\r\n                        // If we are here, we were unable to get a screenshot\r\n                        // Try to wait for a moment (in Perfecto Cloud, the screenshot might not be immidiately available)\r\n                        deasync.sleep(1000);\r\n                        try {\r\n                            step.screenshot = module._takeScreenshotSilent(methodName);\r\n                        }\r\n                        catch (e) {\r\n                            // FIXME: indicate to user that an attempt to take a screenshot has failed\r\n                        }\r\n                    }\r\n                }\r\n            }\r\n        }\r\n        return step;\r\n    }\r\n\r\n    async _disposeServices() {\r\n        if (!this.services || typeof this.services !== 'object') {\r\n            return false;\r\n        }\r\n        for (let key in this.services) {\r\n            const service = this.services[key];\r\n            if (service.dispose) {\r\n                try {\r\n                    await service.dispose();\r\n                }\r\n                catch (e) {\r\n                    // ignore service disposal error\r\n                    this.logger.error(`Failed to dispose service '${key}':`, e);\r\n                }\r\n            }\r\n        }\r\n        return true;\r\n    }\r\n\r\n    async _disposeModules(status = null) {\r\n        if (!this.modules || typeof this.modules !== 'object') {\r\n            return false;\r\n        }\r\n        for (let key in this.modules) {\r\n            const mod = this.modules[key];\r\n\r\n            if (mod.dispose) {\r\n                try {\r\n                    const disposeResult = mod.dispose(status);\r\n                    if (disposeResult && typeof disposeResult.then === 'function') {\r\n                        // probably a promise\r\n                        await disposeResult();\r\n                    }\r\n                }\r\n                catch (e) {\r\n                    // ignore module disposal error \r\n                    this.logger.error(`Failed to dispose module '${key}': `, e);\r\n                }\r\n            }\r\n        }\r\n        return true;\r\n    }\r\n    /*\r\n     * Services Event Emitters\r\n     */\r\n    _callServicesOnModuleLoaded(module) {\r\n        for (let serviceName in this.services) {\r\n            const service = this.services[serviceName];\r\n            if (!service) {\r\n                continue;\r\n            }\r\n            try {\r\n                service.onModuleLoaded(module);\r\n            }\r\n            catch (e) {\r\n                this.logger.error(`Failed to call \"onModuleLoaded\" method of ${serviceName} service.`, e);\r\n            }\r\n        }\r\n    }\r\n    async _callServicesOnModuleInitialized(module) {\r\n        for (let serviceName in this.services) {\r\n            const service = this.services[serviceName];\r\n            if (!service) {\r\n                continue;\r\n            }\r\n            try {\r\n                await service.onModuleInitialized(module);\r\n            }\r\n            catch (e) {\r\n                this.logger.error(`Failed to call \"onModuleInitialized\" method of ${serviceName} service.`, e);\r\n            }\r\n        }\r\n    }\r\n    async _callServicesOnModuleWillDispose(module) {\r\n        if (!this || !this.services) {\r\n            return;\r\n        }\r\n        for (let serviceName in this.services) {\r\n            const service = this.services[serviceName];\r\n            if (!service) {\r\n                continue;\r\n            }\r\n            try {\r\n                if (service.onModuleWillDispose) {\r\n                    service.onModuleWillDispose(module);\r\n                }\r\n            }\r\n            catch (e) {\r\n                this.logger.error(`Failed to call \"onModuleWillDispose\" method of ${serviceName} service.`, e);\r\n            }\r\n        }\r\n    }\r\n    _populateParametersValue(args) {\r\n        if (!args || !Array.isArray(args) || args.length == 0) {\r\n            return args;\r\n        }\r\n        const _newArgs = [];\r\n        for (let arg of args) {\r\n            _newArgs.push(this._replaceParameterInArgument(arg));\r\n        }\r\n        return _newArgs;\r\n    }\r\n    _replaceParameterInArgument(arg) {\r\n        if (arg && typeof arg.getDecryptResult === 'function') {\r\n            return 'ENCRYPTED';\r\n        }\r\n\r\n        if (!arg || typeof arg !== 'string') {\r\n            return arg;\r\n        }\r\n        // replace user parameters with values\r\n        // note: user parameter with the same name takes precedence over environment variable\r\n        for (let paramName in this.ctx.params) {\r\n            if (this.ctx.params.hasOwnProperty(paramName))\r\n            {\r\n                const paramValue = this.ctx.params[paramName];\r\n                arg = arg.replace(new RegExp('\\\\${' + paramName + '}', 'g'), paramValue);\r\n            }\r\n        }\r\n        // replace environment variables with values\r\n        for (let envName in this.ctx.env) {\r\n            if (this.ctx.env.hasOwnProperty(envName))\r\n            {\r\n                const envValue = this.ctx.env[envName];\r\n                arg = arg.replace(new RegExp('\\\\${' + envName + '}', 'g'), envValue);\r\n            }\r\n        }\r\n        return arg;\r\n    }\r\n    _getAllPropertyNames( obj ) {\r\n        const props = [];\r\n\r\n        do {\r\n            Object.getOwnPropertyNames( obj ).forEach(function ( prop ) {\r\n                if ( props.indexOf( prop ) === -1 ) {\r\n                    props.push( prop );\r\n                }\r\n            });\r\n            // eslint-disable-next-line no-cond-assign\r\n        } while ( obj = Object.getPrototypeOf( obj ) );\r\n\r\n        return props;\r\n    }\r\n\r\n    _checkStepResult(resolve, reject) {\r\n        if (this._waitStepResultList.length === 0) {\r\n            resolve();\r\n        } else {\r\n            this._checkStepResult(resolve, reject);\r\n        }\r\n    }\r\n\r\n    _waitStepResult() {\r\n        return new Promise((resolve, reject) => {\r\n            this._checkStepResult(resolve, reject);\r\n        });\r\n    }\r\n\r\n    _getDecryptedArgsForApply(args, moduleName) {\r\n        if (!args || !Array.isArray(args) || args.length == 0) {\r\n            return args;\r\n        }\r\n        const _newArgs = [];\r\n        for (let arg of args) {\r\n            _newArgs.push(this._decryptParameterForApplyInArgument(arg, moduleName));\r\n        }\r\n        return _newArgs;\r\n    }\r\n\r\n    _decryptParameterForApplyInArgument(arg, moduleName) {\r\n        if (arg && typeof arg.getDecryptResult === 'function') {\r\n            if (moduleName === 'log') {\r\n                return 'ENCRYPTED';\r\n            } else {\r\n                return arg.getDecryptResult();\r\n            }\r\n        }\r\n\r\n        return arg;\r\n    }\r\n}\r\n"]}
@@ -265,6 +265,64 @@ class MobileModule extends _WebDriverModule.default {
265
265
  delete wdioOpts.capabilities.host;
266
266
  name = wdioOpts.capabilities['perfectoMobile:options']['name'];
267
267
  delete wdioOpts.capabilities['perfectoMobile:options'];
268
+ } else if (provider === _utils.default.provider.BROWSERSTACK) {
269
+ const bsOptions = wdioOpts.capabilities['bstack:options'];
270
+
271
+ if (bsOptions) {
272
+ const deviceName = bsOptions.deviceName;
273
+ const osName = bsOptions.os;
274
+
275
+ if (deviceName) {
276
+ bsOptions.realMobile = true;
277
+ wdioOpts.capabilities['appium:deviceName'] = deviceName;
278
+ delete bsOptions['deviceName'];
279
+ } // set automationName Appium capability
280
+
281
+
282
+ if (osName && osName.toLowerCase() === 'android') {
283
+ wdioOpts.capabilities.platformName = 'Android';
284
+ wdioOpts.capabilities['appium:automationName'] = 'UIAutomator2';
285
+ } else if (osName && osName.toLowerCase() === 'ios') {
286
+ wdioOpts.capabilities.platformName = 'iOS';
287
+ wdioOpts.capabilities['appium:automationName'] = 'XCUITest';
288
+ } // merge user-provided BS options into the final options object
289
+
290
+
291
+ if (wdioOpts.capabilities['bstack:recordVideo']) {
292
+ bsOptions.video = wdioOpts.capabilities['bstack:recordVideo'];
293
+ delete wdioOpts.capabilities['bstack:recordVideo'];
294
+ }
295
+
296
+ if (wdioOpts.capabilities['bstack:local']) {
297
+ bsOptions.local = wdioOpts.capabilities['bstack:local'];
298
+ delete wdioOpts.capabilities['bstack:local'];
299
+ }
300
+
301
+ if (wdioOpts.capabilities['bstack:networkLogs']) {
302
+ bsOptions.networkLogs = wdioOpts.capabilities['bstack:networkLogs'];
303
+ delete wdioOpts.capabilities['bstack:networkLogs'];
304
+ }
305
+
306
+ if (wdioOpts.capabilities['bstack:debug']) {
307
+ bsOptions.debug = wdioOpts.capabilities['bstack:debug'];
308
+ delete wdioOpts.capabilities['bstack:debug'];
309
+ }
310
+
311
+ if (wdioOpts.capabilities['bstack:gpsLocation']) {
312
+ bsOptions.gpsLocation = wdioOpts.capabilities['bstack:gpsLocation'];
313
+ delete wdioOpts.capabilities['bstack:gpsLocation'];
314
+ }
315
+
316
+ if (wdioOpts.capabilities['bstack:buildName']) {
317
+ bsOptions.buildName = wdioOpts.capabilities['bstack:buildName'];
318
+ delete wdioOpts.capabilities['bstack:buildName'];
319
+ }
320
+
321
+ if (wdioOpts.capabilities['bstack:idleTimeout']) {
322
+ bsOptions.idleTimeout = wdioOpts.capabilities['bstack:idleTimeout'];
323
+ delete wdioOpts.capabilities['bstack:idleTimeout'];
324
+ }
325
+ }
268
326
  }
269
327
 
270
328
  if (wdioOpts.capabilities['bstack:options'] && wdioOpts.capabilities['bstack:options']['name']) {
@@ -704,4 +762,4 @@ class MobileModule extends _WebDriverModule.default {
704
762
  }
705
763
 
706
764
  exports.default = MobileModule;
707
- //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_modules/module-mob.js"],"names":["MODULE_NAME","DEFAULT_APPIUM_URL","DEFAULT_BROWSER_NAME","NO_SCREENSHOT_COMMANDS","ACTION_COMMANDS","DEFAULT_WAIT_TIMEOUT","MobileModule","WebDriverModule","constructor","options","context","rs","logger","modules","services","transactions","lastNavigationStartTime","networkRequests","helpers","appContext","_loadHelperFunctions","OxError","errHelper","waitForTimeout","name","getDriver","getCapabilities","caps","init","appiumUrl","isInitialized","reopenSession","debug","driver","reloadSession","_isInitialized","ctx","platformName","platformVersion","deviceName","browserName","automationName","udid","app","enableAppiumBehavior","useAppiumForWeb","collectDeviceLogs","appPackage","bundleId","toLowerCase","recordHAR","browser","performance","url","URL","parse","protocol","replace","host","hostname","port","parseInt","path","pathname","auth","split","wdioOpts","user","key","capabilities","logLevel","runner","waitforTimeout","connectionRetryTimeout","connectionRetryCount","provider","modUtils","determineProvider","PERFECTO","maxInstances","openDeviceTimeout","manufacturer","model","wdio","remote","seleniumBrowserTimeout","seleniumTimeout","perfectoExecutionContext","perfectoReporting","Perfecto","PerfectoExecutionContext","webdriver","executeScript","command","params","execute","reportingClient","PerfectoReportingClient","testStart","e","getAppiumInitError","getContext","setWebViewContext","BROWSERSTACK","setTimeout","overwriteWdioCommands","dispose","status","steps","Array","isArray","length","failedFinded","find","item","toUpperCase","testStop","Constants","results","passed","failed","_sendResultStatusToBrowserstack","deleteSession","includes","seleniumSessionTimeout","warn","transaction","toString","slice","global","_lastTransactionName","_isAction","_takeScreenshotSilent","error","takeScreenshot","retval","call","Promise","resolve","reject","waitUntilRetVal","waitUntil","images","pushImageToImages","fetchTitle","image","title","getTitle","textToImage","require","titleImage","generate","push","isWebViewContext","handles","getWindowHandles","handle","switchToWindow","mergedImage","direction","timeout","then","catch","err","_adjustAppiumLog","log","src","time","timestamp","msg","message","level","_iterationStart","_iterationEnd","type","errorHelper","errorCode","APPIUM_SESSION_TIMEOUT","logs","getDeviceLogs","collectBrowserLogs","getBrowserLogs","collectAppiumLogs","getAppiumLogs","logEntry","_getWdioLocator","locator","SCRIPT_ERROR","indexOf","platform","substr","getWdioLocator","matchPattern","getElement","getElements","getChildElement","getChildElements","setTimeoutImplicit","restoreTimeoutImplicit","assertArgument","assertArgumentNonEmptyString","assertArgumentNumber","assertArgumentNumberNonNegative","assertArgumentBool","assertArgumentBoolOptional","assertArgumentTimeout","assertContext","contextList","getLogTypes","requestBody","sessionId","method","json","rejectUnauthorized","body","res"],"mappings":"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","sourcesContent":["/*\r\n * Copyright (C) 2015-present CloudBeat Limited\r\n *\r\n * This program is free software: you can redistribute it and/or modify\r\n * it under the terms of the GNU General Public License as published by\r\n * the Free Software Foundation, either version 3 of the License, or\r\n * (at your option) any later version.\r\n */\r\n\r\n'use strict';\r\n/**\r\n * @name mob\r\n * @description Provides methods for mobile automation.\r\n * @sample **Locators:**  \r\n * \r\n * Native application locators for![](../../.gitbook/assets/android.png)  \r\n * * `/XPATH` - Locates element using an XPath 1.0 expression.\r\n * * `~ACCESSIBILITY_ID` - Locates element by its Accessibility Id.\r\n * * `id=ID` - Locates element by its id.\r\n * * `class=CLASS` - Locates element by its class.\r\n * * `text=TEXT` - Locates element by its visible text.\r\n * * `text-contains=TEXT` - Locates element whose visible text contains the specified string.\r\n * * `desc=DESCRIPTION` - Locates element by its description.\r\n * * `desc-contains=DESCRIPTION` - Locates element whose description contains the specified string.\r\n * * `scrollable` - Locates elements that are scrollable.  \r\n *  \r\n * Native application locators for![](../../.gitbook/assets/apple.png)  \r\n *  \r\n * * `/XPATH` - Locates element using an XPath 1.0 expression.\r\n * * `id=ID` - Locates element by its ID.\r\n * * `~ACCESSIBILITY_ID` - Locates element by its Accessibility Id.  \r\n * * `-ios predicate string:PREDICATE_STRING` - Locates element using a [predicate query](https://github.com/facebookarchive/WebDriverAgent/wiki/Predicate-Queries-Construction-Rules).  \r\n * * `-ios class chain:CLASS_CHAIN` - Locates element using a [class chain expression](https://github.com/facebookarchive/WebDriverAgent/wiki/Class-Chain-Queries-Construction-Rules).  \r\n *  \r\n * Hybrid![](../../.gitbook/assets/hybrid.png)  and Web![](../../.gitbook/assets/web.png)  application locators for![](../../.gitbook/assets/android.png)  ![](../../.gitbook/assets/apple.png)  \r\n *  \r\n * * `/XPATH` - Locates element using an XPath 1.0 expression.\r\n * * `id=ID` - Locates element by its id.\r\n * * `name=NAME` - Locates element by its name attribute.\r\n * * `tag=NAME` - Locates element by its tag name.\r\n * * `link=TEXT` - Locates anchor element whose text matches the given string.\r\n * * `link-contains=TEXT` - Locates anchor element whose text contains the given string.\r\n * * `css=CSS_SELECTOR` - Locates element using a CSS selector.\r\n * \r\n * **Pattern arguments:**\r\n * \r\n * Commands which expect a string matching pattern in their arguments, support following patterns unless specified otherwise:\r\n * \r\n * * `regex:PATTERN` - Match using regular expression.\r\n * * `PATTERN` - Verbatim matching.\r\n * \r\n */\r\nimport URL from 'url';\r\nimport * as wdio from 'webdriverio';\r\nimport WebDriverModule from '../core/WebDriverModule';\r\nimport modUtils from './utils';\r\nimport errHelper from '../errors/helper';\r\nimport OxError from '../errors/OxygenError';\r\nimport perfectoReporting from 'perfecto-reporting';\r\nimport request from 'request';\r\nimport mergeImages from '../lib/img-merge';\r\nimport errorHelper from '../errors/helper';\r\n\r\nconst MODULE_NAME = 'mob';\r\nconst DEFAULT_APPIUM_URL = 'http://localhost:4723/wd/hub';\r\nconst DEFAULT_BROWSER_NAME = 'default';\r\nconst NO_SCREENSHOT_COMMANDS = ['init', 'assertAlert'];\r\nconst ACTION_COMMANDS = ['open','tap','click','swipe','submit','setValue'];\r\nconst DEFAULT_WAIT_TIMEOUT = 60 * 1000;            // default 60s wait timeout\r\n\r\nexport default class MobileModule extends WebDriverModule {\r\n    constructor(options, context, rs, logger, modules, services) {\r\n        super(options, context, rs, logger, modules, services);\r\n        this.transactions = {};\r\n        this.lastNavigationStartTime = null;\r\n        this.networkRequests = null;\r\n        this.helpers = {};\r\n        this.appContext = 'NATIVE_APP';\r\n        this._loadHelperFunctions();\r\n        // support backward compatibility (some module commands might refer to this.OxError and this.errHelper)\r\n        this.OxError = OxError;\r\n        this.errHelper = errHelper;\r\n        // holds element operation timeout value\r\n        this.waitForTimeout = DEFAULT_WAIT_TIMEOUT;\r\n    }\r\n\r\n    get name() {\r\n        return MODULE_NAME;\r\n    }\r\n\r\n    /**\r\n     * @function getDriver\r\n     * @summary Returns the underlying WDIO driver.\r\n     * @return {Object} WDIO driver.\r\n     */\r\n    getDriver() {\r\n        return super.getDriver();\r\n    }\r\n\r\n    /**\r\n     * @function getCapabilities\r\n     * @summary Returns currently defined capabilities.\r\n     * @return {Object} Current capabilities object.\r\n     */\r\n    getCapabilities() {\r\n        return this.caps || super.getCapabilities();\r\n    }\r\n\r\n    /**\r\n     * @function init\r\n     * @summary Initializes a new Appium session.\r\n     * @param {String=} caps - Desired capabilities. If not specified capabilities will be taken from suite definition.\r\n     * @param {String=} appiumUrl - Remote Appium server URL (default: http://localhost:4723/wd/hub).\r\n     */\r\n    async init(caps, appiumUrl) {\r\n        // if reopenSession is true - reinitilize the module\r\n        if (this.isInitialized) {\r\n            if (this.options.reopenSession !== false) { // true or false if explisitly set. true on null or undefined.\r\n                this.logger.debug('reopenSession is true - reloading the session...');\r\n                this.driver.reloadSession();\r\n                this._isInitialized = true;\r\n            } else {\r\n                this.logger.debug('mob.init was called for already initialized module. reopenSession is false so the call is ignored.');\r\n            }\r\n            return;\r\n        }\r\n\r\n        // FIXME: this should be refactored\r\n        if (this.ctx.caps && this.ctx.caps['perfectoMobile:options']) {\r\n            if (caps) {\r\n                delete caps.platformName;\r\n                delete caps.platformVersion;\r\n                delete caps.deviceName;\r\n                delete caps.browserName;\r\n                delete caps.automationName;\r\n                delete caps.udid;\r\n\r\n                if (caps.app) {\r\n                    caps.enableAppiumBehavior = true;\r\n                } else {\r\n                    caps.useAppiumForWeb = true;\r\n                    caps.enableAppiumBehavior = true;\r\n                }\r\n            } else {\r\n                this.ctx.caps.useAppiumForWeb = true;\r\n                this.ctx.caps.enableAppiumBehavior = true;\r\n            }\r\n        }\r\n\r\n        if (!appiumUrl) {\r\n            appiumUrl = this.options.appiumUrl || DEFAULT_APPIUM_URL;\r\n        }\r\n\r\n        // merge capabilities from context and from init function argument, give preference to context-passed capabilities\r\n        this.caps = {};\r\n        if (this.ctx.caps) {\r\n            this.caps = { ...this.ctx.caps };\r\n        }\r\n        if (caps) {\r\n            this.caps = { ...this.caps, ...caps };\r\n        }\r\n\r\n        // make sure to clear the existing device logs, if collectDeviceLogs option is true (we want to include logs only relevant for this session)\r\n        if (this.options.collectDeviceLogs) {\r\n            this.caps['clearDeviceLogsOnStart'] = true;\r\n        }\r\n\r\n        // if both browserName and appPackage/app/bundleId were specified - assume we want to run the application and remove browserName\r\n        if (this.caps.browserName && (this.caps.appPackage || this.caps.app || this.caps.bundleId)) {\r\n            delete this.caps.browserName;\r\n        }\r\n        // if no appPackage/app/bundleId capability nor browserName are defined, assume we want to run the test against default browser\r\n        else if (!this.caps.browserName && !this.caps.appPackage && !this.caps.app && !this.caps.bundleId) {\r\n            this.caps.browserName = DEFAULT_BROWSER_NAME;\r\n        }\r\n        // webdriver expects lower case names\r\n        if (this.caps.browserName && typeof this.caps.browserName === 'string') {\r\n            this.caps.browserName = this.caps.browserName.toLowerCase();\r\n        }\r\n        // adjust capabilities to enable collecting browser and performance stats in Chrome \r\n        if (this.options.recordHAR && this.caps.browserName === 'chrome') {\r\n            this.caps['goog:loggingPrefs'] = {     // for ChromeDriver >= 75\r\n                browser: 'ALL',\r\n                performance: 'ALL'\r\n            };\r\n        }\r\n\r\n        // populate WDIO options\r\n        const url = URL.parse(appiumUrl);\r\n        const protocol = url.protocol.replace(/:$/, '');\r\n        const host = url.hostname;\r\n        const port = parseInt(url.port || (protocol === 'https' ? 443 : 80));\r\n        const path = url.pathname;\r\n\r\n        // auth is needed mostly for cloud providers such as LambdaTest\r\n        if (url.auth) {\r\n            const auth = url.auth.split(':');\r\n            this.options.wdioOpts = {\r\n                user: auth[0],\r\n                key: auth[1]\r\n            };\r\n        }\r\n\r\n        var wdioOpts = {\r\n            ...this.options.wdioOpts || {},\r\n            protocol: protocol,\r\n            hostname: host,\r\n            port: port,\r\n            path: path,\r\n            capabilities: this.caps,\r\n            logLevel: 'silent',\r\n            runner: 'repl',\r\n            waitforTimeout: 5000, // increase the default 3000\r\n            connectionRetryTimeout: 310*1000,\r\n            connectionRetryCount: 1\r\n        };\r\n\r\n        let provider = modUtils.determineProvider(wdioOpts);\r\n        let name = 'name';\r\n\r\n        if (provider === modUtils.provider.PERFECTO) {\r\n            wdioOpts.capabilities.maxInstances = 1;\r\n            wdioOpts.path = '/nexperience/perfectomobile/wd/hub';\r\n            wdioOpts.port = 80;\r\n            wdioOpts.protocol = 'http';\r\n            wdioOpts.openDeviceTimeout = 15;\r\n\r\n            delete wdioOpts.capabilities.manufacturer;\r\n            delete wdioOpts.capabilities.model;\r\n            delete wdioOpts.capabilities.browserName;\r\n            delete wdioOpts.capabilities.host;\r\n\r\n            name = wdioOpts.capabilities['perfectoMobile:options']['name'];\r\n            delete wdioOpts.capabilities['perfectoMobile:options'];\r\n        }\r\n\r\n        if (wdioOpts.capabilities['bstack:options'] && wdioOpts.capabilities['bstack:options']['name']) {\r\n            name = wdioOpts.capabilities['bstack:options']['name'];\r\n            delete wdioOpts.capabilities['bstack:options'];\r\n        }\r\n\r\n        this.wdioOpts = wdioOpts;\r\n\r\n        // init webdriver\r\n        try {\r\n            this.driver = await wdio.remote(wdioOpts);\r\n            this.driver.provider = provider;\r\n\r\n            if (this.options.seleniumBrowserTimeout) {\r\n                this.driver.seleniumBrowserTimeout = this.options.seleniumBrowserTimeout;\r\n            }\r\n\r\n            if (this.options.seleniumTimeout) {\r\n                this.driver.seleniumTimeout = this.options.seleniumTimeout;\r\n            }\r\n\r\n            if (provider === modUtils.provider.PERFECTO) {\r\n                const perfectoExecutionContext = await new perfectoReporting.Perfecto.PerfectoExecutionContext({\r\n                    webdriver: {\r\n                        executeScript: async (command, params) => {\r\n                            return await this.driver.execute(command, params);\r\n                        }\r\n                    }\r\n                });\r\n                this.reportingClient = new perfectoReporting.Perfecto.PerfectoReportingClient(perfectoExecutionContext);\r\n                await this.reportingClient.testStart(name);\r\n            }\r\n        } catch (e) {\r\n            throw errHelper.getAppiumInitError(e);\r\n        }\r\n\r\n        this.appContext = await this.driver.getContext();\r\n\r\n        // if we are running on Android 7+ emulator, and thus/or using a WebView Browser Tester -\r\n        // perform an actual appContext switch to WEB\r\n        // so Appium will delegate commands to Chrome Driver instead of Appium Driver\r\n        if (this.caps.browserName ===  'chromium-webview') {\r\n            await this.setWebViewContext();\r\n        }\r\n\r\n        if (provider === modUtils.provider.BROWSERSTACK) {\r\n            // ignore\r\n            // fails on browserstack\r\n        } else {\r\n            await this.driver.setTimeout({ 'implicit': this.waitForTimeout });\r\n        }\r\n\r\n        await modUtils.overwriteWdioCommands(this.driver);\r\n\r\n        super.init(this.driver);\r\n    }\r\n\r\n    /**\r\n     * @function dispose\r\n     * @summary Ends the current session.\r\n     * @param {String=} status - Test status, either `passed` or `failed`.\r\n     */\r\n    async dispose(status) {\r\n        if (!status) {\r\n            status = 'passed';\r\n\r\n            if (this.rs.steps && Array.isArray(this.rs.steps) && this.rs.steps.length > 0) {\r\n                const failedFinded = this.rs.steps.find((item) => item.status === 'failed');\r\n                if (failedFinded) {\r\n                    status = 'failed';\r\n                }\r\n            }\r\n        }\r\n\r\n        if (this.driver && this.isInitialized) {\r\n            status = status.toUpperCase();\r\n\r\n            if (this.driver.provider === modUtils.provider.PERFECTO) {\r\n                await this.reportingClient.testStop({\r\n                    status: status === 'PASSED' ?\r\n                                perfectoReporting.Constants.results.passed :\r\n                                perfectoReporting.Constants.results.failed\r\n                });\r\n            } else if (this.driver.provider === modUtils.provider.BROWSERSTACK) {\r\n                await this._sendResultStatusToBrowserstack(status);\r\n                await this.deleteSession();\r\n            }\r\n\r\n            try {\r\n                if (!['CANCELED', 'FAILED'].includes(status)) {\r\n                    if (this.seleniumSessionTimeout) {\r\n                        // ignore\r\n                        // deleteSession will take 5 min to call\r\n                    } else {\r\n                        await this.driver.deleteSession();\r\n                    }\r\n                }\r\n            } catch (e) {\r\n                this.logger.warn('Error disposing driver: ' + e);    // ignore any errors at disposal stage\r\n            }\r\n            this.driver = null;\r\n            this.lastNavigationStartTime = null;\r\n            super.dispose();\r\n        } else {\r\n            return;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Opens new transaction.\r\n     * @description The transaction will persist till a new one is opened. Transaction names must be unique.\r\n     * @function transaction\r\n     * @param {String} name - The transaction name.\r\n     * @for android, ios, hybrid, web\r\n     */\r\n    transaction(name) {\r\n        if (!name) {\r\n            return;\r\n        }\r\n        // just in case user passed a complex object by mistake\r\n        name = name.toString();\r\n\r\n        // limit the name length (since we can't store values larger than 512B in the database)\r\n        name = name.slice(0, 512);\r\n\r\n        global._lastTransactionName = name;\r\n    }\r\n\r\n    /*\r\n     * Private\r\n     */\r\n\r\n    _isAction(name) {\r\n        return ACTION_COMMANDS.includes(name);\r\n    }\r\n\r\n    _takeScreenshotSilent(name) {\r\n        if (!NO_SCREENSHOT_COMMANDS.includes(name)) {\r\n            let error;\r\n            try {\r\n                if (\r\n                    this.driver &&\r\n                    this.driver.takeScreenshot\r\n                ) {\r\n                    let retval;\r\n                    this.driver.call(() => {\r\n                        return new Promise((resolve, reject) => {\r\n                            const waitUntilRetVal = this.driver.waitUntil(async() => {\r\n                                try {\r\n                                    let images = [];\r\n\r\n                                    const pushImageToImages = async(fetchTitle = true) => {\r\n                                        const image = await this.driver.takeScreenshot();\r\n                                        if (fetchTitle) {\r\n                                            const title = await this.driver.getTitle();\r\n                                            if (title) {\r\n                                                const textToImage = require('../lib/text-to-image');\r\n                                                let titleImage = await textToImage.generate(title);\r\n                                                if (titleImage && typeof titleImage === 'string') {\r\n                                                    titleImage = titleImage.replace('data:image/png;base64,', '');\r\n                                                    images.push(titleImage);\r\n                                                }\r\n                                            }\r\n                                        }\r\n\r\n                                        images.push(image);\r\n                                    };\r\n\r\n                                    const isWebViewContext = await this.isWebViewContext();\r\n                                    if (isWebViewContext) {\r\n                                        // collect all (screenshot and title) images\r\n                                        const handles = await this.driver.getWindowHandles();\r\n                                        if (\r\n                                            handles &&\r\n                                            Array.isArray(handles) &&\r\n                                            handles.length > 0\r\n                                        ) {\r\n                                            for (const handle of handles) {\r\n                                                await this.driver.switchToWindow(handle);\r\n                                                await pushImageToImages();\r\n                                            }\r\n                                        }\r\n                                    } else {\r\n                                        await pushImageToImages(false);\r\n                                    }\r\n\r\n                                    // merge all images into one\r\n                                    const mergedImage = await mergeImages(images, { direction: true });\r\n                                    if (mergedImage && typeof mergedImage === 'string') {\r\n                                        retval = mergedImage.replace('data:image/jpeg;base64,', '');\r\n                                    }\r\n\r\n                                    return true;\r\n                                } catch (e) {\r\n                                    error = e;\r\n                                    return false;\r\n                                }\r\n                            },\r\n                            { timeout: 30*1000 });\r\n\r\n                            if (waitUntilRetVal && waitUntilRetVal.then) {\r\n                                waitUntilRetVal.then(() => {\r\n                                    resolve();\r\n                                }).catch((err) => {\r\n                                    reject(err);\r\n                                });\r\n                            } else {\r\n                                resolve();\r\n                            }\r\n                        });\r\n                    });\r\n\r\n                    if (error) {\r\n                        this.logger.error('Cannot get screenshot', error);\r\n                    }\r\n\r\n                    return retval;\r\n                }\r\n            } catch (e) {\r\n                this.logger.error('Cannot get screenshot', e);\r\n                if (error) {\r\n                    this.logger.error('Cannot get screenshot inner error', error);\r\n                }\r\n                // ignore\r\n            }\r\n        }\r\n    }\r\n\r\n    // _getLogs(name) {\r\n    //     if (!NO_LOGS_COMMANDS.includes(name)) {\r\n    //         return this.getLogs();\r\n    //     }\r\n    // }\r\n\r\n    _adjustAppiumLog(log, src) {\r\n        if (!log || typeof log !== 'object') {\r\n            return null;\r\n        }\r\n        // TODO: convert log.timestamp from the device time zone to the local one (so we can later correlate between steps and logs)        \r\n        return {\r\n            time: log.timestamp,\r\n            msg: log.message,\r\n            level: log.level,\r\n            src: src\r\n        };\r\n    }\r\n\r\n    _iterationStart() {\r\n        // clear transaction name saved in previous iteration if any\r\n        global._lastTransactionName = null;\r\n    }\r\n\r\n    async _iterationEnd(error) {\r\n        if (error && error.type === errorHelper.errorCode.APPIUM_SESSION_TIMEOUT) {\r\n            this.seleniumSessionTimeout = true;\r\n            return;\r\n        } else {\r\n            this.seleniumSessionTimeout = false;\r\n        }\r\n        // ignore the rest if mob module is not initialized\r\n        if (!this.isInitialized) {\r\n            return;\r\n        }\r\n        // collect all the device logs for this session\r\n        if (this.options.collectDeviceLogs) {\r\n            try {\r\n                const logs = await this.getDeviceLogs();\r\n                if (logs && Array.isArray(logs)) {\r\n                    for (let log of logs) {\r\n                        this.rs.logs.push(this._adjustAppiumLog(log, 'device'));\r\n                    }\r\n                }\r\n            }\r\n            catch (e) {\r\n                // ignore errors\r\n                this.logger.error('Cannot retrieve device logs.', e);\r\n            }\r\n        }\r\n\r\n        // collect all the browser logs for this session\r\n        if (this.options.collectBrowserLogs) {\r\n            try {\r\n                const logs = await this.getBrowserLogs();\r\n                if (logs && Array.isArray(logs)) {\r\n                    for (let log of logs) {\r\n                        this.rs.logs.push(this._adjustAppiumLog(log, 'browser'));\r\n                    }\r\n                }\r\n            }\r\n            catch (e) {\r\n                // ignore errors\r\n                this.logger.error('Cannot retrieve browser logs.', e);\r\n            }\r\n        }\r\n\r\n        // collect all Appium logs for this session\r\n        if (this.options.collectAppiumLogs) {\r\n            try {\r\n                const logs = this.getAppiumLogs();\r\n                if (logs && Array.isArray(logs)) {\r\n                    for (var logEntry of logs) {\r\n                        this.rs.logs.push(this._adjustAppiumLog(logEntry, 'appium'));\r\n                    }\r\n                }\r\n            }\r\n            catch (e) {\r\n                // ignore errors\r\n                this.logger.error('Cannot retrieve Appium logs.', e);\r\n            }\r\n        }\r\n    }\r\n\r\n    _getWdioLocator(locator) {\r\n        if (!locator) {\r\n            throw new OxError(errHelper.errorCode.SCRIPT_ERROR, 'Invalid argument - locator not specified');\r\n        }\r\n        if (typeof locator !== 'string') {\r\n            return locator;\r\n        }\r\n        if (locator.indexOf('/') === 0) {\r\n            return locator; // leave xpath locator as is\r\n        }\r\n        const platform = this.caps && this.caps.platformName ? this.caps.platformName.toLowerCase() : null;\r\n\r\n        if (this.appContext === 'NATIVE_APP' && platform === 'android') {\r\n            if (locator.indexOf('id=') === 0) {\r\n                // prepend package name if it's not specified\r\n                // NOTE: getCurrentPackage() seems to crash possibly due to a wdio bug. \r\n                //       so we get package name from caps instead.\r\n                locator = locator.substr('id='.length);\r\n                if (locator.indexOf(':id/') === -1) {\r\n                    locator = this.caps.appPackage + ':id/' + locator;\r\n                }\r\n                return 'android=new UiSelector().resourceId(\"' + locator + '\")';\r\n            } else if (locator.indexOf('class=') === 0)\r\n                return 'android=new UiSelector().className(\"' + locator.substr('class='.length) + '\")';\r\n            else if (locator.indexOf('text=') === 0)\r\n                return 'android=new UiSelector().text(\"' + locator.substr('text='.length) + '\")';\r\n            else if (locator.indexOf('text-contains=') === 0)\r\n                return 'android=new UiSelector().textContains(\"' + locator.substr('text-contains='.length) + '\")';\r\n            else if (locator.indexOf('desc=') === 0)\r\n                return 'android=new UiSelector().description(\"' + locator.substr('desc='.length) + '\")';\r\n            else if (locator.indexOf('desc-contains=') === 0)\r\n                return 'android=new UiSelector().descriptionContains(\"' + locator.substr('desc-contains='.length) + '\")';\r\n            else if (locator.indexOf('scrollable') === 0)\r\n                return 'android=new UiSelector().scrollable(true)';\r\n            else if (locator.indexOf('~') === 0)    // accessibility id\r\n                return locator;\r\n        } else if (this.appContext === 'NATIVE_APP' && platform === 'ios') {\r\n            if (locator.indexOf('~') === 0) // accessibility id\r\n                return locator;\r\n        } else if (this.appContext !== 'NATIVE_APP') {            // Hybrid or Web application\r\n            if (locator.indexOf('id=') === 0)\r\n                return '#' + locator.substr('id='.length);      // convert 'id=' to '#'\r\n            else if (locator.indexOf('name=') === 0)\r\n                return '[name=' + locator.substr('name='.length) + ']';\r\n            else if (locator.indexOf('link=') === 0)\r\n                return '=' + locator.substr('link='.length);\r\n            else if (locator.indexOf('link-contains=') === 0)\r\n                return '*=' + locator.substr('link='.length);\r\n            else if (locator.indexOf('css=') === 0)\r\n                return locator.substr('css='.length);           // in case of css, just remove css= prefix\r\n        }\r\n\r\n        return locator;\r\n    }\r\n\r\n    _loadHelperFunctions() {\r\n        this.helpers.getWdioLocator = this._getWdioLocator;\r\n        this.helpers.matchPattern = modUtils.matchPattern;\r\n        this.helpers.getElement = modUtils.getElement;\r\n        this.helpers.getElements = modUtils.getElements;\r\n        this.helpers.getChildElement = modUtils.getChildElement;\r\n        this.helpers.getChildElements = modUtils.getChildElements;\r\n        this.helpers.setTimeoutImplicit = modUtils.setTimeoutImplicit;\r\n        this.helpers.restoreTimeoutImplicit = modUtils.restoreTimeoutImplicit;\r\n        this.helpers.assertArgument = modUtils.assertArgument;\r\n        this.helpers.assertArgumentNonEmptyString = modUtils.assertArgumentNonEmptyString;\r\n        this.helpers.assertArgumentNumber = modUtils.assertArgumentNumber;\r\n        this.helpers.assertArgumentNumberNonNegative = modUtils.assertArgumentNumberNonNegative;\r\n        this.helpers.assertArgumentBool = modUtils.assertArgumentBool;\r\n        this.helpers.assertArgumentBoolOptional = modUtils.assertArgumentBoolOptional;\r\n        this.helpers.assertArgumentTimeout = modUtils.assertArgumentTimeout;\r\n        this.helpers.assertContext = modUtils.assertContext;\r\n        this.helpers.contextList = modUtils.contextList;\r\n        this.helpers.getLogTypes = modUtils.getLogTypes;\r\n    }\r\n\r\n    async deleteSession() {\r\n        try {\r\n            if (this.driver && this.driver.deleteSession) {\r\n                await this.driver.deleteSession();\r\n            }\r\n        } catch (e) {\r\n            this.logger.error('deleteSession error', e);\r\n        }\r\n    }\r\n\r\n    async _sendResultStatusToBrowserstack(status) {\r\n        return new Promise((resolve, reject) => {\r\n            const requestBody = {\r\n                status: status === 'PASSED' ? 'passed' : 'failed'\r\n            };\r\n\r\n            let options;\r\n\r\n            if (this.wdioOpts.capabilities.browserName) {\r\n                options = {\r\n                    url: `https://api.browserstack.com/automate/sessions/${this.driver.sessionId}.json`,\r\n                    method: 'PUT',\r\n                    json: true,\r\n                    rejectUnauthorized: false,\r\n                    body: requestBody,\r\n                    'auth': {\r\n                        'user': this.wdioOpts.user,\r\n                        'pass': this.wdioOpts.key,\r\n                        'sendImmediately': false\r\n                    },\r\n                };\r\n            } else {\r\n                options = {\r\n                    url: `https://api-cloud.browserstack.com/app-automate/sessions/${this.driver.sessionId}.json`,\r\n                    method: 'PUT',\r\n                    json: true,\r\n                    rejectUnauthorized: false,\r\n                    body: requestBody,\r\n                    'auth': {\r\n                        'user': this.wdioOpts.capabilities['browserstack.user'],\r\n                        'pass': this.wdioOpts.capabilities['browserstack.key'],\r\n                        'sendImmediately': false\r\n                    },\r\n                };\r\n            }\r\n\r\n            try {\r\n                request(options, (err, res, body) => {\r\n                    resolve();\r\n                });\r\n            } catch (e) {\r\n                this.logger.error('Unable to send result status to Browserstack: ' + e.toString());\r\n                resolve();\r\n            }\r\n        });\r\n    }\r\n}\r\n"]}
765
+ //# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_modules/module-mob.js"],"names":["MODULE_NAME","DEFAULT_APPIUM_URL","DEFAULT_BROWSER_NAME","NO_SCREENSHOT_COMMANDS","ACTION_COMMANDS","DEFAULT_WAIT_TIMEOUT","MobileModule","WebDriverModule","constructor","options","context","rs","logger","modules","services","transactions","lastNavigationStartTime","networkRequests","helpers","appContext","_loadHelperFunctions","OxError","errHelper","waitForTimeout","name","getDriver","getCapabilities","caps","init","appiumUrl","isInitialized","reopenSession","debug","driver","reloadSession","_isInitialized","ctx","platformName","platformVersion","deviceName","browserName","automationName","udid","app","enableAppiumBehavior","useAppiumForWeb","collectDeviceLogs","appPackage","bundleId","toLowerCase","recordHAR","browser","performance","url","URL","parse","protocol","replace","host","hostname","port","parseInt","path","pathname","auth","split","wdioOpts","user","key","capabilities","logLevel","runner","waitforTimeout","connectionRetryTimeout","connectionRetryCount","provider","modUtils","determineProvider","PERFECTO","maxInstances","openDeviceTimeout","manufacturer","model","BROWSERSTACK","bsOptions","osName","os","realMobile","video","local","networkLogs","gpsLocation","buildName","idleTimeout","wdio","remote","seleniumBrowserTimeout","seleniumTimeout","perfectoExecutionContext","perfectoReporting","Perfecto","PerfectoExecutionContext","webdriver","executeScript","command","params","execute","reportingClient","PerfectoReportingClient","testStart","e","getAppiumInitError","getContext","setWebViewContext","setTimeout","overwriteWdioCommands","dispose","status","steps","Array","isArray","length","failedFinded","find","item","toUpperCase","testStop","Constants","results","passed","failed","_sendResultStatusToBrowserstack","deleteSession","includes","seleniumSessionTimeout","warn","transaction","toString","slice","global","_lastTransactionName","_isAction","_takeScreenshotSilent","error","takeScreenshot","retval","call","Promise","resolve","reject","waitUntilRetVal","waitUntil","images","pushImageToImages","fetchTitle","image","title","getTitle","textToImage","require","titleImage","generate","push","isWebViewContext","handles","getWindowHandles","handle","switchToWindow","mergedImage","direction","timeout","then","catch","err","_adjustAppiumLog","log","src","time","timestamp","msg","message","level","_iterationStart","_iterationEnd","type","errorHelper","errorCode","APPIUM_SESSION_TIMEOUT","logs","getDeviceLogs","collectBrowserLogs","getBrowserLogs","collectAppiumLogs","getAppiumLogs","logEntry","_getWdioLocator","locator","SCRIPT_ERROR","indexOf","platform","substr","getWdioLocator","matchPattern","getElement","getElements","getChildElement","getChildElements","setTimeoutImplicit","restoreTimeoutImplicit","assertArgument","assertArgumentNonEmptyString","assertArgumentNumber","assertArgumentNumberNonNegative","assertArgumentBool","assertArgumentBoolOptional","assertArgumentTimeout","assertContext","contextList","getLogTypes","requestBody","sessionId","method","json","rejectUnauthorized","body","res"],"mappings":"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","sourcesContent":["/*\r\n * Copyright (C) 2015-present CloudBeat Limited\r\n *\r\n * This program is free software: you can redistribute it and/or modify\r\n * it under the terms of the GNU General Public License as published by\r\n * the Free Software Foundation, either version 3 of the License, or\r\n * (at your option) any later version.\r\n */\r\n\r\n'use strict';\r\n/**\r\n * @name mob\r\n * @description Provides methods for mobile automation.\r\n * @sample **Locators:**  \r\n * \r\n * Native application locators for![](../../.gitbook/assets/android.png)  \r\n * * `/XPATH` - Locates element using an XPath 1.0 expression.\r\n * * `~ACCESSIBILITY_ID` - Locates element by its Accessibility Id.\r\n * * `id=ID` - Locates element by its id.\r\n * * `class=CLASS` - Locates element by its class.\r\n * * `text=TEXT` - Locates element by its visible text.\r\n * * `text-contains=TEXT` - Locates element whose visible text contains the specified string.\r\n * * `desc=DESCRIPTION` - Locates element by its description.\r\n * * `desc-contains=DESCRIPTION` - Locates element whose description contains the specified string.\r\n * * `scrollable` - Locates elements that are scrollable.  \r\n *  \r\n * Native application locators for![](../../.gitbook/assets/apple.png)  \r\n *  \r\n * * `/XPATH` - Locates element using an XPath 1.0 expression.\r\n * * `id=ID` - Locates element by its ID.\r\n * * `~ACCESSIBILITY_ID` - Locates element by its Accessibility Id.  \r\n * * `-ios predicate string:PREDICATE_STRING` - Locates element using a [predicate query](https://github.com/facebookarchive/WebDriverAgent/wiki/Predicate-Queries-Construction-Rules).  \r\n * * `-ios class chain:CLASS_CHAIN` - Locates element using a [class chain expression](https://github.com/facebookarchive/WebDriverAgent/wiki/Class-Chain-Queries-Construction-Rules).  \r\n *  \r\n * Hybrid![](../../.gitbook/assets/hybrid.png)  and Web![](../../.gitbook/assets/web.png)  application locators for![](../../.gitbook/assets/android.png)  ![](../../.gitbook/assets/apple.png)  \r\n *  \r\n * * `/XPATH` - Locates element using an XPath 1.0 expression.\r\n * * `id=ID` - Locates element by its id.\r\n * * `name=NAME` - Locates element by its name attribute.\r\n * * `tag=NAME` - Locates element by its tag name.\r\n * * `link=TEXT` - Locates anchor element whose text matches the given string.\r\n * * `link-contains=TEXT` - Locates anchor element whose text contains the given string.\r\n * * `css=CSS_SELECTOR` - Locates element using a CSS selector.\r\n * \r\n * **Pattern arguments:**\r\n * \r\n * Commands which expect a string matching pattern in their arguments, support following patterns unless specified otherwise:\r\n * \r\n * * `regex:PATTERN` - Match using regular expression.\r\n * * `PATTERN` - Verbatim matching.\r\n * \r\n */\r\nimport URL from 'url';\r\nimport * as wdio from 'webdriverio';\r\nimport WebDriverModule from '../core/WebDriverModule';\r\nimport modUtils from './utils';\r\nimport errHelper from '../errors/helper';\r\nimport OxError from '../errors/OxygenError';\r\nimport perfectoReporting from 'perfecto-reporting';\r\nimport request from 'request';\r\nimport mergeImages from '../lib/img-merge';\r\nimport errorHelper from '../errors/helper';\r\n\r\nconst MODULE_NAME = 'mob';\r\nconst DEFAULT_APPIUM_URL = 'http://localhost:4723/wd/hub';\r\nconst DEFAULT_BROWSER_NAME = 'default';\r\nconst NO_SCREENSHOT_COMMANDS = ['init', 'assertAlert'];\r\nconst ACTION_COMMANDS = ['open','tap','click','swipe','submit','setValue'];\r\nconst DEFAULT_WAIT_TIMEOUT = 60 * 1000;            // default 60s wait timeout\r\n\r\nexport default class MobileModule extends WebDriverModule {\r\n    constructor(options, context, rs, logger, modules, services) {\r\n        super(options, context, rs, logger, modules, services);\r\n        this.transactions = {};\r\n        this.lastNavigationStartTime = null;\r\n        this.networkRequests = null;\r\n        this.helpers = {};\r\n        this.appContext = 'NATIVE_APP';\r\n        this._loadHelperFunctions();\r\n        // support backward compatibility (some module commands might refer to this.OxError and this.errHelper)\r\n        this.OxError = OxError;\r\n        this.errHelper = errHelper;\r\n        // holds element operation timeout value\r\n        this.waitForTimeout = DEFAULT_WAIT_TIMEOUT;\r\n    }\r\n\r\n    get name() {\r\n        return MODULE_NAME;\r\n    }\r\n\r\n    /**\r\n     * @function getDriver\r\n     * @summary Returns the underlying WDIO driver.\r\n     * @return {Object} WDIO driver.\r\n     */\r\n    getDriver() {\r\n        return super.getDriver();\r\n    }\r\n\r\n    /**\r\n     * @function getCapabilities\r\n     * @summary Returns currently defined capabilities.\r\n     * @return {Object} Current capabilities object.\r\n     */\r\n    getCapabilities() {\r\n        return this.caps || super.getCapabilities();\r\n    }\r\n\r\n    /**\r\n     * @function init\r\n     * @summary Initializes a new Appium session.\r\n     * @param {String=} caps - Desired capabilities. If not specified capabilities will be taken from suite definition.\r\n     * @param {String=} appiumUrl - Remote Appium server URL (default: http://localhost:4723/wd/hub).\r\n     */\r\n    async init(caps, appiumUrl) {\r\n        // if reopenSession is true - reinitilize the module\r\n        if (this.isInitialized) {\r\n            if (this.options.reopenSession !== false) { // true or false if explisitly set. true on null or undefined.\r\n                this.logger.debug('reopenSession is true - reloading the session...');\r\n                this.driver.reloadSession();\r\n                this._isInitialized = true;\r\n            } else {\r\n                this.logger.debug('mob.init was called for already initialized module. reopenSession is false so the call is ignored.');\r\n            }\r\n            return;\r\n        }\r\n\r\n        // FIXME: this should be refactored\r\n        if (this.ctx.caps && this.ctx.caps['perfectoMobile:options']) {\r\n            if (caps) {\r\n                delete caps.platformName;\r\n                delete caps.platformVersion;\r\n                delete caps.deviceName;\r\n                delete caps.browserName;\r\n                delete caps.automationName;\r\n                delete caps.udid;\r\n\r\n                if (caps.app) {\r\n                    caps.enableAppiumBehavior = true;\r\n                } else {\r\n                    caps.useAppiumForWeb = true;\r\n                    caps.enableAppiumBehavior = true;\r\n                }\r\n            } else {\r\n                this.ctx.caps.useAppiumForWeb = true;\r\n                this.ctx.caps.enableAppiumBehavior = true;\r\n            }\r\n        }\r\n\r\n        if (!appiumUrl) {\r\n            appiumUrl = this.options.appiumUrl || DEFAULT_APPIUM_URL;\r\n        }\r\n\r\n        // merge capabilities from context and from init function argument, give preference to context-passed capabilities\r\n        this.caps = {};\r\n        if (this.ctx.caps) {\r\n            this.caps = { ...this.ctx.caps };\r\n        }\r\n        if (caps) {\r\n            this.caps = { ...this.caps, ...caps };\r\n        }\r\n\r\n        // make sure to clear the existing device logs, if collectDeviceLogs option is true (we want to include logs only relevant for this session)\r\n        if (this.options.collectDeviceLogs) {\r\n            this.caps['clearDeviceLogsOnStart'] = true;\r\n        }\r\n\r\n        // if both browserName and appPackage/app/bundleId were specified - assume we want to run the application and remove browserName\r\n        if (this.caps.browserName && (this.caps.appPackage || this.caps.app || this.caps.bundleId)) {\r\n            delete this.caps.browserName;\r\n        }\r\n        // if no appPackage/app/bundleId capability nor browserName are defined, assume we want to run the test against default browser\r\n        else if (!this.caps.browserName && !this.caps.appPackage && !this.caps.app && !this.caps.bundleId) {\r\n            this.caps.browserName = DEFAULT_BROWSER_NAME;\r\n        }\r\n        // webdriver expects lower case names\r\n        if (this.caps.browserName && typeof this.caps.browserName === 'string') {\r\n            this.caps.browserName = this.caps.browserName.toLowerCase();\r\n        }\r\n        // adjust capabilities to enable collecting browser and performance stats in Chrome \r\n        if (this.options.recordHAR && this.caps.browserName === 'chrome') {\r\n            this.caps['goog:loggingPrefs'] = {     // for ChromeDriver >= 75\r\n                browser: 'ALL',\r\n                performance: 'ALL'\r\n            };\r\n        }\r\n\r\n        // populate WDIO options\r\n        const url = URL.parse(appiumUrl);\r\n        const protocol = url.protocol.replace(/:$/, '');\r\n        const host = url.hostname;\r\n        const port = parseInt(url.port || (protocol === 'https' ? 443 : 80));\r\n        const path = url.pathname;\r\n\r\n        // auth is needed mostly for cloud providers such as LambdaTest\r\n        if (url.auth) {\r\n            const auth = url.auth.split(':');\r\n            this.options.wdioOpts = {\r\n                user: auth[0],\r\n                key: auth[1]\r\n            };\r\n        }\r\n\r\n        var wdioOpts = {\r\n            ...this.options.wdioOpts || {},\r\n            protocol: protocol,\r\n            hostname: host,\r\n            port: port,\r\n            path: path,\r\n            capabilities: this.caps,\r\n            logLevel: 'silent',\r\n            runner: 'repl',\r\n            waitforTimeout: 5000, // increase the default 3000\r\n            connectionRetryTimeout: 310*1000,\r\n            connectionRetryCount: 1\r\n        };\r\n\r\n        let provider = modUtils.determineProvider(wdioOpts);\r\n        let name = 'name';\r\n\r\n        if (provider === modUtils.provider.PERFECTO) {\r\n            wdioOpts.capabilities.maxInstances = 1;\r\n            wdioOpts.path = '/nexperience/perfectomobile/wd/hub';\r\n            wdioOpts.port = 80;\r\n            wdioOpts.protocol = 'http';\r\n            wdioOpts.openDeviceTimeout = 15;\r\n\r\n            delete wdioOpts.capabilities.manufacturer;\r\n            delete wdioOpts.capabilities.model;\r\n            delete wdioOpts.capabilities.browserName;\r\n            delete wdioOpts.capabilities.host;\r\n\r\n            name = wdioOpts.capabilities['perfectoMobile:options']['name'];\r\n            delete wdioOpts.capabilities['perfectoMobile:options'];\r\n        }\r\n\r\n        else if (provider === modUtils.provider.BROWSERSTACK) {\r\n            const bsOptions = wdioOpts.capabilities['bstack:options'];\r\n            if (bsOptions) {\r\n                const deviceName = bsOptions.deviceName;\r\n                const osName = bsOptions.os;\r\n\r\n                if (deviceName) {\r\n                    bsOptions.realMobile = true;\r\n                    wdioOpts.capabilities['appium:deviceName'] = deviceName;\r\n                    delete bsOptions['deviceName'];\r\n                }\r\n\r\n                // set automationName Appium capability\r\n                if (osName && osName.toLowerCase() === 'android') {\r\n                    wdioOpts.capabilities.platformName = 'Android';\r\n                    wdioOpts.capabilities['appium:automationName'] = 'UIAutomator2';\r\n                }\r\n                else if (osName && osName.toLowerCase() === 'ios') {\r\n                    wdioOpts.capabilities.platformName = 'iOS';\r\n                    wdioOpts.capabilities['appium:automationName'] = 'XCUITest';\r\n                }\r\n\r\n                // merge user-provided BS options into the final options object\r\n                if (wdioOpts.capabilities['bstack:recordVideo']) {\r\n                    bsOptions.video = wdioOpts.capabilities['bstack:recordVideo'];\r\n                    delete wdioOpts.capabilities['bstack:recordVideo'];\r\n                }\r\n                if (wdioOpts.capabilities['bstack:local']) {\r\n                    bsOptions.local = wdioOpts.capabilities['bstack:local'];\r\n                    delete wdioOpts.capabilities['bstack:local'];\r\n                }\r\n                if (wdioOpts.capabilities['bstack:networkLogs']) {\r\n                    bsOptions.networkLogs = wdioOpts.capabilities['bstack:networkLogs'];\r\n                    delete wdioOpts.capabilities['bstack:networkLogs'];\r\n                }\r\n                if (wdioOpts.capabilities['bstack:debug']) {\r\n                    bsOptions.debug = wdioOpts.capabilities['bstack:debug'];\r\n                    delete wdioOpts.capabilities['bstack:debug'];\r\n                }\r\n                if (wdioOpts.capabilities['bstack:gpsLocation']) {\r\n                    bsOptions.gpsLocation = wdioOpts.capabilities['bstack:gpsLocation'];\r\n                    delete wdioOpts.capabilities['bstack:gpsLocation'];\r\n                }\r\n                if (wdioOpts.capabilities['bstack:buildName']) {\r\n                    bsOptions.buildName = wdioOpts.capabilities['bstack:buildName'];\r\n                    delete wdioOpts.capabilities['bstack:buildName'];\r\n                }\r\n                if (wdioOpts.capabilities['bstack:idleTimeout']) {\r\n                    bsOptions.idleTimeout = wdioOpts.capabilities['bstack:idleTimeout'];\r\n                    delete wdioOpts.capabilities['bstack:idleTimeout'];\r\n                }\r\n            }\r\n        }\r\n\r\n        if (wdioOpts.capabilities['bstack:options'] && wdioOpts.capabilities['bstack:options']['name']) {\r\n            name = wdioOpts.capabilities['bstack:options']['name'];\r\n            delete wdioOpts.capabilities['bstack:options'];\r\n        }\r\n\r\n        this.wdioOpts = wdioOpts;\r\n\r\n        // init webdriver\r\n        try {\r\n            this.driver = await wdio.remote(wdioOpts);\r\n\r\n            this.driver.provider = provider;\r\n\r\n            if (this.options.seleniumBrowserTimeout) {\r\n                this.driver.seleniumBrowserTimeout = this.options.seleniumBrowserTimeout;\r\n            }\r\n\r\n            if (this.options.seleniumTimeout) {\r\n                this.driver.seleniumTimeout = this.options.seleniumTimeout;\r\n            }\r\n\r\n            if (provider === modUtils.provider.PERFECTO) {\r\n                const perfectoExecutionContext = await new perfectoReporting.Perfecto.PerfectoExecutionContext({\r\n                    webdriver: {\r\n                        executeScript: async (command, params) => {\r\n                            return await this.driver.execute(command, params);\r\n                        }\r\n                    }\r\n                });\r\n                this.reportingClient = new perfectoReporting.Perfecto.PerfectoReportingClient(perfectoExecutionContext);\r\n                await this.reportingClient.testStart(name);\r\n            }\r\n        } catch (e) {\r\n            throw errHelper.getAppiumInitError(e);\r\n        }\r\n\r\n        this.appContext = await this.driver.getContext();\r\n\r\n        // if we are running on Android 7+ emulator, and thus/or using a WebView Browser Tester -\r\n        // perform an actual appContext switch to WEB\r\n        // so Appium will delegate commands to Chrome Driver instead of Appium Driver\r\n        if (this.caps.browserName ===  'chromium-webview') {\r\n            await this.setWebViewContext();\r\n        }\r\n\r\n        if (provider === modUtils.provider.BROWSERSTACK) {\r\n            // ignore\r\n            // fails on browserstack\r\n        } else {\r\n            await this.driver.setTimeout({ 'implicit': this.waitForTimeout });\r\n        }\r\n\r\n        await modUtils.overwriteWdioCommands(this.driver);\r\n\r\n        super.init(this.driver);\r\n    }\r\n\r\n    /**\r\n     * @function dispose\r\n     * @summary Ends the current session.\r\n     * @param {String=} status - Test status, either `passed` or `failed`.\r\n     */\r\n    async dispose(status) {\r\n        if (!status) {\r\n            status = 'passed';\r\n\r\n            if (this.rs.steps && Array.isArray(this.rs.steps) && this.rs.steps.length > 0) {\r\n                const failedFinded = this.rs.steps.find((item) => item.status === 'failed');\r\n                if (failedFinded) {\r\n                    status = 'failed';\r\n                }\r\n            }\r\n        }\r\n\r\n        if (this.driver && this.isInitialized) {\r\n            status = status.toUpperCase();\r\n\r\n            if (this.driver.provider === modUtils.provider.PERFECTO) {\r\n                await this.reportingClient.testStop({\r\n                    status: status === 'PASSED' ?\r\n                                perfectoReporting.Constants.results.passed :\r\n                                perfectoReporting.Constants.results.failed\r\n                });\r\n            } else if (this.driver.provider === modUtils.provider.BROWSERSTACK) {\r\n                await this._sendResultStatusToBrowserstack(status);\r\n                await this.deleteSession();\r\n            }\r\n\r\n            try {\r\n                if (!['CANCELED', 'FAILED'].includes(status)) {\r\n                    if (this.seleniumSessionTimeout) {\r\n                        // ignore\r\n                        // deleteSession will take 5 min to call\r\n                    } else {\r\n                        await this.driver.deleteSession();\r\n                    }\r\n                }\r\n            } catch (e) {\r\n                this.logger.warn('Error disposing driver: ' + e);    // ignore any errors at disposal stage\r\n            }\r\n            this.driver = null;\r\n            this.lastNavigationStartTime = null;\r\n            super.dispose();\r\n        } else {\r\n            return;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Opens new transaction.\r\n     * @description The transaction will persist till a new one is opened. Transaction names must be unique.\r\n     * @function transaction\r\n     * @param {String} name - The transaction name.\r\n     * @for android, ios, hybrid, web\r\n     */\r\n    transaction(name) {\r\n        if (!name) {\r\n            return;\r\n        }\r\n        // just in case user passed a complex object by mistake\r\n        name = name.toString();\r\n\r\n        // limit the name length (since we can't store values larger than 512B in the database)\r\n        name = name.slice(0, 512);\r\n\r\n        global._lastTransactionName = name;\r\n    }\r\n\r\n    /*\r\n     * Private\r\n     */\r\n\r\n    _isAction(name) {\r\n        return ACTION_COMMANDS.includes(name);\r\n    }\r\n\r\n    _takeScreenshotSilent(name) {\r\n        if (!NO_SCREENSHOT_COMMANDS.includes(name)) {\r\n            let error;\r\n            try {\r\n                if (\r\n                    this.driver &&\r\n                    this.driver.takeScreenshot\r\n                ) {\r\n                    let retval;\r\n                    this.driver.call(() => {\r\n                        return new Promise((resolve, reject) => {\r\n                            const waitUntilRetVal = this.driver.waitUntil(async() => {\r\n                                try {\r\n                                    let images = [];\r\n\r\n                                    const pushImageToImages = async(fetchTitle = true) => {\r\n                                        const image = await this.driver.takeScreenshot();\r\n                                        if (fetchTitle) {\r\n                                            const title = await this.driver.getTitle();\r\n                                            if (title) {\r\n                                                const textToImage = require('../lib/text-to-image');\r\n                                                let titleImage = await textToImage.generate(title);\r\n                                                if (titleImage && typeof titleImage === 'string') {\r\n                                                    titleImage = titleImage.replace('data:image/png;base64,', '');\r\n                                                    images.push(titleImage);\r\n                                                }\r\n                                            }\r\n                                        }\r\n\r\n                                        images.push(image);\r\n                                    };\r\n\r\n                                    const isWebViewContext = await this.isWebViewContext();\r\n                                    if (isWebViewContext) {\r\n                                        // collect all (screenshot and title) images\r\n                                        const handles = await this.driver.getWindowHandles();\r\n                                        if (\r\n                                            handles &&\r\n                                            Array.isArray(handles) &&\r\n                                            handles.length > 0\r\n                                        ) {\r\n                                            for (const handle of handles) {\r\n                                                await this.driver.switchToWindow(handle);\r\n                                                await pushImageToImages();\r\n                                            }\r\n                                        }\r\n                                    } else {\r\n                                        await pushImageToImages(false);\r\n                                    }\r\n\r\n                                    // merge all images into one\r\n                                    const mergedImage = await mergeImages(images, { direction: true });\r\n                                    if (mergedImage && typeof mergedImage === 'string') {\r\n                                        retval = mergedImage.replace('data:image/jpeg;base64,', '');\r\n                                    }\r\n\r\n                                    return true;\r\n                                } catch (e) {\r\n                                    error = e;\r\n                                    return false;\r\n                                }\r\n                            },\r\n                            { timeout: 30*1000 });\r\n\r\n                            if (waitUntilRetVal && waitUntilRetVal.then) {\r\n                                waitUntilRetVal.then(() => {\r\n                                    resolve();\r\n                                }).catch((err) => {\r\n                                    reject(err);\r\n                                });\r\n                            } else {\r\n                                resolve();\r\n                            }\r\n                        });\r\n                    });\r\n\r\n                    if (error) {\r\n                        this.logger.error('Cannot get screenshot', error);\r\n                    }\r\n\r\n                    return retval;\r\n                }\r\n            } catch (e) {\r\n                this.logger.error('Cannot get screenshot', e);\r\n                if (error) {\r\n                    this.logger.error('Cannot get screenshot inner error', error);\r\n                }\r\n                // ignore\r\n            }\r\n        }\r\n    }\r\n\r\n    // _getLogs(name) {\r\n    //     if (!NO_LOGS_COMMANDS.includes(name)) {\r\n    //         return this.getLogs();\r\n    //     }\r\n    // }\r\n\r\n    _adjustAppiumLog(log, src) {\r\n        if (!log || typeof log !== 'object') {\r\n            return null;\r\n        }\r\n        // TODO: convert log.timestamp from the device time zone to the local one (so we can later correlate between steps and logs)        \r\n        return {\r\n            time: log.timestamp,\r\n            msg: log.message,\r\n            level: log.level,\r\n            src: src\r\n        };\r\n    }\r\n\r\n    _iterationStart() {\r\n        // clear transaction name saved in previous iteration if any\r\n        global._lastTransactionName = null;\r\n    }\r\n\r\n    async _iterationEnd(error) {\r\n        if (error && error.type === errorHelper.errorCode.APPIUM_SESSION_TIMEOUT) {\r\n            this.seleniumSessionTimeout = true;\r\n            return;\r\n        } else {\r\n            this.seleniumSessionTimeout = false;\r\n        }\r\n        // ignore the rest if mob module is not initialized\r\n        if (!this.isInitialized) {\r\n            return;\r\n        }\r\n        // collect all the device logs for this session\r\n        if (this.options.collectDeviceLogs) {\r\n            try {\r\n                const logs = await this.getDeviceLogs();\r\n                if (logs && Array.isArray(logs)) {\r\n                    for (let log of logs) {\r\n                        this.rs.logs.push(this._adjustAppiumLog(log, 'device'));\r\n                    }\r\n                }\r\n            }\r\n            catch (e) {\r\n                // ignore errors\r\n                this.logger.error('Cannot retrieve device logs.', e);\r\n            }\r\n        }\r\n\r\n        // collect all the browser logs for this session\r\n        if (this.options.collectBrowserLogs) {\r\n            try {\r\n                const logs = await this.getBrowserLogs();\r\n                if (logs && Array.isArray(logs)) {\r\n                    for (let log of logs) {\r\n                        this.rs.logs.push(this._adjustAppiumLog(log, 'browser'));\r\n                    }\r\n                }\r\n            }\r\n            catch (e) {\r\n                // ignore errors\r\n                this.logger.error('Cannot retrieve browser logs.', e);\r\n            }\r\n        }\r\n\r\n        // collect all Appium logs for this session\r\n        if (this.options.collectAppiumLogs) {\r\n            try {\r\n                const logs = this.getAppiumLogs();\r\n                if (logs && Array.isArray(logs)) {\r\n                    for (var logEntry of logs) {\r\n                        this.rs.logs.push(this._adjustAppiumLog(logEntry, 'appium'));\r\n                    }\r\n                }\r\n            }\r\n            catch (e) {\r\n                // ignore errors\r\n                this.logger.error('Cannot retrieve Appium logs.', e);\r\n            }\r\n        }\r\n    }\r\n\r\n    _getWdioLocator(locator) {\r\n        if (!locator) {\r\n            throw new OxError(errHelper.errorCode.SCRIPT_ERROR, 'Invalid argument - locator not specified');\r\n        }\r\n        if (typeof locator !== 'string') {\r\n            return locator;\r\n        }\r\n        if (locator.indexOf('/') === 0) {\r\n            return locator; // leave xpath locator as is\r\n        }\r\n        const platform = this.caps && this.caps.platformName ? this.caps.platformName.toLowerCase() : null;\r\n\r\n        if (this.appContext === 'NATIVE_APP' && platform === 'android') {\r\n            if (locator.indexOf('id=') === 0) {\r\n                // prepend package name if it's not specified\r\n                // NOTE: getCurrentPackage() seems to crash possibly due to a wdio bug. \r\n                //       so we get package name from caps instead.\r\n                locator = locator.substr('id='.length);\r\n                if (locator.indexOf(':id/') === -1) {\r\n                    locator = this.caps.appPackage + ':id/' + locator;\r\n                }\r\n                return 'android=new UiSelector().resourceId(\"' + locator + '\")';\r\n            } else if (locator.indexOf('class=') === 0)\r\n                return 'android=new UiSelector().className(\"' + locator.substr('class='.length) + '\")';\r\n            else if (locator.indexOf('text=') === 0)\r\n                return 'android=new UiSelector().text(\"' + locator.substr('text='.length) + '\")';\r\n            else if (locator.indexOf('text-contains=') === 0)\r\n                return 'android=new UiSelector().textContains(\"' + locator.substr('text-contains='.length) + '\")';\r\n            else if (locator.indexOf('desc=') === 0)\r\n                return 'android=new UiSelector().description(\"' + locator.substr('desc='.length) + '\")';\r\n            else if (locator.indexOf('desc-contains=') === 0)\r\n                return 'android=new UiSelector().descriptionContains(\"' + locator.substr('desc-contains='.length) + '\")';\r\n            else if (locator.indexOf('scrollable') === 0)\r\n                return 'android=new UiSelector().scrollable(true)';\r\n            else if (locator.indexOf('~') === 0)    // accessibility id\r\n                return locator;\r\n        } else if (this.appContext === 'NATIVE_APP' && platform === 'ios') {\r\n            if (locator.indexOf('~') === 0) // accessibility id\r\n                return locator;\r\n        } else if (this.appContext !== 'NATIVE_APP') {            // Hybrid or Web application\r\n            if (locator.indexOf('id=') === 0)\r\n                return '#' + locator.substr('id='.length);      // convert 'id=' to '#'\r\n            else if (locator.indexOf('name=') === 0)\r\n                return '[name=' + locator.substr('name='.length) + ']';\r\n            else if (locator.indexOf('link=') === 0)\r\n                return '=' + locator.substr('link='.length);\r\n            else if (locator.indexOf('link-contains=') === 0)\r\n                return '*=' + locator.substr('link='.length);\r\n            else if (locator.indexOf('css=') === 0)\r\n                return locator.substr('css='.length);           // in case of css, just remove css= prefix\r\n        }\r\n\r\n        return locator;\r\n    }\r\n\r\n    _loadHelperFunctions() {\r\n        this.helpers.getWdioLocator = this._getWdioLocator;\r\n        this.helpers.matchPattern = modUtils.matchPattern;\r\n        this.helpers.getElement = modUtils.getElement;\r\n        this.helpers.getElements = modUtils.getElements;\r\n        this.helpers.getChildElement = modUtils.getChildElement;\r\n        this.helpers.getChildElements = modUtils.getChildElements;\r\n        this.helpers.setTimeoutImplicit = modUtils.setTimeoutImplicit;\r\n        this.helpers.restoreTimeoutImplicit = modUtils.restoreTimeoutImplicit;\r\n        this.helpers.assertArgument = modUtils.assertArgument;\r\n        this.helpers.assertArgumentNonEmptyString = modUtils.assertArgumentNonEmptyString;\r\n        this.helpers.assertArgumentNumber = modUtils.assertArgumentNumber;\r\n        this.helpers.assertArgumentNumberNonNegative = modUtils.assertArgumentNumberNonNegative;\r\n        this.helpers.assertArgumentBool = modUtils.assertArgumentBool;\r\n        this.helpers.assertArgumentBoolOptional = modUtils.assertArgumentBoolOptional;\r\n        this.helpers.assertArgumentTimeout = modUtils.assertArgumentTimeout;\r\n        this.helpers.assertContext = modUtils.assertContext;\r\n        this.helpers.contextList = modUtils.contextList;\r\n        this.helpers.getLogTypes = modUtils.getLogTypes;\r\n    }\r\n\r\n    async deleteSession() {\r\n        try {\r\n            if (this.driver && this.driver.deleteSession) {\r\n                await this.driver.deleteSession();\r\n            }\r\n        } catch (e) {\r\n            this.logger.error('deleteSession error', e);\r\n        }\r\n    }\r\n\r\n    async _sendResultStatusToBrowserstack(status) {\r\n        return new Promise((resolve, reject) => {\r\n            const requestBody = {\r\n                status: status === 'PASSED' ? 'passed' : 'failed'\r\n            };\r\n\r\n            let options;\r\n\r\n            if (this.wdioOpts.capabilities.browserName) {\r\n                options = {\r\n                    url: `https://api.browserstack.com/automate/sessions/${this.driver.sessionId}.json`,\r\n                    method: 'PUT',\r\n                    json: true,\r\n                    rejectUnauthorized: false,\r\n                    body: requestBody,\r\n                    'auth': {\r\n                        'user': this.wdioOpts.user,\r\n                        'pass': this.wdioOpts.key,\r\n                        'sendImmediately': false\r\n                    },\r\n                };\r\n            } else {\r\n                options = {\r\n                    url: `https://api-cloud.browserstack.com/app-automate/sessions/${this.driver.sessionId}.json`,\r\n                    method: 'PUT',\r\n                    json: true,\r\n                    rejectUnauthorized: false,\r\n                    body: requestBody,\r\n                    'auth': {\r\n                        'user': this.wdioOpts.capabilities['browserstack.user'],\r\n                        'pass': this.wdioOpts.capabilities['browserstack.key'],\r\n                        'sendImmediately': false\r\n                    },\r\n                };\r\n            }\r\n\r\n            try {\r\n                request(options, (err, res, body) => {\r\n                    resolve();\r\n                });\r\n            } catch (e) {\r\n                this.logger.error('Unable to send result status to Browserstack: ' + e.toString());\r\n                resolve();\r\n            }\r\n        });\r\n    }\r\n}\r\n"]}
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "oxygen-cli",
3
- "version": "1.37.2",
3
+ "version": "1.37.3",
4
4
  "description": "Automation framework for testing modern applications",
5
5
  "main": "./build/index.js",
6
6
  "bin": {