oxygen-cli 1.22.0 → 1.23.0
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 +19 -0
- package/build/ox_modules/module-db.js +26 -1
- package/build/ox_modules/module-http.js +19 -4
- package/build/ox_modules/module-mob/commands/getDeviceLogs.js +7 -3
- package/build/ox_modules/module-mob.js +2 -2
- package/build/ox_modules/module-web/commands/click.js +11 -1
- package/build/ox_services/service-devtools.js +8 -3
- package/package.json +22 -22
package/CHANGELOG.md
CHANGED
|
@@ -1,5 +1,24 @@
|
|
|
1
1
|
# CHANGELOG
|
|
2
2
|
|
|
3
|
+
## v1.23.0 (2022-06-15)
|
|
4
|
+
|
|
5
|
+
#### :tada: New Feature
|
|
6
|
+
* Add `db.callProcedure`.
|
|
7
|
+
|
|
8
|
+
#### :beetle: Bug Fix
|
|
9
|
+
* Fix test execution on Firefox.
|
|
10
|
+
* `http`: fix issue with "Cannot read property 'includes' of undefined" error when content-type header is missing in the response.
|
|
11
|
+
|
|
12
|
+
#### :house: Internal
|
|
13
|
+
* Bump dependencies.
|
|
14
|
+
|
|
15
|
+
## v1.22.1 (2022-04-28)
|
|
16
|
+
|
|
17
|
+
#### :beetle: Bug Fix
|
|
18
|
+
* Fix test execution on Firefox.
|
|
19
|
+
* Convert body to object in http.get when nessasry.
|
|
20
|
+
* Catch and ignore device logs retrieval issue, if cloud provider doesn't support this operation.
|
|
21
|
+
|
|
3
22
|
## v1.22.0 (2022-01-14)
|
|
4
23
|
|
|
5
24
|
#### :tada: New Feature
|
|
@@ -140,7 +140,32 @@ module.exports = function () {
|
|
|
140
140
|
await connection.close();
|
|
141
141
|
}
|
|
142
142
|
};
|
|
143
|
+
/**
|
|
144
|
+
* @summary Calls a stored procedure.
|
|
145
|
+
* @function callProcedure
|
|
146
|
+
* @param {String} name - Name of the procedure to call.
|
|
147
|
+
* @param {...Object} args - Procedure arguments. If procedure produces output parameters then these need to be specified using `undefined`.
|
|
148
|
+
* @return {Object} Procedure output if any.
|
|
149
|
+
* @example <caption>[javascript] Usage example</caption>
|
|
150
|
+
* // calls a procedure which expects two input parameters and one output parameter.
|
|
151
|
+
* var result = db.callProcedure('test', 3, 4, undefined);
|
|
152
|
+
* log.info(result);
|
|
153
|
+
*/
|
|
154
|
+
|
|
155
|
+
|
|
156
|
+
module.callProcedure = async function (name, ...args) {
|
|
157
|
+
await module._openDbConn();
|
|
158
|
+
|
|
159
|
+
try {
|
|
160
|
+
const querySyncRetval = await connection.callProcedure(null, null, name, [...args]);
|
|
161
|
+
return querySyncRetval;
|
|
162
|
+
} catch (e) {
|
|
163
|
+
throw new _OxygenError.default(errHelper.errorCode.DB_QUERY_ERROR, errHelper.getDbErrorMessage(e));
|
|
164
|
+
} finally {
|
|
165
|
+
await connection.close();
|
|
166
|
+
}
|
|
167
|
+
};
|
|
143
168
|
|
|
144
169
|
return module;
|
|
145
170
|
};
|
|
146
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_modules/module-db.js"],"names":["connection","errHelper","require","module","exports","isInitialized","_openDbConn","connString","OxError","errorCode","DB_CONNECTION_ERROR","db","e","ModuleUnavailableError","message","connect","getDbErrorMessage","setConnectionString","getScalar","query","resultSet","length","firstRow","firstCol","Object","keys","DB_QUERY_ERROR","close","executeQuery","querySyncRetval","executeNonQuery"],"mappings":";;;;AAoBA;;;;AApBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA,IAAIA,UAAJ;;AAGA,IAAIC,SAAS,GAAGC,OAAO,CAAC,kBAAD,CAAvB;;AAEAC,MAAM,CAACC,OAAP,GAAiB,YAAW;AACxB;AACAD,EAAAA,MAAM,CAACE,aAAP,GAAuB,YAAW;AAC9B,WAAO,IAAP;AACH,GAFD;;AAIAF,EAAAA,MAAM,CAACG,WAAP,GAAqB,kBAAiB;AAClC,QAAI,CAAC,KAAKC,UAAV,EAAsB;AAClB,YAAM,IAAIC,oBAAJ,CAAYP,SAAS,CAACQ,SAAV,CAAoBC,mBAAhC,EAAqD,+DAArD,CAAN;AACH;;AAED,QAAI;AACA;AACA,UAAIC,EAAJ;;AACA,UAAI;AACAA,QAAAA,EAAE,GAAGT,OAAO,CAAC,MAAD,CAAZ;AACH,OAFD,CAEE,OAAOU,CAAP,EAAU;AACR;AACA,cAAMC,sBAAsB,GAAGX,OAAO,CAAC,kCAAD,CAAtC;;AACA,cAAM,IAAIW,sBAAJ,CAA2B,+BAA6BD,CAAC,CAACE,OAA1D,CAAN;AACH;;AAEDd,MAAAA,UAAU,GAAG,MAAMW,EAAE,CAACI,OAAH,CAAW,KAAKR,UAAhB,CAAnB;AACH,KAZD,CAYE,OAAOK,CAAP,EAAU;AACR,YAAM,IAAIJ,oBAAJ,CAAYP,SAAS,CAACQ,SAAV,CAAoBC,mBAAhC,EAAqDT,SAAS,CAACe,iBAAV,CAA4BJ,CAA5B,CAArD,CAAN;AACH;AACJ,GApBD;AAsBA;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACIT,EAAAA,MAAM,CAACc,mBAAP,GAA6B,UAASV,UAAT,EAAqB;AAC9CJ,IAAAA,MAAM,CAACI,UAAP,GAAoBA,UAApB;AACH,GAFD;AAIA;AACJ;AACA;AACA;AACA;AACA;AACA;;;AACIJ,EAAAA,MAAM,CAACe,SAAP,GAAmB,gBAAeC,KAAf,EAAsB;AACrC,UAAMhB,MAAM,CAACG,WAAP,EAAN;;AACA,QAAI;AACA,UAAIc,SAAS,GAAG,MAAMpB,UAAU,CAACmB,KAAX,CAAiBA,KAAjB,CAAtB;;AACA,UAAIC,SAAS,CAACC,MAAV,KAAqB,CAAzB,EAA4B;AACxB,eAAO,IAAP;AACH;;AACD,UAAIC,QAAQ,GAAGF,SAAS,CAAC,CAAD,CAAxB;AACA,UAAIG,QAAQ,GAAGD,QAAQ,CAACE,MAAM,CAACC,IAAP,CAAYH,QAAZ,EAAsB,CAAtB,CAAD,CAAvB;AACA,aAAOC,QAAP;AACH,KARD,CAQE,OAAOX,CAAP,EAAU;AACR,YAAM,IAAIJ,oBAAJ,CAAYP,SAAS,CAACQ,SAAV,CAAoBiB,cAAhC,EAAgDzB,SAAS,CAACe,iBAAV,CAA4BJ,CAA5B,CAAhD,CAAN;AACH,KAVD,SAUU;AACN,YAAMZ,UAAU,CAAC2B,KAAX,EAAN;AACH;AACJ,GAfD;AAiBA;AACJ;AACA;AACA;AACA;AACA;;;AACIxB,EAAAA,MAAM,CAACyB,YAAP,GAAsB,gBAAeT,KAAf,EAAsB;AACxC,UAAMhB,MAAM,CAACG,WAAP,EAAN;;AACA,QAAI;AACA,YAAMuB,eAAe,GAAG,MAAM7B,UAAU,CAACmB,KAAX,CAAiBA,KAAjB,CAA9B;AACA,aAAOU,eAAP;AACH,KAHD,CAGE,OAAOjB,CAAP,EAAU;AACR,YAAM,IAAIJ,oBAAJ,CAAYP,SAAS,CAACQ,SAAV,CAAoBiB,cAAhC,EAAgDzB,SAAS,CAACe,iBAAV,CAA4BJ,CAA5B,CAAhD,CAAN;AACH,KALD,SAKU;AACN,YAAMZ,UAAU,CAAC2B,KAAX,EAAN;AACH;AACJ,GAVD;AAYA;AACJ;AACA;AACA;AACA;AACA;;;AACIxB,EAAAA,MAAM,CAAC2B,eAAP,GAAyB,gBAAeX,KAAf,EAAsB;AAC3C,UAAMhB,MAAM,CAACG,WAAP,EAAN;;AACA,QAAI;AACA,YAAMN,UAAU,CAACmB,KAAX,CAAiBA,KAAjB,CAAN;AACH,KAFD,CAEE,OAAOP,CAAP,EAAU;AACR,YAAM,IAAIJ,oBAAJ,CAAYP,SAAS,CAACQ,SAAV,CAAoBiB,cAAhC,EAAgDzB,SAAS,CAACe,iBAAV,CAA4BJ,CAA5B,CAAhD,CAAN;AACH,KAJD,SAIU;AACN,YAAMZ,UAAU,CAAC2B,KAAX,EAAN;AACH;AACJ,GATD;;AAWA,SAAOxB,MAAP;AACH,CAxGD","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/**\r\n * @name db\r\n * @description Provides methods for working with Data Bases through ODBC.\r\n * @note Before using this module, make sure to install `unixodbc`:  \r\n *   * Windows - Install `Windows SDK`  \r\n *   * OS X -  `brew install unixodbc`  \r\n *   * Linux - `sudo apt-get install unixodbc unixodbc-dev` or `sudo dnf install unixODBC unixODBC-devel`\r\n */\r\n\r\nvar connection;\r\n\r\nimport OxError from '../errors/OxygenError';\r\nvar errHelper = require('../errors/helper');\r\n\r\nmodule.exports = function() {\r\n    // FIXME: change setConnectionString to init and add hadnling in here\r\n    module.isInitialized = function() {\r\n        return true;\r\n    };\r\n\r\n    module._openDbConn = async function() {\r\n        if (!this.connString) {\r\n            throw new OxError(errHelper.errorCode.DB_CONNECTION_ERROR, 'No connection string specified. Use db.setConnectionString().');\r\n        }\r\n\r\n        try {\r\n            // ignore this module if odbc wasn't installed\r\n            var db;\r\n            try {\r\n                db = require('odbc');\r\n            } catch (e) {\r\n                // could happen only on unix due to missing unixodbc binaries\r\n                const ModuleUnavailableError = require('../errors/ModuleUnavailableError');\r\n                throw new ModuleUnavailableError('Unable to load DB module. '+e.message);\r\n            }\r\n\r\n            connection = await db.connect(this.connString);\r\n        } catch (e) {\r\n            throw new OxError(errHelper.errorCode.DB_CONNECTION_ERROR, errHelper.getDbErrorMessage(e));\r\n        }\r\n    };\r\n\r\n    /**\r\n    * @summary Sets DB connection string to be used by other methods.\r\n    * @description This method doesn't actually open the connection as it's opened/closed\r\n    *              automatically by query methods.  \r\n    *              Example connection strings:  \r\n    *              - `Driver={MySQL ODBC 5.3 UNICODE Driver};Server=localhost;Database=myDatabase;\r\n    *                User=myUsername;Password=myPassword;Option=3;`  \r\n    *              - `Driver={Oracle in instantclient_11_2};dbq=127.0.0.1:1521/XE;uid=myUsername;\r\n    *                pwd=myPassword;`\r\n    * @function setConnectionString\r\n    * @param {String} connString - ODBC connection string.\r\n    */\r\n    module.setConnectionString = function(connString) {\r\n        module.connString = connString;\r\n    };\r\n\r\n    /**\r\n     * @summary Executes SQL query and returns the first column of the first row in the result set.\r\n     * @function getScalar\r\n     * @param {String} query - The query to execute.\r\n     * @return {Object} The first column of the first row in the result set, or null if the result\r\n     *                  set is empty.\r\n     */\r\n    module.getScalar = async function(query) {\r\n        await module._openDbConn();\r\n        try {\r\n            var resultSet = await connection.query(query);\r\n            if (resultSet.length === 0) {\r\n                return null;\r\n            }\r\n            var firstRow = resultSet[0];\r\n            var firstCol = firstRow[Object.keys(firstRow)[0]];\r\n            return firstCol;\r\n        } catch (e) {\r\n            throw new OxError(errHelper.errorCode.DB_QUERY_ERROR, errHelper.getDbErrorMessage(e));\r\n        } finally {\r\n            await connection.close();\r\n        }\r\n    };\r\n\r\n    /**\r\n     * @summary Executes SQL query and returns the result set.\r\n     * @function executeQuery\r\n     * @param {String} query - The query to execute.\r\n     * @return {Object} The result set.\r\n     */\r\n    module.executeQuery = async function(query) {\r\n        await module._openDbConn();\r\n        try {\r\n            const querySyncRetval = await connection.query(query);\r\n            return querySyncRetval;\r\n        } catch (e) {\r\n            throw new OxError(errHelper.errorCode.DB_QUERY_ERROR, errHelper.getDbErrorMessage(e));\r\n        } finally {\r\n            await connection.close();\r\n        }\r\n    };\r\n\r\n    /**\r\n     * @summary Executes SQL statement.\r\n     * @description Any results from the query are discarded.\r\n     * @function executeNonQuery\r\n     * @param {String} query - The query to execute.\r\n     */\r\n    module.executeNonQuery = async function(query) {\r\n        await module._openDbConn();\r\n        try {\r\n            await connection.query(query);\r\n        } catch (e) {\r\n            throw new OxError(errHelper.errorCode.DB_QUERY_ERROR, errHelper.getDbErrorMessage(e));\r\n        } finally {\r\n            await connection.close();\r\n        }\r\n    };\r\n\r\n    return module;\r\n};\r\n"]}
|
|
171
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_modules/module-db.js"],"names":["connection","errHelper","require","module","exports","isInitialized","_openDbConn","connString","OxError","errorCode","DB_CONNECTION_ERROR","db","e","ModuleUnavailableError","message","connect","getDbErrorMessage","setConnectionString","getScalar","query","resultSet","length","firstRow","firstCol","Object","keys","DB_QUERY_ERROR","close","executeQuery","querySyncRetval","executeNonQuery","callProcedure","name","args"],"mappings":";;;;AAoBA;;;;AApBA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;AAEA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AAEA,IAAIA,UAAJ;;AAGA,IAAIC,SAAS,GAAGC,OAAO,CAAC,kBAAD,CAAvB;;AAEAC,MAAM,CAACC,OAAP,GAAiB,YAAW;AACxB;AACAD,EAAAA,MAAM,CAACE,aAAP,GAAuB,YAAW;AAC9B,WAAO,IAAP;AACH,GAFD;;AAIAF,EAAAA,MAAM,CAACG,WAAP,GAAqB,kBAAiB;AAClC,QAAI,CAAC,KAAKC,UAAV,EAAsB;AAClB,YAAM,IAAIC,oBAAJ,CAAYP,SAAS,CAACQ,SAAV,CAAoBC,mBAAhC,EAAqD,+DAArD,CAAN;AACH;;AAED,QAAI;AACA;AACA,UAAIC,EAAJ;;AACA,UAAI;AACAA,QAAAA,EAAE,GAAGT,OAAO,CAAC,MAAD,CAAZ;AACH,OAFD,CAEE,OAAOU,CAAP,EAAU;AACR;AACA,cAAMC,sBAAsB,GAAGX,OAAO,CAAC,kCAAD,CAAtC;;AACA,cAAM,IAAIW,sBAAJ,CAA2B,+BAA6BD,CAAC,CAACE,OAA1D,CAAN;AACH;;AAEDd,MAAAA,UAAU,GAAG,MAAMW,EAAE,CAACI,OAAH,CAAW,KAAKR,UAAhB,CAAnB;AACH,KAZD,CAYE,OAAOK,CAAP,EAAU;AACR,YAAM,IAAIJ,oBAAJ,CAAYP,SAAS,CAACQ,SAAV,CAAoBC,mBAAhC,EAAqDT,SAAS,CAACe,iBAAV,CAA4BJ,CAA5B,CAArD,CAAN;AACH;AACJ,GApBD;AAsBA;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACIT,EAAAA,MAAM,CAACc,mBAAP,GAA6B,UAASV,UAAT,EAAqB;AAC9CJ,IAAAA,MAAM,CAACI,UAAP,GAAoBA,UAApB;AACH,GAFD;AAIA;AACJ;AACA;AACA;AACA;AACA;AACA;;;AACIJ,EAAAA,MAAM,CAACe,SAAP,GAAmB,gBAAeC,KAAf,EAAsB;AACrC,UAAMhB,MAAM,CAACG,WAAP,EAAN;;AACA,QAAI;AACA,UAAIc,SAAS,GAAG,MAAMpB,UAAU,CAACmB,KAAX,CAAiBA,KAAjB,CAAtB;;AACA,UAAIC,SAAS,CAACC,MAAV,KAAqB,CAAzB,EAA4B;AACxB,eAAO,IAAP;AACH;;AACD,UAAIC,QAAQ,GAAGF,SAAS,CAAC,CAAD,CAAxB;AACA,UAAIG,QAAQ,GAAGD,QAAQ,CAACE,MAAM,CAACC,IAAP,CAAYH,QAAZ,EAAsB,CAAtB,CAAD,CAAvB;AACA,aAAOC,QAAP;AACH,KARD,CAQE,OAAOX,CAAP,EAAU;AACR,YAAM,IAAIJ,oBAAJ,CAAYP,SAAS,CAACQ,SAAV,CAAoBiB,cAAhC,EAAgDzB,SAAS,CAACe,iBAAV,CAA4BJ,CAA5B,CAAhD,CAAN;AACH,KAVD,SAUU;AACN,YAAMZ,UAAU,CAAC2B,KAAX,EAAN;AACH;AACJ,GAfD;AAiBA;AACJ;AACA;AACA;AACA;AACA;;;AACIxB,EAAAA,MAAM,CAACyB,YAAP,GAAsB,gBAAeT,KAAf,EAAsB;AACxC,UAAMhB,MAAM,CAACG,WAAP,EAAN;;AACA,QAAI;AACA,YAAMuB,eAAe,GAAG,MAAM7B,UAAU,CAACmB,KAAX,CAAiBA,KAAjB,CAA9B;AACA,aAAOU,eAAP;AACH,KAHD,CAGE,OAAOjB,CAAP,EAAU;AACR,YAAM,IAAIJ,oBAAJ,CAAYP,SAAS,CAACQ,SAAV,CAAoBiB,cAAhC,EAAgDzB,SAAS,CAACe,iBAAV,CAA4BJ,CAA5B,CAAhD,CAAN;AACH,KALD,SAKU;AACN,YAAMZ,UAAU,CAAC2B,KAAX,EAAN;AACH;AACJ,GAVD;AAYA;AACJ;AACA;AACA;AACA;AACA;;;AACIxB,EAAAA,MAAM,CAAC2B,eAAP,GAAyB,gBAAeX,KAAf,EAAsB;AAC3C,UAAMhB,MAAM,CAACG,WAAP,EAAN;;AACA,QAAI;AACA,YAAMN,UAAU,CAACmB,KAAX,CAAiBA,KAAjB,CAAN;AACH,KAFD,CAEE,OAAOP,CAAP,EAAU;AACR,YAAM,IAAIJ,oBAAJ,CAAYP,SAAS,CAACQ,SAAV,CAAoBiB,cAAhC,EAAgDzB,SAAS,CAACe,iBAAV,CAA4BJ,CAA5B,CAAhD,CAAN;AACH,KAJD,SAIU;AACN,YAAMZ,UAAU,CAAC2B,KAAX,EAAN;AACH;AACJ,GATD;AAWA;AACJ;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;AACA;;;AACIxB,EAAAA,MAAM,CAAC4B,aAAP,GAAuB,gBAAeC,IAAf,EAAqB,GAAGC,IAAxB,EAA8B;AACjD,UAAM9B,MAAM,CAACG,WAAP,EAAN;;AAEA,QAAI;AACA,YAAMuB,eAAe,GAAG,MAAM7B,UAAU,CAAC+B,aAAX,CAAyB,IAAzB,EAA+B,IAA/B,EAAqCC,IAArC,EAA2C,CAAC,GAAGC,IAAJ,CAA3C,CAA9B;AACA,aAAOJ,eAAP;AACH,KAHD,CAGE,OAAOjB,CAAP,EAAU;AACR,YAAM,IAAIJ,oBAAJ,CAAYP,SAAS,CAACQ,SAAV,CAAoBiB,cAAhC,EAAgDzB,SAAS,CAACe,iBAAV,CAA4BJ,CAA5B,CAAhD,CAAN;AACH,KALD,SAKU;AACN,YAAMZ,UAAU,CAAC2B,KAAX,EAAN;AACH;AACJ,GAXD;;AAaA,SAAOxB,MAAP;AACH,CAhID","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/**\r\n * @name db\r\n * @description Provides methods for working with Data Bases through ODBC.\r\n * @note Before using this module, make sure to install `unixodbc`:  \r\n *   * Windows - Install `Windows SDK`  \r\n *   * OS X -  `brew install unixodbc`  \r\n *   * Linux - `sudo apt-get install unixodbc unixodbc-dev` or `sudo dnf install unixODBC unixODBC-devel`\r\n */\r\n\r\nvar connection;\r\n\r\nimport OxError from '../errors/OxygenError';\r\nvar errHelper = require('../errors/helper');\r\n\r\nmodule.exports = function() {\r\n    // FIXME: change setConnectionString to init and add hadnling in here\r\n    module.isInitialized = function() {\r\n        return true;\r\n    };\r\n\r\n    module._openDbConn = async function() {\r\n        if (!this.connString) {\r\n            throw new OxError(errHelper.errorCode.DB_CONNECTION_ERROR, 'No connection string specified. Use db.setConnectionString().');\r\n        }\r\n\r\n        try {\r\n            // ignore this module if odbc wasn't installed\r\n            var db;\r\n            try {\r\n                db = require('odbc');\r\n            } catch (e) {\r\n                // could happen only on unix due to missing unixodbc binaries\r\n                const ModuleUnavailableError = require('../errors/ModuleUnavailableError');\r\n                throw new ModuleUnavailableError('Unable to load DB module. '+e.message);\r\n            }\r\n\r\n            connection = await db.connect(this.connString);\r\n        } catch (e) {\r\n            throw new OxError(errHelper.errorCode.DB_CONNECTION_ERROR, errHelper.getDbErrorMessage(e));\r\n        }\r\n    };\r\n\r\n    /**\r\n    * @summary Sets DB connection string to be used by other methods.\r\n    * @description This method doesn't actually open the connection as it's opened/closed\r\n    *              automatically by query methods.  \r\n    *              Example connection strings:  \r\n    *              - `Driver={MySQL ODBC 5.3 UNICODE Driver};Server=localhost;Database=myDatabase;\r\n    *                User=myUsername;Password=myPassword;Option=3;`  \r\n    *              - `Driver={Oracle in instantclient_11_2};dbq=127.0.0.1:1521/XE;uid=myUsername;\r\n    *                pwd=myPassword;`\r\n    * @function setConnectionString\r\n    * @param {String} connString - ODBC connection string.\r\n    */\r\n    module.setConnectionString = function(connString) {\r\n        module.connString = connString;\r\n    };\r\n\r\n    /**\r\n     * @summary Executes SQL query and returns the first column of the first row in the result set.\r\n     * @function getScalar\r\n     * @param {String} query - The query to execute.\r\n     * @return {Object} The first column of the first row in the result set, or null if the result\r\n     *                  set is empty.\r\n     */\r\n    module.getScalar = async function(query) {\r\n        await module._openDbConn();\r\n        try {\r\n            var resultSet = await connection.query(query);\r\n            if (resultSet.length === 0) {\r\n                return null;\r\n            }\r\n            var firstRow = resultSet[0];\r\n            var firstCol = firstRow[Object.keys(firstRow)[0]];\r\n            return firstCol;\r\n        } catch (e) {\r\n            throw new OxError(errHelper.errorCode.DB_QUERY_ERROR, errHelper.getDbErrorMessage(e));\r\n        } finally {\r\n            await connection.close();\r\n        }\r\n    };\r\n\r\n    /**\r\n     * @summary Executes SQL query and returns the result set.\r\n     * @function executeQuery\r\n     * @param {String} query - The query to execute.\r\n     * @return {Object} The result set.\r\n     */\r\n    module.executeQuery = async function(query) {\r\n        await module._openDbConn();\r\n        try {\r\n            const querySyncRetval = await connection.query(query);\r\n            return querySyncRetval;\r\n        } catch (e) {\r\n            throw new OxError(errHelper.errorCode.DB_QUERY_ERROR, errHelper.getDbErrorMessage(e));\r\n        } finally {\r\n            await connection.close();\r\n        }\r\n    };\r\n\r\n    /**\r\n     * @summary Executes SQL statement.\r\n     * @description Any results from the query are discarded.\r\n     * @function executeNonQuery\r\n     * @param {String} query - The query to execute.\r\n     */\r\n    module.executeNonQuery = async function(query) {\r\n        await module._openDbConn();\r\n        try {\r\n            await connection.query(query);\r\n        } catch (e) {\r\n            throw new OxError(errHelper.errorCode.DB_QUERY_ERROR, errHelper.getDbErrorMessage(e));\r\n        } finally {\r\n            await connection.close();\r\n        }\r\n    };\r\n\r\n    /**\r\n     * @summary Calls a stored procedure.\r\n     * @function callProcedure\r\n     * @param {String} name - Name of the procedure to call.\r\n     * @param {...Object} args - Procedure arguments. If procedure produces output parameters then these need to be specified using `undefined`.\r\n     * @return {Object} Procedure output if any.\r\n     * @example <caption>[javascript] Usage example</caption>\r\n     * // calls a procedure which expects two input parameters and one output parameter.\r\n     * var result = db.callProcedure('test', 3, 4, undefined);\r\n     * log.info(result);\r\n     */\r\n    module.callProcedure = async function(name, ...args) {\r\n        await module._openDbConn();\r\n\r\n        try {\r\n            const querySyncRetval = await connection.callProcedure(null, null, name, [...args]);\r\n            return querySyncRetval;\r\n        } catch (e) {\r\n            throw new OxError(errHelper.errorCode.DB_QUERY_ERROR, errHelper.getDbErrorMessage(e));\r\n        } finally {\r\n            await connection.close();\r\n        }\r\n    };\r\n\r\n    return module;\r\n};\r\n"]}
|
|
@@ -53,6 +53,7 @@ const DEFAULT_HTTP_OPTIONS = {
|
|
|
53
53
|
},
|
|
54
54
|
dnsLookupIpVersion: 'ipv4'
|
|
55
55
|
};
|
|
56
|
+
const CONTENT_TYPE_HEADER = 'content-type';
|
|
56
57
|
|
|
57
58
|
class HttpModule extends _OxygenModule.default {
|
|
58
59
|
constructor(options, context, rs, logger, modules, services) {
|
|
@@ -444,7 +445,7 @@ class HttpModule extends _OxygenModule.default {
|
|
|
444
445
|
decomp.on('data', data => {
|
|
445
446
|
result.body = data.toString();
|
|
446
447
|
|
|
447
|
-
if (result.headers[
|
|
448
|
+
if (result.headers[CONTENT_TYPE_HEADER] && result.headers[CONTENT_TYPE_HEADER].includes('application/json')) {
|
|
448
449
|
try {
|
|
449
450
|
result.body = JSON.parse(result.body);
|
|
450
451
|
} catch (e) {// if parsing fails just return the original string
|
|
@@ -456,7 +457,7 @@ class HttpModule extends _OxygenModule.default {
|
|
|
456
457
|
});
|
|
457
458
|
})();
|
|
458
459
|
} else {
|
|
459
|
-
if (result.headers[
|
|
460
|
+
if (result.headers[CONTENT_TYPE_HEADER] && result.headers[CONTENT_TYPE_HEADER].includes('application/json')) {
|
|
460
461
|
try {
|
|
461
462
|
result.body = JSON.parse(result.body);
|
|
462
463
|
} catch (e) {// if parsing fails just return the original string
|
|
@@ -471,13 +472,27 @@ class HttpModule extends _OxygenModule.default {
|
|
|
471
472
|
this._lastResponse = result;
|
|
472
473
|
|
|
473
474
|
if (result instanceof Error) {
|
|
475
|
+
let body = null;
|
|
476
|
+
|
|
477
|
+
if (result.response && result.response.body) {
|
|
478
|
+
body = result.response.body;
|
|
479
|
+
|
|
480
|
+
if (typeof body === 'string') {
|
|
481
|
+
try {
|
|
482
|
+
body = JSON.parse(body);
|
|
483
|
+
} catch (e) {
|
|
484
|
+
body = result.response.body;
|
|
485
|
+
}
|
|
486
|
+
}
|
|
487
|
+
}
|
|
488
|
+
|
|
474
489
|
result = {
|
|
475
490
|
errorMessage: result.message,
|
|
476
491
|
headers: result.response ? result.response.headers : null,
|
|
477
492
|
statusCode: result.response ? result.response.statusCode : null,
|
|
478
493
|
statusMessage: result.response ? result.response.statusMessage : null,
|
|
479
494
|
rawBody: result.response ? result.response.rawBody : null,
|
|
480
|
-
body:
|
|
495
|
+
body: body
|
|
481
496
|
};
|
|
482
497
|
} else {
|
|
483
498
|
result = {
|
|
@@ -504,4 +519,4 @@ class HttpModule extends _OxygenModule.default {
|
|
|
504
519
|
}
|
|
505
520
|
|
|
506
521
|
exports.default = HttpModule;
|
|
507
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_modules/module-http.js"],"names":["MODULE_NAME","RESPONSE_TIMEOUT","DAFAULT_HTTP2","DEFAULT_HTTP_OPTIONS","decompress","responseType","timeout","lookup","connect","secureConnect","socket","send","response","http2","https","rejectUnauthorized","dnsLookupIpVersion","HttpModule","OxygenModule","constructor","options","context","rs","logger","modules","services","_alwaysInitialized","_lastResponse","_baseUrl","_userHttpOptions","_isInitialized","name","setOptions","opts","deflateRaw","setProxy","url","bootstrap","require","parse","parsedUrl","hostname","OxError","errHelper","errorCode","HTTP_ERROR","port","protocol","global","GLOBAL_AGENT","HTTP_PROXY","get","headers","httpOpts","method","_httpRequestSync","post","data","resolvedData","_resolveData","put","patch","delete","getResponse","getResponseBody","body","getResponseHeaders","getResponseUrl","assertText","pattern","ASSERT_ERROR","respContent","JSON","stringify","modUtils","matchPattern","assertResponseTime","maxTime","Error","assertHeader","headerName","headerValuePattern","length","toLowerCase","actualHeaderValue","assertCookie","cookieName","cookieValuePattern","assertStatus","codeList","Array","isArray","statusCode","includes","assertStatusOk","transaction","_lastTransactionName","dataResolver","Object","assertCircular","json","result","zlib","decomp","createInflateRaw","write","Promise","resolve","reject","on","toString","e","errorMessage","message","statusMessage","rawBody","httpVersion","upgrade","timings","requestUrl","redirectUrls","isFromCache","ip","retryCount"],"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/**\r\n * @name http\r\n * @description Provides methods for working with HTTP(S)\r\n */\r\nimport got from 'got';\r\nimport OxygenModule from '../core/OxygenModule';\r\nimport OxError from '../errors/OxygenError';\r\nimport errHelper from '../errors/helper';\r\nimport modUtils from './utils';\r\n\r\nconst MODULE_NAME = 'http';\r\nconst RESPONSE_TIMEOUT = 1000 * 60;   // in ms\r\nconst DAFAULT_HTTP2 = false;\r\nconst DEFAULT_HTTP_OPTIONS = {\r\n    decompress: true,\r\n    responseType: 'text',\r\n    timeout: {\r\n        lookup: 1000,\r\n        connect: 500,\r\n        secureConnect: 500,\r\n        socket: 100000,\r\n        send: 100000,\r\n        response: RESPONSE_TIMEOUT\r\n    },\r\n    http2: DAFAULT_HTTP2,\r\n    https: {\r\n        rejectUnauthorized: false\r\n    },\r\n    dnsLookupIpVersion: 'ipv4'\r\n};\r\n\r\nexport default class HttpModule extends OxygenModule {\r\n    constructor(options, context, rs, logger, modules, services) {\r\n        super(options, context, rs, logger, modules, services);\r\n        this._alwaysInitialized = true;\r\n        this._lastResponse = null;\r\n        this._baseUrl = null;\r\n        this._userHttpOptions = {};\r\n        // pre-initialize the module\r\n        this._isInitialized = true;\r\n    }\r\n\r\n    /*\r\n     * @summary Gets module name\r\n     * @function name\r\n     * @return {String} Constant value \"http\".\r\n     */\r\n    get name() {\r\n        return MODULE_NAME;\r\n    }\r\n\r\n    /**\r\n     * @summary Sets user defined HTTP options (such as proxy, decompress and etc.)\r\n     * @function setOptions\r\n     * @param {Object} opts - HTTP request options object, see [Request Options](https://github.com/sindresorhus/got/blob/main/documentation/2-options.md). \r\n     * In addition to the options listed in the linked document, 'deflateRaw' option can be used when server returns Deflate-compressed stream without headers.\r\n     */\r\n    setOptions(opts) {\r\n        this._userHttpOptions = opts;\r\n        if (opts.deflateRaw) {\r\n            this._userHttpOptions.decompress = false;     // decompress=true in default options so we override it\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Sets proxy url to be used for connections with the service.\r\n     * @function setProxy\r\n     * @param {String} url - Proxy server URL. Not passing this argument will reset the proxy settings.\r\n     */\r\n    setProxy(url) {\r\n        if (url) {\r\n            const {\r\n                bootstrap\r\n            } = require('global-agent');\r\n\r\n            const { parse } = require('url');\r\n            const parsedUrl = parse(url);\r\n\r\n            if (!parsedUrl.hostname) {\r\n                throw new OxError(errHelper.errorCode.HTTP_ERROR, 'Hostname in undefined');\r\n            }\r\n            if (!parsedUrl.port) {\r\n                throw new OxError(errHelper.errorCode.HTTP_ERROR, 'Port in undefined');\r\n            }\r\n            if (!parsedUrl.protocol) {\r\n                throw new OxError(errHelper.errorCode.HTTP_ERROR, 'Protocol in undefined');\r\n            }\r\n\r\n            bootstrap();\r\n            global.GLOBAL_AGENT.HTTP_PROXY = url;\r\n        } else {\r\n            global.GLOBAL_AGENT.HTTP_PROXY = false;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Performs HTTP GET\r\n     * @function get\r\n     * @param {String} url - URL.\r\n     * @param {Object=} headers - HTTP headers.\r\n     * @return {Object} Response object.\r\n     * @example <caption>[javascript] Usage example</caption>\r\n     * // Basic usage example:\r\n     * var response = http.get(\r\n     * 'https://api.github.com/repos/oxygenhq/oxygen-ide/releases', \r\n     * {\r\n     *   'Accept-Encoding': 'gzip, deflate',\r\n     *   'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:86.0) Gecko/20100101 Firefox/86.0'\r\n     * });\r\n     * log.info(response.body);\r\n     *\r\n     * // If server returns Deflate-compressed stream without headers, `deflateRaw` can be used to decompress the content.\r\n     * http.setOptions({\r\n     *   deflateRaw: true\r\n     * });\r\n     * var response = http.get('https://FOO.BAR');\r\n     * log.info(response.body);\r\n     */\r\n    async get(url, headers) {\r\n        const httpOpts = {\r\n            ...DEFAULT_HTTP_OPTIONS,\r\n            ...this._userHttpOptions || {},\r\n            url: url,\r\n            method: 'GET',\r\n            headers: headers || {}\r\n        };\r\n        return await this._httpRequestSync(httpOpts);\r\n    }\r\n\r\n    /**\r\n     * @summary Performs HTTP POST\r\n     * @function post\r\n     * @param {String} url - URL.\r\n     * @param {Object} data - Data.\r\n     * @param {Object=} headers - HTTP headers.\r\n     * @return {Object} Response object.\r\n     */\r\n    async post(url, data, headers) {\r\n        const resolvedData = this._resolveData(data);\r\n\r\n        const httpOpts = {\r\n            ...DEFAULT_HTTP_OPTIONS,\r\n            ...this._userHttpOptions || {},\r\n            url: url,\r\n            method: 'POST',\r\n            headers: headers || {},\r\n            ...resolvedData\r\n        };\r\n        return await this._httpRequestSync(httpOpts);\r\n    }\r\n\r\n    /**\r\n     * @summary Performs HTTP PUT\r\n     * @function put\r\n     * @param {String} url - URL.\r\n     * @param {Object} data - Data.\r\n     * @param {Object=} headers - HTTP headers.\r\n     * @return {Object} Response object.\r\n     */\r\n    async put(url, data, headers) {\r\n        const resolvedData = this._resolveData(data);\r\n\r\n        const httpOpts = {\r\n            ...DEFAULT_HTTP_OPTIONS,\r\n            ...this._userHttpOptions || {},\r\n            url: url,\r\n            method: 'PUT',\r\n            headers: headers || {},\r\n            ...resolvedData\r\n        };\r\n        return await this._httpRequestSync(httpOpts);\r\n    }\r\n\r\n    /**\r\n     * @summary Performs HTTP PATCH\r\n     * @function patch\r\n     * @param {String} url - URL.\r\n     * @param {Object} data - Data.\r\n     * @param {Object=} headers - HTTP headers.\r\n     * @return {Object} Response object.\r\n     */\r\n    async patch(url, data, headers) {\r\n        const resolvedData = this._resolveData(data);\r\n\r\n        const httpOpts = {\r\n            ...DEFAULT_HTTP_OPTIONS,\r\n            ...this._userHttpOptions || {},\r\n            url: url,\r\n            method: 'PATCH',\r\n            headers: headers || {},\r\n            ...resolvedData\r\n        };\r\n        return await this._httpRequestSync(httpOpts);\r\n    }\r\n\r\n    /**\r\n     * @summary Performs HTTP DELETE\r\n     * @function delete\r\n     * @param {String} url - URL.\r\n     * @param {Object=} headers - HTTP headers.\r\n     * @param {Object} data - Data.\r\n     * @return {Object} Response object.\r\n     */\r\n    async delete(url, headers, data) {\r\n        const resolvedData = this._resolveData(data);\r\n        const httpOpts = {\r\n            ...DEFAULT_HTTP_OPTIONS,\r\n            ...this._userHttpOptions || {},\r\n            url: url,\r\n            method: 'DELETE',\r\n            headers: headers || {},\r\n            ...resolvedData\r\n        };\r\n        return await this._httpRequestSync(httpOpts);\r\n    }\r\n\r\n    /**\r\n     * @summary Returns last response object\r\n     * @function getResponse\r\n     * @return {Object} Response object.\r\n     */\r\n    getResponse() {\r\n        return this._lastResponse;\r\n    }\r\n\r\n    /**\r\n     * @summary Returns last response body\r\n     * @function getResponseBody\r\n     * @return {String} Response body.\r\n     */\r\n    getResponseBody() {\r\n        return this._lastResponse && this._lastResponse.body ? this._lastResponse.body : null;\r\n    }\r\n\r\n    /**\r\n     * @summary Returns response headers\r\n     * @function getResponseHeaders\r\n     * @return {Object} Response headers.\r\n     */\r\n    getResponseHeaders() {\r\n        if (!this._lastResponse) {\r\n            return null;\r\n        }\r\n        return this._lastResponse.headers;\r\n    }\r\n\r\n    /**\r\n     * @summary Returns response URL\r\n     * @function getResponseUrl\r\n     * @return {String} Response URL.\r\n     */\r\n    getResponseUrl() {\r\n        if (!this._lastResponse) {\r\n            return null;\r\n        }\r\n        return this._lastResponse.url;\r\n    }\r\n\r\n    /**\r\n     * @summary Assert whether the specified pattern is present in the response body.\r\n     * @function assertText\r\n     * @param {String} pattern - Pattern to assert.\r\n     */\r\n    assertText(pattern) {\r\n        if (!this._lastResponse) {\r\n            return false;\r\n        }\r\n        if (!this._lastResponse.body) {\r\n            throw new OxError(errHelper.errorCode.ASSERT_ERROR, 'Response body is empty');\r\n        }\r\n        const respContent = typeof this._lastResponse.body === 'string' ? this._lastResponse.body : JSON.stringify(this._lastResponse.body);\r\n        if (!modUtils.matchPattern(respContent, pattern)) {\r\n            throw new OxError(errHelper.errorCode.ASSERT_ERROR, `Expected HTTP response content to match: \"${pattern}\" but got: \"${respContent}\"`);\r\n        }\r\n        return true;\r\n    }\r\n\r\n    /**\r\n     * @summary Assert response time\r\n     * @function assertResponseTime\r\n     * @param {Number} maxTime - Maximum response time in milliseconds.\r\n     */\r\n    assertResponseTime(maxTime) {\r\n        throw new Error('Not implemented');\r\n    }\r\n\r\n    /**\r\n     * @summary Assert if HTTP header is presented in the response\r\n     * @function assertHeader\r\n     * @param {String} headerName - A HTTP header name.\r\n     * @param {String=} headerValuePattern - An optional HTTP header value pattern.\r\n     */\r\n    assertHeader(headerName, headerValuePattern = null) {\r\n        if (!headerName || typeof headerName !== 'string' || headerName.length == 0) {\r\n            return false;\r\n        }\r\n        headerName = headerName.toLowerCase();\r\n        const headers = this._lastResponse.headers;\r\n        if (!headers[headerName]) {\r\n            throw new OxError(errHelper.errorCode.ASSERT_ERROR, 'Expected HTTP header \"${headerName}\" to be present');\r\n        }\r\n        else if (headerValuePattern && typeof headerValuePattern === 'string') {\r\n            const actualHeaderValue = headers[headerName];\r\n            if (!modUtils.matchPattern(actualHeaderValue, headerValuePattern)) {\r\n                throw new OxError(errHelper.errorCode.ASSERT_ERROR, `Expected HTTP header \"${headerName}\" value to match: \"${headerValuePattern}\" but got: \"${actualHeaderValue}\"`);\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Assert if HTTP cookie is presented in the response\r\n     * @function assertCookie\r\n     * @param {String} cookieName - A HTTP cookie name.\r\n     * @param {String=} cookieValuePattern - An optional HTTP cookie value pattern.\r\n     */\r\n    assertCookie(cookieName, cookieValuePattern) {\r\n        throw new Error('Not implemented');\r\n    }\r\n\r\n    /**\r\n     * @summary Assert the last HTTP response's status code\r\n     * @function assertStatus\r\n     * @param {Number|Array} codeList - A single status code or a list of codes.\r\n     */\r\n    assertStatus(codeList) {\r\n        if (!this._lastResponse || !codeList) {\r\n            return false;\r\n        }\r\n        // if we got a single value, then convert it to an array\r\n        if (!Array.isArray(codeList)) {\r\n            codeList = [codeList];\r\n        }\r\n        const statusCode = this._lastResponse.statusCode;\r\n        if (!codeList.includes(statusCode)) {\r\n            throw new OxError(errHelper.errorCode.ASSERT_ERROR, `Expected HTTP status to be: \"${codeList}\" but got: \"${statusCode}\"`);\r\n        }\r\n        return true;\r\n    }\r\n\r\n    /**\r\n     * @summary Assert HTTP 200 OK status\r\n     * @function assertStatusOk\r\n     */\r\n    assertStatusOk() {\r\n        return this.assertStatus(200);\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\r\n     *              unique.\r\n     * @function transaction\r\n     * @param {String} name - The transaction name.\r\n     */\r\n    async transaction(name) {\r\n        global._lastTransactionName = name;\r\n    }\r\n\r\n    _resolveData(data) {\r\n        const dataResolver = {};\r\n\r\n        if (data instanceof Object) {\r\n            modUtils.assertCircular(data);\r\n            dataResolver.json = data;\r\n        } else {\r\n            dataResolver.body = data;\r\n        }\r\n\r\n        return dataResolver;\r\n    }\r\n\r\n    async _httpRequestSync(httpOpts) {\r\n        let result;\r\n\r\n        try {\r\n            result = await got(httpOpts);\r\n            if (httpOpts.deflateRaw && result.headers['content-encoding'] === 'deflate') {\r\n                const zlib = require('zlib');\r\n                const decomp = zlib.createInflateRaw();\r\n                decomp.write(result.body);\r\n                await (() => {\r\n                    return new Promise((resolve, reject) => {\r\n                        decomp.on('data', (data) => {\r\n                            result.body = data.toString();\r\n                            if (result.headers['content-type'].includes('application/json')) {\r\n                                try {\r\n                                    result.body = JSON.parse(result.body);\r\n                                } catch (e) {\r\n                                    // if parsing fails just return the original string\r\n                                }\r\n                            }\r\n                            resolve();\r\n                        });\r\n                    });\r\n                })();\r\n            } else {\r\n                if (result.headers['content-type'].includes('application/json')) {\r\n                    try {\r\n                        result.body = JSON.parse(result.body);\r\n                    } catch (e) {\r\n                        // if parsing fails just return the original string\r\n                    }\r\n                }\r\n            }\r\n\r\n        } catch (e) {\r\n            result = e;\r\n        }\r\n\r\n        // store last response to allow further assertions and validations\r\n        this._lastResponse = result;\r\n\r\n        if (result instanceof Error) {\r\n            result = {\r\n                errorMessage: result.message,\r\n                headers: result.response ? result.response.headers : null,\r\n                statusCode: result.response ? result.response.statusCode : null,\r\n                statusMessage: result.response ? result.response.statusMessage : null,\r\n                rawBody: result.response ? result.response.rawBody : null,\r\n                body: result.response ? result.response.body : null\r\n            };\r\n        } else {\r\n            result = {\r\n                httpVersion: result.httpVersion,\r\n                headers: result.headers,\r\n                upgrade: result.upgrade,\r\n                url: result.url,\r\n                method: result.method,\r\n                statusCode: result.statusCode,\r\n                statusMessage: result.statusMessage,\r\n                timings: result.timings,\r\n                requestUrl: result.requestUrl,\r\n                redirectUrls: result.redirectUrls,\r\n                isFromCache: result.isFromCache,\r\n                ip: result.ip,\r\n                retryCount: result.retryCount,\r\n                body: result.body\r\n            };\r\n        }\r\n\r\n        return result;\r\n    }\r\n}"]}
|
|
522
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_modules/module-http.js"],"names":["MODULE_NAME","RESPONSE_TIMEOUT","DAFAULT_HTTP2","DEFAULT_HTTP_OPTIONS","decompress","responseType","timeout","lookup","connect","secureConnect","socket","send","response","http2","https","rejectUnauthorized","dnsLookupIpVersion","CONTENT_TYPE_HEADER","HttpModule","OxygenModule","constructor","options","context","rs","logger","modules","services","_alwaysInitialized","_lastResponse","_baseUrl","_userHttpOptions","_isInitialized","name","setOptions","opts","deflateRaw","setProxy","url","bootstrap","require","parse","parsedUrl","hostname","OxError","errHelper","errorCode","HTTP_ERROR","port","protocol","global","GLOBAL_AGENT","HTTP_PROXY","get","headers","httpOpts","method","_httpRequestSync","post","data","resolvedData","_resolveData","put","patch","delete","getResponse","getResponseBody","body","getResponseHeaders","getResponseUrl","assertText","pattern","ASSERT_ERROR","respContent","JSON","stringify","modUtils","matchPattern","assertResponseTime","maxTime","Error","assertHeader","headerName","headerValuePattern","length","toLowerCase","actualHeaderValue","assertCookie","cookieName","cookieValuePattern","assertStatus","codeList","Array","isArray","statusCode","includes","assertStatusOk","transaction","_lastTransactionName","dataResolver","Object","assertCircular","json","result","zlib","decomp","createInflateRaw","write","Promise","resolve","reject","on","toString","e","errorMessage","message","statusMessage","rawBody","httpVersion","upgrade","timings","requestUrl","redirectUrls","isFromCache","ip","retryCount"],"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/**\r\n * @name http\r\n * @description Provides methods for working with HTTP(S)\r\n */\r\nimport got from 'got';\r\nimport OxygenModule from '../core/OxygenModule';\r\nimport OxError from '../errors/OxygenError';\r\nimport errHelper from '../errors/helper';\r\nimport modUtils from './utils';\r\n\r\nconst MODULE_NAME = 'http';\r\nconst RESPONSE_TIMEOUT = 1000 * 60;   // in ms\r\nconst DAFAULT_HTTP2 = false;\r\nconst DEFAULT_HTTP_OPTIONS = {\r\n    decompress: true,\r\n    responseType: 'text',\r\n    timeout: {\r\n        lookup: 1000,\r\n        connect: 500,\r\n        secureConnect: 500,\r\n        socket: 100000,\r\n        send: 100000,\r\n        response: RESPONSE_TIMEOUT\r\n    },\r\n    http2: DAFAULT_HTTP2,\r\n    https: {\r\n        rejectUnauthorized: false\r\n    },\r\n    dnsLookupIpVersion: 'ipv4'\r\n};\r\nconst CONTENT_TYPE_HEADER = 'content-type';\r\n\r\nexport default class HttpModule extends OxygenModule {\r\n    constructor(options, context, rs, logger, modules, services) {\r\n        super(options, context, rs, logger, modules, services);\r\n        this._alwaysInitialized = true;\r\n        this._lastResponse = null;\r\n        this._baseUrl = null;\r\n        this._userHttpOptions = {};\r\n        // pre-initialize the module\r\n        this._isInitialized = true;\r\n    }\r\n\r\n    /*\r\n     * @summary Gets module name\r\n     * @function name\r\n     * @return {String} Constant value \"http\".\r\n     */\r\n    get name() {\r\n        return MODULE_NAME;\r\n    }\r\n\r\n    /**\r\n     * @summary Sets user defined HTTP options (such as proxy, decompress and etc.)\r\n     * @function setOptions\r\n     * @param {Object} opts - HTTP request options object, see [Request Options](https://github.com/sindresorhus/got/blob/main/documentation/2-options.md). \r\n     * In addition to the options listed in the linked document, 'deflateRaw' option can be used when server returns Deflate-compressed stream without headers.\r\n     */\r\n    setOptions(opts) {\r\n        this._userHttpOptions = opts;\r\n        if (opts.deflateRaw) {\r\n            this._userHttpOptions.decompress = false;     // decompress=true in default options so we override it\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Sets proxy url to be used for connections with the service.\r\n     * @function setProxy\r\n     * @param {String} url - Proxy server URL. Not passing this argument will reset the proxy settings.\r\n     */\r\n    setProxy(url) {\r\n        if (url) {\r\n            const {\r\n                bootstrap\r\n            } = require('global-agent');\r\n\r\n            const { parse } = require('url');\r\n            const parsedUrl = parse(url);\r\n\r\n            if (!parsedUrl.hostname) {\r\n                throw new OxError(errHelper.errorCode.HTTP_ERROR, 'Hostname in undefined');\r\n            }\r\n            if (!parsedUrl.port) {\r\n                throw new OxError(errHelper.errorCode.HTTP_ERROR, 'Port in undefined');\r\n            }\r\n            if (!parsedUrl.protocol) {\r\n                throw new OxError(errHelper.errorCode.HTTP_ERROR, 'Protocol in undefined');\r\n            }\r\n\r\n            bootstrap();\r\n            global.GLOBAL_AGENT.HTTP_PROXY = url;\r\n        } else {\r\n            global.GLOBAL_AGENT.HTTP_PROXY = false;\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Performs HTTP GET\r\n     * @function get\r\n     * @param {String} url - URL.\r\n     * @param {Object=} headers - HTTP headers.\r\n     * @return {Object} Response object.\r\n     * @example <caption>[javascript] Usage example</caption>\r\n     * // Basic usage example:\r\n     * var response = http.get(\r\n     * 'https://api.github.com/repos/oxygenhq/oxygen-ide/releases', \r\n     * {\r\n     *   'Accept-Encoding': 'gzip, deflate',\r\n     *   'User-Agent': 'Mozilla/5.0 (Windows NT 10.0; Win64; x64; rv:86.0) Gecko/20100101 Firefox/86.0'\r\n     * });\r\n     * log.info(response.body);\r\n     *\r\n     * // If server returns Deflate-compressed stream without headers, `deflateRaw` can be used to decompress the content.\r\n     * http.setOptions({\r\n     *   deflateRaw: true\r\n     * });\r\n     * var response = http.get('https://FOO.BAR');\r\n     * log.info(response.body);\r\n     */\r\n    async get(url, headers) {\r\n        const httpOpts = {\r\n            ...DEFAULT_HTTP_OPTIONS,\r\n            ...this._userHttpOptions || {},\r\n            url: url,\r\n            method: 'GET',\r\n            headers: headers || {}\r\n        };\r\n        return await this._httpRequestSync(httpOpts);\r\n    }\r\n\r\n    /**\r\n     * @summary Performs HTTP POST\r\n     * @function post\r\n     * @param {String} url - URL.\r\n     * @param {Object} data - Data.\r\n     * @param {Object=} headers - HTTP headers.\r\n     * @return {Object} Response object.\r\n     */\r\n    async post(url, data, headers) {\r\n        const resolvedData = this._resolveData(data);\r\n\r\n        const httpOpts = {\r\n            ...DEFAULT_HTTP_OPTIONS,\r\n            ...this._userHttpOptions || {},\r\n            url: url,\r\n            method: 'POST',\r\n            headers: headers || {},\r\n            ...resolvedData\r\n        };\r\n        return await this._httpRequestSync(httpOpts);\r\n    }\r\n\r\n    /**\r\n     * @summary Performs HTTP PUT\r\n     * @function put\r\n     * @param {String} url - URL.\r\n     * @param {Object} data - Data.\r\n     * @param {Object=} headers - HTTP headers.\r\n     * @return {Object} Response object.\r\n     */\r\n    async put(url, data, headers) {\r\n        const resolvedData = this._resolveData(data);\r\n\r\n        const httpOpts = {\r\n            ...DEFAULT_HTTP_OPTIONS,\r\n            ...this._userHttpOptions || {},\r\n            url: url,\r\n            method: 'PUT',\r\n            headers: headers || {},\r\n            ...resolvedData\r\n        };\r\n        return await this._httpRequestSync(httpOpts);\r\n    }\r\n\r\n    /**\r\n     * @summary Performs HTTP PATCH\r\n     * @function patch\r\n     * @param {String} url - URL.\r\n     * @param {Object} data - Data.\r\n     * @param {Object=} headers - HTTP headers.\r\n     * @return {Object} Response object.\r\n     */\r\n    async patch(url, data, headers) {\r\n        const resolvedData = this._resolveData(data);\r\n\r\n        const httpOpts = {\r\n            ...DEFAULT_HTTP_OPTIONS,\r\n            ...this._userHttpOptions || {},\r\n            url: url,\r\n            method: 'PATCH',\r\n            headers: headers || {},\r\n            ...resolvedData\r\n        };\r\n        return await this._httpRequestSync(httpOpts);\r\n    }\r\n\r\n    /**\r\n     * @summary Performs HTTP DELETE\r\n     * @function delete\r\n     * @param {String} url - URL.\r\n     * @param {Object=} headers - HTTP headers.\r\n     * @param {Object} data - Data.\r\n     * @return {Object} Response object.\r\n     */\r\n    async delete(url, headers, data) {\r\n        const resolvedData = this._resolveData(data);\r\n        const httpOpts = {\r\n            ...DEFAULT_HTTP_OPTIONS,\r\n            ...this._userHttpOptions || {},\r\n            url: url,\r\n            method: 'DELETE',\r\n            headers: headers || {},\r\n            ...resolvedData\r\n        };\r\n        return await this._httpRequestSync(httpOpts);\r\n    }\r\n\r\n    /**\r\n     * @summary Returns last response object\r\n     * @function getResponse\r\n     * @return {Object} Response object.\r\n     */\r\n    getResponse() {\r\n        return this._lastResponse;\r\n    }\r\n\r\n    /**\r\n     * @summary Returns last response body\r\n     * @function getResponseBody\r\n     * @return {String} Response body.\r\n     */\r\n    getResponseBody() {\r\n        return this._lastResponse && this._lastResponse.body ? this._lastResponse.body : null;\r\n    }\r\n\r\n    /**\r\n     * @summary Returns response headers\r\n     * @function getResponseHeaders\r\n     * @return {Object} Response headers.\r\n     */\r\n    getResponseHeaders() {\r\n        if (!this._lastResponse) {\r\n            return null;\r\n        }\r\n        return this._lastResponse.headers;\r\n    }\r\n\r\n    /**\r\n     * @summary Returns response URL\r\n     * @function getResponseUrl\r\n     * @return {String} Response URL.\r\n     */\r\n    getResponseUrl() {\r\n        if (!this._lastResponse) {\r\n            return null;\r\n        }\r\n        return this._lastResponse.url;\r\n    }\r\n\r\n    /**\r\n     * @summary Assert whether the specified pattern is present in the response body.\r\n     * @function assertText\r\n     * @param {String} pattern - Pattern to assert.\r\n     */\r\n    assertText(pattern) {\r\n        if (!this._lastResponse) {\r\n            return false;\r\n        }\r\n        if (!this._lastResponse.body) {\r\n            throw new OxError(errHelper.errorCode.ASSERT_ERROR, 'Response body is empty');\r\n        }\r\n        const respContent = typeof this._lastResponse.body === 'string' ? this._lastResponse.body : JSON.stringify(this._lastResponse.body);\r\n        if (!modUtils.matchPattern(respContent, pattern)) {\r\n            throw new OxError(errHelper.errorCode.ASSERT_ERROR, `Expected HTTP response content to match: \"${pattern}\" but got: \"${respContent}\"`);\r\n        }\r\n        return true;\r\n    }\r\n\r\n    /**\r\n     * @summary Assert response time\r\n     * @function assertResponseTime\r\n     * @param {Number} maxTime - Maximum response time in milliseconds.\r\n     */\r\n    assertResponseTime(maxTime) {\r\n        throw new Error('Not implemented');\r\n    }\r\n\r\n    /**\r\n     * @summary Assert if HTTP header is presented in the response\r\n     * @function assertHeader\r\n     * @param {String} headerName - A HTTP header name.\r\n     * @param {String=} headerValuePattern - An optional HTTP header value pattern.\r\n     */\r\n    assertHeader(headerName, headerValuePattern = null) {\r\n        if (!headerName || typeof headerName !== 'string' || headerName.length == 0) {\r\n            return false;\r\n        }\r\n        headerName = headerName.toLowerCase();\r\n        const headers = this._lastResponse.headers;\r\n        if (!headers[headerName]) {\r\n            throw new OxError(errHelper.errorCode.ASSERT_ERROR, 'Expected HTTP header \"${headerName}\" to be present');\r\n        }\r\n        else if (headerValuePattern && typeof headerValuePattern === 'string') {\r\n            const actualHeaderValue = headers[headerName];\r\n            if (!modUtils.matchPattern(actualHeaderValue, headerValuePattern)) {\r\n                throw new OxError(errHelper.errorCode.ASSERT_ERROR, `Expected HTTP header \"${headerName}\" value to match: \"${headerValuePattern}\" but got: \"${actualHeaderValue}\"`);\r\n            }\r\n        }\r\n    }\r\n\r\n    /**\r\n     * @summary Assert if HTTP cookie is presented in the response\r\n     * @function assertCookie\r\n     * @param {String} cookieName - A HTTP cookie name.\r\n     * @param {String=} cookieValuePattern - An optional HTTP cookie value pattern.\r\n     */\r\n    assertCookie(cookieName, cookieValuePattern) {\r\n        throw new Error('Not implemented');\r\n    }\r\n\r\n    /**\r\n     * @summary Assert the last HTTP response's status code\r\n     * @function assertStatus\r\n     * @param {Number|Array} codeList - A single status code or a list of codes.\r\n     */\r\n    assertStatus(codeList) {\r\n        if (!this._lastResponse || !codeList) {\r\n            return false;\r\n        }\r\n        // if we got a single value, then convert it to an array\r\n        if (!Array.isArray(codeList)) {\r\n            codeList = [codeList];\r\n        }\r\n        const statusCode = this._lastResponse.statusCode;\r\n        if (!codeList.includes(statusCode)) {\r\n            throw new OxError(errHelper.errorCode.ASSERT_ERROR, `Expected HTTP status to be: \"${codeList}\" but got: \"${statusCode}\"`);\r\n        }\r\n        return true;\r\n    }\r\n\r\n    /**\r\n     * @summary Assert HTTP 200 OK status\r\n     * @function assertStatusOk\r\n     */\r\n    assertStatusOk() {\r\n        return this.assertStatus(200);\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\r\n     *              unique.\r\n     * @function transaction\r\n     * @param {String} name - The transaction name.\r\n     */\r\n    async transaction(name) {\r\n        global._lastTransactionName = name;\r\n    }\r\n\r\n    _resolveData(data) {\r\n        const dataResolver = {};\r\n\r\n        if (data instanceof Object) {\r\n            modUtils.assertCircular(data);\r\n            dataResolver.json = data;\r\n        } else {\r\n            dataResolver.body = data;\r\n        }\r\n\r\n        return dataResolver;\r\n    }\r\n\r\n    async _httpRequestSync(httpOpts) {\r\n        let result;\r\n\r\n        try {\r\n            result = await got(httpOpts);\r\n            if (httpOpts.deflateRaw && result.headers['content-encoding'] === 'deflate') {\r\n                const zlib = require('zlib');\r\n                const decomp = zlib.createInflateRaw();\r\n                decomp.write(result.body);\r\n                await (() => {\r\n                    return new Promise((resolve, reject) => {\r\n                        decomp.on('data', (data) => {\r\n                            result.body = data.toString();\r\n                            if (result.headers[CONTENT_TYPE_HEADER] && result.headers[CONTENT_TYPE_HEADER].includes('application/json')) {\r\n                                try {\r\n                                    result.body = JSON.parse(result.body);\r\n                                } catch (e) {\r\n                                    // if parsing fails just return the original string\r\n                                }\r\n                            }\r\n                            resolve();\r\n                        });\r\n                    });\r\n                })();\r\n            } else {\r\n                if (result.headers[CONTENT_TYPE_HEADER] && result.headers[CONTENT_TYPE_HEADER].includes('application/json')) {\r\n                    try {\r\n                        result.body = JSON.parse(result.body);\r\n                    } catch (e) {\r\n                        // if parsing fails just return the original string\r\n                    }\r\n                }\r\n            }\r\n\r\n        } catch (e) {\r\n            result = e;\r\n        }\r\n\r\n        // store last response to allow further assertions and validations\r\n        this._lastResponse = result;\r\n\r\n        if (result instanceof Error) {\r\n            let body = null;\r\n            if (\r\n                result.response &&\r\n                result.response.body\r\n            ) {\r\n                body = result.response.body;\r\n                if (typeof body === 'string') {\r\n                    try {\r\n                        body = JSON.parse(body);\r\n                    } catch (e) {\r\n                        body = result.response.body;\r\n                    }\r\n                }\r\n            }\r\n\r\n            result = {\r\n                errorMessage: result.message,\r\n                headers: result.response ? result.response.headers : null,\r\n                statusCode: result.response ? result.response.statusCode : null,\r\n                statusMessage: result.response ? result.response.statusMessage : null,\r\n                rawBody: result.response ? result.response.rawBody : null,\r\n                body: body\r\n            };\r\n        } else {\r\n            result = {\r\n                httpVersion: result.httpVersion,\r\n                headers: result.headers,\r\n                upgrade: result.upgrade,\r\n                url: result.url,\r\n                method: result.method,\r\n                statusCode: result.statusCode,\r\n                statusMessage: result.statusMessage,\r\n                timings: result.timings,\r\n                requestUrl: result.requestUrl,\r\n                redirectUrls: result.redirectUrls,\r\n                isFromCache: result.isFromCache,\r\n                ip: result.ip,\r\n                retryCount: result.retryCount,\r\n                body: result.body\r\n            };\r\n        }\r\n\r\n        return result;\r\n    }\r\n}"]}
|
|
@@ -41,8 +41,12 @@ module.exports = async function () {
|
|
|
41
41
|
const types = this.helpers.getLogTypes(context);
|
|
42
42
|
|
|
43
43
|
if (types && Array.isArray(types) && types.length > 0 && types.some(t => t === 'logcat')) {
|
|
44
|
-
|
|
45
|
-
|
|
44
|
+
try {
|
|
45
|
+
const logs = await this.driver.getLogs('logcat');
|
|
46
|
+
allLogs = [...allLogs, ...logs];
|
|
47
|
+
} catch (e) {
|
|
48
|
+
console.error('Unable to retrieve device logs:', e);
|
|
49
|
+
}
|
|
46
50
|
}
|
|
47
51
|
}
|
|
48
52
|
|
|
@@ -54,4 +58,4 @@ module.exports = async function () {
|
|
|
54
58
|
|
|
55
59
|
return null;
|
|
56
60
|
};
|
|
57
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
61
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uL3NyYy9veF9tb2R1bGVzL21vZHVsZS1tb2IvY29tbWFuZHMvZ2V0RGV2aWNlTG9ncy5qcyJdLCJuYW1lcyI6WyJtb2R1bGUiLCJleHBvcnRzIiwiY2FwcyIsInBsYXRmb3JtTmFtZSIsImFsbExvZ3MiLCJjb250ZXh0cyIsImRyaXZlciIsImdldENvbnRleHRzIiwiQXJyYXkiLCJpc0FycmF5IiwibGVuZ3RoIiwiYyIsImNvbnRleHQiLCJzd2l0Y2hDb250ZXh0IiwiZSIsInR5cGVzIiwiaGVscGVycyIsImdldExvZ1R5cGVzIiwic29tZSIsInQiLCJsb2dzIiwiZ2V0TG9ncyIsImNvbnNvbGUiLCJlcnJvciIsImFwcENvbnRleHQiXSwibWFwcGluZ3MiOiI7Ozs7QUFBQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBOztBQUVBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBO0FBQ0E7QUFDQTtBQUNBQSxNQUFNLENBQUNDLE9BQVAsR0FBaUIsa0JBQWtCO0FBQ2xDO0FBQ0csTUFBSSxLQUFLQyxJQUFMLElBQWEsS0FBS0EsSUFBTCxDQUFVQyxZQUF2QixJQUF1QyxLQUFLRCxJQUFMLENBQVVDLFlBQVYsS0FBMkIsU0FBdEUsRUFBaUY7QUFDN0UsUUFBSUMsT0FBTyxHQUFHLEVBQWQ7QUFDQSxVQUFNQyxRQUFRLEdBQUcsTUFBTSxLQUFLQyxNQUFMLENBQVlDLFdBQVosRUFBdkI7O0FBQ0EsUUFBSUYsUUFBUSxJQUFJRyxLQUFLLENBQUNDLE9BQU4sQ0FBY0osUUFBZCxDQUFaLElBQXVDQSxRQUFRLENBQUNLLE1BQVQsR0FBa0IsQ0FBN0QsRUFBZ0U7QUFDNUQsV0FBSyxJQUFJQyxDQUFULElBQWNOLFFBQWQsRUFBd0I7QUFDcEIsY0FBTU8sT0FBTyxHQUFHUCxRQUFRLENBQUNNLENBQUQsQ0FBeEI7O0FBQ0EsWUFBSTtBQUNBLGdCQUFNLEtBQUtMLE1BQUwsQ0FBWU8sYUFBWixDQUEwQkQsT0FBMUIsQ0FBTjtBQUNILFNBRkQsQ0FFRSxPQUFPRSxDQUFQLEVBQVU7QUFDUjtBQUNBO0FBQ0E7QUFDSDs7QUFDRCxjQUFNQyxLQUFLLEdBQUcsS0FBS0MsT0FBTCxDQUFhQyxXQUFiLENBQXlCTCxPQUF6QixDQUFkOztBQUNBLFlBQUlHLEtBQUssSUFBSVAsS0FBSyxDQUFDQyxPQUFOLENBQWNNLEtBQWQsQ0FBVCxJQUFpQ0EsS0FBSyxDQUFDTCxNQUFOLEdBQWUsQ0FBaEQsSUFBcURLLEtBQUssQ0FBQ0csSUFBTixDQUFXQyxDQUFDLElBQUlBLENBQUMsS0FBSyxRQUF0QixDQUF6RCxFQUEwRjtBQUN0RixjQUFJO0FBQ0Esa0JBQU1DLElBQUksR0FBRyxNQUFNLEtBQUtkLE1BQUwsQ0FBWWUsT0FBWixDQUFvQixRQUFwQixDQUFuQjtBQUNBakIsWUFBQUEsT0FBTyxHQUFHLENBQ04sR0FBR0EsT0FERyxFQUVOLEdBQUdnQixJQUZHLENBQVY7QUFJSCxXQU5ELENBT0EsT0FBT04sQ0FBUCxFQUFVO0FBQ05RLFlBQUFBLE9BQU8sQ0FBQ0MsS0FBUixDQUFjLGlDQUFkLEVBQWlEVCxDQUFqRDtBQUNIO0FBQ0o7QUFDSjs7QUFDRCxZQUFNLEtBQUtSLE1BQUwsQ0FBWU8sYUFBWixDQUEwQixLQUFLVyxVQUEvQixDQUFOO0FBQ0g7O0FBRUQsV0FBT3BCLE9BQVA7QUFDSDs7QUFFRCxTQUFPLElBQVA7QUFDSCxDQXBDRCIsInNvdXJjZXNDb250ZW50IjpbIi8qXHJcbiAqIENvcHlyaWdodCAoQykgMjAxNS1wcmVzZW50IENsb3VkQmVhdCBMaW1pdGVkXHJcbiAqXHJcbiAqIFRoaXMgcHJvZ3JhbSBpcyBmcmVlIHNvZnR3YXJlOiB5b3UgY2FuIHJlZGlzdHJpYnV0ZSBpdCBhbmQvb3IgbW9kaWZ5XHJcbiAqIGl0IHVuZGVyIHRoZSB0ZXJtcyBvZiB0aGUgR05VIEdlbmVyYWwgUHVibGljIExpY2Vuc2UgYXMgcHVibGlzaGVkIGJ5XHJcbiAqIHRoZSBGcmVlIFNvZnR3YXJlIEZvdW5kYXRpb24sIGVpdGhlciB2ZXJzaW9uIDMgb2YgdGhlIExpY2Vuc2UsIG9yXHJcbiAqIChhdCB5b3VyIG9wdGlvbikgYW55IGxhdGVyIHZlcnNpb24uXHJcbiAqL1xyXG5cclxuLyoqXHJcbiAqIEBmdW5jdGlvbiBnZXREZXZpY2VMb2dzXHJcbiAqIEBzdW1tYXJ5IENvbGxlY3RzIGxvZ3MgZnJvbSB0aGUgbW9iaWxlIGRldmljZS5cclxuICogQHJldHVybiB7T2JqZWN0W119IEEgbGlzdCBvZiBsb2dzLlxyXG4gKiBAZm9yIGFuZHJvaWQsIGlvcywgaHlicmlkLCB3ZWJcclxuICogQGV4YW1wbGUgPGNhcHRpb24+W2phdmFzY3JpcHRdIFVzYWdlIGV4YW1wbGU8L2NhcHRpb24+XHJcbiAqIG1vYi5pbml0KGNhcHMpOyAvL1N0YXJ0cyBhIG1vYmlsZSBzZXNzaW9uIGFuZCBvcGVucyBhcHAgZnJvbSBkZXNpcmVkIGNhcGFiaWxpdGllc1xyXG4gKiBtb2IuZ2V0RGV2aWNlTG9ncygpOyAvL0NvbGxlY3RzIGxvZ3MgZnJvbSB0aGUgbW9iaWxlIGRldmljZVxyXG4gKi9cclxubW9kdWxlLmV4cG9ydHMgPSBhc3luYyBmdW5jdGlvbiAoKSB7XHJcblx0Ly8gY3VycmVudGx5IHN1cHBvcnRzIG9ubHkgQW5kcm9pZCBsb2dzXHJcbiAgICBpZiAodGhpcy5jYXBzICYmIHRoaXMuY2Fwcy5wbGF0Zm9ybU5hbWUgJiYgdGhpcy5jYXBzLnBsYXRmb3JtTmFtZSA9PT0gJ0FuZHJvaWQnKSB7XHJcbiAgICAgICAgbGV0IGFsbExvZ3MgPSBbXTtcclxuICAgICAgICBjb25zdCBjb250ZXh0cyA9IGF3YWl0IHRoaXMuZHJpdmVyLmdldENvbnRleHRzKCk7XHJcbiAgICAgICAgaWYgKGNvbnRleHRzICYmIEFycmF5LmlzQXJyYXkoY29udGV4dHMpICYmIGNvbnRleHRzLmxlbmd0aCA+IDApIHtcclxuICAgICAgICAgICAgZm9yIChsZXQgYyBpbiBjb250ZXh0cykge1xyXG4gICAgICAgICAgICAgICAgY29uc3QgY29udGV4dCA9IGNvbnRleHRzW2NdO1xyXG4gICAgICAgICAgICAgICAgdHJ5IHtcclxuICAgICAgICAgICAgICAgICAgICBhd2FpdCB0aGlzLmRyaXZlci5zd2l0Y2hDb250ZXh0KGNvbnRleHQpO1xyXG4gICAgICAgICAgICAgICAgfSBjYXRjaCAoZSkge1xyXG4gICAgICAgICAgICAgICAgICAgIC8vIGlnbm9yZSBzd2l0Y2ggZXJyb3JzLCBsaWtlIFxyXG4gICAgICAgICAgICAgICAgICAgIC8vIFwiRmFpbGVkIHRvIGdldCBzb2NrZXRzIG1hdGNoaW5nOiBAd2VibGF5ZXJfZGV2dG9vbHNfcmVtb3RlXy4qNDczN1xcbiAgKG1ha2Ugc3VyZSB0aGUgYXBwIGhhcyBpdHMgV2ViVmlldy9XZWJMYXllciBjb25maWd1cmVkIGZvciBkZWJ1Z2dpbmcpXHJcbiAgICAgICAgICAgICAgICAgICAgY29udGludWU7XHJcbiAgICAgICAgICAgICAgICB9XHJcbiAgICAgICAgICAgICAgICBjb25zdCB0eXBlcyA9IHRoaXMuaGVscGVycy5nZXRMb2dUeXBlcyhjb250ZXh0KTtcclxuICAgICAgICAgICAgICAgIGlmICh0eXBlcyAmJiBBcnJheS5pc0FycmF5KHR5cGVzKSAmJiB0eXBlcy5sZW5ndGggPiAwICYmIHR5cGVzLnNvbWUodCA9PiB0ID09PSAnbG9nY2F0JykpIHtcclxuICAgICAgICAgICAgICAgICAgICB0cnkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjb25zdCBsb2dzID0gYXdhaXQgdGhpcy5kcml2ZXIuZ2V0TG9ncygnbG9nY2F0Jyk7XHJcbiAgICAgICAgICAgICAgICAgICAgICAgIGFsbExvZ3MgPSBbXHJcbiAgICAgICAgICAgICAgICAgICAgICAgICAgICAuLi5hbGxMb2dzLFxyXG4gICAgICAgICAgICAgICAgICAgICAgICAgICAgLi4ubG9nc1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBdO1xyXG4gICAgICAgICAgICAgICAgICAgIH1cclxuICAgICAgICAgICAgICAgICAgICBjYXRjaCAoZSkge1xyXG4gICAgICAgICAgICAgICAgICAgICAgICBjb25zb2xlLmVycm9yKCdVbmFibGUgdG8gcmV0cmlldmUgZGV2aWNlIGxvZ3M6JywgZSk7XHJcbiAgICAgICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICAgICAgfVxyXG4gICAgICAgICAgICB9XHJcbiAgICAgICAgICAgIGF3YWl0IHRoaXMuZHJpdmVyLnN3aXRjaENvbnRleHQodGhpcy5hcHBDb250ZXh0KTtcclxuICAgICAgICB9XHJcblxyXG4gICAgICAgIHJldHVybiBhbGxMb2dzO1xyXG4gICAgfVxyXG5cclxuICAgIHJldHVybiBudWxsO1xyXG59OyJdfQ==
|
|
@@ -192,7 +192,7 @@ class MobileModule extends _WebDriverModule.default {
|
|
|
192
192
|
|
|
193
193
|
|
|
194
194
|
if (this.options.collectDeviceLogs) {
|
|
195
|
-
this.caps
|
|
195
|
+
this.caps['appium:clearDeviceLogsOnStart'] = true;
|
|
196
196
|
} // if both browserName and appPackage were specified - remove browserName
|
|
197
197
|
|
|
198
198
|
|
|
@@ -696,4 +696,4 @@ class MobileModule extends _WebDriverModule.default {
|
|
|
696
696
|
}
|
|
697
697
|
|
|
698
698
|
exports.default = MobileModule;
|
|
699
|
-
//# 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","clearDeviceLogsOnStart","appPackage","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","dispose","status","steps","Array","isArray","length","failedFinded","find","item","toUpperCase","testStop","Constants","results","passed","failed","_sendResultStatusToBrowserstack","deleteSession","includes","seleniumSessionTimeout","warn","transaction","global","_lastTransactionName","_isAction","_takeScreenshotSilent","error","takeScreenshot","retval","call","Promise","resolve","reject","waitUntilRetVal","waitUntil","images","pushImageToImages","fetchTitle","image","title","getTitle","textToImage","require","titleImage","generate","fontFamily","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","SELENIUM_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","toString"],"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 *  \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 were specified - remove browserName\r\n        if (this.caps.browserName && (this.caps.appPackage || this.caps.app)) {\r\n            delete this.caps.browserName;\r\n        }\r\n        // if no appPackage nor app capability, not 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) {\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\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        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\r\n     *              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        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('text-to-image');\r\n                                                let titleImage = await textToImage.generate(title, { debug: false, fontFamily: 'Arial' });\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.SELENIUM_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"]}
|
|
699
|
+
//# 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","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","dispose","status","steps","Array","isArray","length","failedFinded","find","item","toUpperCase","testStop","Constants","results","passed","failed","_sendResultStatusToBrowserstack","deleteSession","includes","seleniumSessionTimeout","warn","transaction","global","_lastTransactionName","_isAction","_takeScreenshotSilent","error","takeScreenshot","retval","call","Promise","resolve","reject","waitUntilRetVal","waitUntil","images","pushImageToImages","fetchTitle","image","title","getTitle","textToImage","require","titleImage","generate","fontFamily","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","SELENIUM_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","toString"],"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 *  \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['appium:clearDeviceLogsOnStart'] = true;\r\n        }\r\n\r\n        // if both browserName and appPackage were specified - remove browserName\r\n        if (this.caps.browserName && (this.caps.appPackage || this.caps.app)) {\r\n            delete this.caps.browserName;\r\n        }\r\n        // if no appPackage nor app capability, not 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) {\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\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        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\r\n     *              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        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('text-to-image');\r\n                                                let titleImage = await textToImage.generate(title, { debug: false, fontFamily: 'Arial' });\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.SELENIUM_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"]}
|
|
@@ -58,6 +58,9 @@ module.exports = async function (locator, timeout) {
|
|
|
58
58
|
throw new Error(retVal.error + ' ' + retVal.message);
|
|
59
59
|
}
|
|
60
60
|
} catch (e) {
|
|
61
|
+
console.log('clickJS failure');
|
|
62
|
+
console.log(e);
|
|
63
|
+
|
|
61
64
|
if (this.retryCount) {
|
|
62
65
|
--this.retryCount;
|
|
63
66
|
await this.clickJS(el);
|
|
@@ -71,10 +74,13 @@ module.exports = async function (locator, timeout) {
|
|
|
71
74
|
|
|
72
75
|
try {
|
|
73
76
|
var clickable = await el.isClickable();
|
|
77
|
+
console.log('Element clickable: ' + clickable);
|
|
74
78
|
} catch (e) {
|
|
75
79
|
let documentMode;
|
|
76
80
|
|
|
77
81
|
if (this.driver && this.driver.capabilities && this.driver.capabilities.browserName === 'internet explorer') {
|
|
82
|
+
console.log('Falling back to IE workaround');
|
|
83
|
+
|
|
78
84
|
try {
|
|
79
85
|
documentMode = await this.driver.execute(function () {
|
|
80
86
|
// eslint-disable-next-line no-undef
|
|
@@ -93,10 +99,13 @@ module.exports = async function (locator, timeout) {
|
|
|
93
99
|
|
|
94
100
|
if (clickable) {
|
|
95
101
|
try {
|
|
102
|
+
console.log('Performing el.click');
|
|
96
103
|
await el.click();
|
|
104
|
+
console.log('el.click done');
|
|
97
105
|
} catch (e) {
|
|
98
106
|
// chromedriver doesn't seem to support clicking on elements in Shadow DOM
|
|
99
107
|
if (e.message.startsWith("javascript error: Cannot read property 'defaultView' of undefined")) {
|
|
108
|
+
console.log('el.click failed due to missing defaultView. Falling back to clickJS');
|
|
100
109
|
await this.clickJS(el);
|
|
101
110
|
} else {
|
|
102
111
|
throw e;
|
|
@@ -104,9 +113,10 @@ module.exports = async function (locator, timeout) {
|
|
|
104
113
|
}
|
|
105
114
|
} else {
|
|
106
115
|
// if element is not clickable, try clicking it using JS injection
|
|
116
|
+
console.log('Element not clickable. Invoking clikcJS');
|
|
107
117
|
await this.clickJS(el);
|
|
108
118
|
}
|
|
109
119
|
|
|
110
120
|
await this.checkWaitForAngular();
|
|
111
121
|
};
|
|
112
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/ox_modules/module-web/commands/click.js"],"names":["module","exports","locator","timeout","helpers","assertArgumentTimeout","retryCount","clickJS","el","retVal","driver","execute","domEl","document","createEvent","createEventObject","ev","fireEvent","clckEv","initEvent","dispatchEvent","error","message","Error","e","getElement","clickable","isClickable","documentMode","capabilities","browserName","window","includes","parseInt","click","startsWith","checkWaitForAngular"],"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/**\r\n * @summary Clicks on an element.\r\n * @description If the click causes new page to load, the command waits for page to load before\r\n *              proceeding.\r\n * @function click\r\n * @param {String|Element} locator - An element locator.\r\n * @param {Number=} timeout - Timeout in milliseconds. Default is 60 seconds.\r\n * @example <caption>[javascript] Usage example</caption>\r\n * web.init();//Opens browser session.\r\n * web.open(\"www.yourwebsite.com\");// Opens a website.\r\n * web.click(\"id=NextPage\");//Clicks on next page link.\r\n */\r\nmodule.exports = async function(locator, timeout) {\r\n    this.helpers.assertArgumentTimeout(timeout, 'timeout');\r\n    this.retryCount = 3;\r\n    this.clickJS = async (el) =>  {\r\n        try {\r\n            /*global document*/\r\n            const retVal = await this.driver.execute(function(domEl) {\r\n                // createEvent won't be available in IE < 9 compatibility mode\r\n                if (!document.createEvent) {\r\n                    if (document.createEventObject) {\r\n                        var ev = document.createEventObject();\r\n                        domEl.fireEvent('onclick', ev);\r\n                        return;\r\n                    } else {\r\n                        return; // fail silently\r\n                    }\r\n                }\r\n                var clckEv = document.createEvent('MouseEvent');\r\n                clckEv.initEvent('click', true, true);\r\n                domEl.dispatchEvent(clckEv);\r\n            }, el);\r\n\r\n            /*\r\n                {\r\n                    error: 'no such element',\r\n                    message: 'Error executing JavaScript',\r\n                    stacktrace: ''\r\n                }\r\n            */\r\n            if (retVal && retVal.error && retVal.message) {\r\n                throw new Error(retVal.error + ' ' + retVal.message);\r\n            }\r\n\r\n        } catch (e) {\r\n            if (this.retryCount) {\r\n                --this.retryCount;\r\n                await this.clickJS(el);\r\n            } else {\r\n                throw e;\r\n            }\r\n        }\r\n    };\r\n\r\n    var el = await this.helpers.getElement(locator, false, timeout);\r\n\r\n    try {\r\n        var clickable = await el.isClickable();\r\n    } catch (e) {\r\n        let documentMode;\r\n        if (\r\n            this.driver &&\r\n            this.driver.capabilities &&\r\n            this.driver.capabilities.browserName === 'internet explorer'\r\n        ) {\r\n            try {\r\n                documentMode = await this.driver.execute(function() {\r\n                    // eslint-disable-next-line no-undef\r\n                    return window.document.documentMode;\r\n                });\r\n            } catch (e) {\r\n                // ignore\r\n            }\r\n\r\n            if (\r\n                documentMode &&\r\n                [5, 6, 7, 8, 9, 10].includes(parseInt(documentMode))\r\n            ) {\r\n                clickable = true;\r\n            } else {\r\n                throw e;\r\n            }\r\n        }\r\n    }\r\n\r\n    if (clickable) {\r\n        try {\r\n            await el.click();\r\n        } catch (e) {\r\n            // chromedriver doesn't seem to support clicking on elements in Shadow DOM\r\n            if (e.message.startsWith(\"javascript error: Cannot read property 'defaultView' of undefined\")) {\r\n                await this.clickJS(el);\r\n            } else {\r\n                throw e;\r\n            }\r\n        }\r\n    } else {\r\n        // if element is not clickable, try clicking it using JS injection\r\n        await this.clickJS(el);\r\n    }\r\n\r\n    await this.checkWaitForAngular();\r\n};\r\n"]}
|
|
122
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../../../src/ox_modules/module-web/commands/click.js"],"names":["module","exports","locator","timeout","helpers","assertArgumentTimeout","retryCount","clickJS","el","retVal","driver","execute","domEl","document","createEvent","createEventObject","ev","fireEvent","clckEv","initEvent","dispatchEvent","error","message","Error","e","console","log","getElement","clickable","isClickable","documentMode","capabilities","browserName","window","includes","parseInt","click","startsWith","checkWaitForAngular"],"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/**\r\n * @summary Clicks on an element.\r\n * @description If the click causes new page to load, the command waits for page to load before\r\n *              proceeding.\r\n * @function click\r\n * @param {String|Element} locator - An element locator.\r\n * @param {Number=} timeout - Timeout in milliseconds. Default is 60 seconds.\r\n * @example <caption>[javascript] Usage example</caption>\r\n * web.init();//Opens browser session.\r\n * web.open(\"www.yourwebsite.com\");// Opens a website.\r\n * web.click(\"id=NextPage\");//Clicks on next page link.\r\n */\r\nmodule.exports = async function(locator, timeout) {\r\n    this.helpers.assertArgumentTimeout(timeout, 'timeout');\r\n    this.retryCount = 3;\r\n    this.clickJS = async (el) =>  {\r\n        try {\r\n            /*global document*/\r\n            const retVal = await this.driver.execute(function(domEl) {\r\n                // createEvent won't be available in IE < 9 compatibility mode\r\n                if (!document.createEvent) {\r\n                    if (document.createEventObject) {\r\n                        var ev = document.createEventObject();\r\n                        domEl.fireEvent('onclick', ev);\r\n                        return;\r\n                    } else {\r\n                        return; // fail silently\r\n                    }\r\n                }\r\n                var clckEv = document.createEvent('MouseEvent');\r\n                clckEv.initEvent('click', true, true);\r\n                domEl.dispatchEvent(clckEv);\r\n            }, el);\r\n\r\n            /*\r\n                {\r\n                    error: 'no such element',\r\n                    message: 'Error executing JavaScript',\r\n                    stacktrace: ''\r\n                }\r\n            */\r\n            if (retVal && retVal.error && retVal.message) {\r\n                throw new Error(retVal.error + ' ' + retVal.message);\r\n            }\r\n\r\n        } catch (e) {\r\n            console.log('clickJS failure');\r\n            console.log(e);\r\n            if (this.retryCount) {\r\n                --this.retryCount;\r\n                await this.clickJS(el);\r\n            } else {\r\n                throw e;\r\n            }\r\n        }\r\n    };\r\n\r\n    var el = await this.helpers.getElement(locator, false, timeout);\r\n\r\n    try {\r\n        var clickable = await el.isClickable();\r\n        console.log('Element clickable: ' + clickable);\r\n    } catch (e) {\r\n        let documentMode;\r\n        if (\r\n            this.driver &&\r\n            this.driver.capabilities &&\r\n            this.driver.capabilities.browserName === 'internet explorer'\r\n        ) {\r\n            console.log('Falling back to IE workaround');\r\n            try {\r\n                documentMode = await this.driver.execute(function() {\r\n                    // eslint-disable-next-line no-undef\r\n                    return window.document.documentMode;\r\n                });\r\n            } catch (e) {\r\n                // ignore\r\n            }\r\n\r\n            if (\r\n                documentMode &&\r\n                [5, 6, 7, 8, 9, 10].includes(parseInt(documentMode))\r\n            ) {\r\n                clickable = true;\r\n            } else {\r\n                throw e;\r\n            }\r\n        }\r\n    }\r\n\r\n    if (clickable) {\r\n        try {\r\n            console.log('Performing el.click');\r\n            await el.click();\r\n            console.log('el.click done');\r\n        } catch (e) {\r\n            // chromedriver doesn't seem to support clicking on elements in Shadow DOM\r\n            if (e.message.startsWith(\"javascript error: Cannot read property 'defaultView' of undefined\")) {\r\n                console.log('el.click failed due to missing defaultView. Falling back to clickJS');\r\n                await this.clickJS(el);\r\n            } else {\r\n                throw e;\r\n            }\r\n        }\r\n    } else {\r\n        // if element is not clickable, try clicking it using JS injection\r\n        console.log('Element not clickable. Invoking clikcJS');\r\n        await this.clickJS(el);\r\n    }\r\n\r\n    await this.checkWaitForAngular();\r\n};\r\n"]}
|
|
@@ -15,6 +15,8 @@ var _submoduleNetwork = _interopRequireDefault(require("./service-devtools/submo
|
|
|
15
15
|
|
|
16
16
|
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
17
17
|
|
|
18
|
+
const CHROME_BROWSER = 'chrome';
|
|
19
|
+
|
|
18
20
|
class DevToolsService extends _OxygenService.default {
|
|
19
21
|
constructor(options, ctx, results, logger) {
|
|
20
22
|
super(options, ctx, results, logger);
|
|
@@ -44,14 +46,17 @@ class DevToolsService extends _OxygenService.default {
|
|
|
44
46
|
}
|
|
45
47
|
|
|
46
48
|
let options = {};
|
|
47
|
-
const capabilities = module.getCapabilities();
|
|
49
|
+
const capabilities = module.getCapabilities() || {};
|
|
50
|
+
const {
|
|
51
|
+
browserName
|
|
52
|
+
} = capabilities;
|
|
48
53
|
this._driver = module.getDriver();
|
|
49
54
|
|
|
50
55
|
if (this._driver && this._driver.capabilities && this._driver.capabilities['goog:chromeOptions'] && this._driver.capabilities['goog:chromeOptions']['debuggerAddress']) {
|
|
51
56
|
options.debuggerAddress = this._driver.capabilities['goog:chromeOptions']['debuggerAddress'];
|
|
52
57
|
}
|
|
53
58
|
|
|
54
|
-
if (this._driver.provider === null) {
|
|
59
|
+
if (this._driver.provider === null && browserName && browserName.toLowerCase() === CHROME_BROWSER) {
|
|
55
60
|
const devToolsSvc = new _devtoolsService.default(options);
|
|
56
61
|
const UNSUPPORTED_ERROR_MESSAGE = devToolsSvc.beforeSession(null, capabilities);
|
|
57
62
|
|
|
@@ -80,4 +85,4 @@ class DevToolsService extends _OxygenService.default {
|
|
|
80
85
|
}
|
|
81
86
|
|
|
82
87
|
exports.default = DevToolsService;
|
|
83
|
-
//# sourceMappingURL=data:application/json;charset=utf-8;base64,
|
|
88
|
+
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"sources":["../../src/ox_services/service-devtools.js"],"names":["CHROME_BROWSER","DevToolsService","OxygenService","constructor","options","ctx","results","logger","_subModules","isServiceInitialized","onModuleLoaded","module","getDriver","getCapabilities","networkSubmodule","NetworkSubModule","addSubModule","name","onModuleInitialized","submodule","isInitialized","capabilities","browserName","_driver","debuggerAddress","provider","toLowerCase","devToolsSvc","WDIODevToolsService","UNSUPPORTED_ERROR_MESSAGE","beforeSession","console","log","_isSupported","global","browser","before","init","onModuleWillDispose","dispose"],"mappings":"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","sourcesContent":["/* eslint-disable no-unreachable */\r\nimport WDIODevToolsService from '@wdio/devtools-service';\r\n\r\nimport OxygenService from '../core/OxygenService';\r\nimport NetworkSubModule from './service-devtools/submodule-network';\r\n\r\nconst CHROME_BROWSER = 'chrome';\r\n\r\nexport default class DevToolsService extends OxygenService {\r\n    constructor(options, ctx, results, logger) {\r\n        super(options, ctx, results, logger);\r\n        // hash of webdriver based modules\r\n        this._subModules = {};\r\n        this.isServiceInitialized = true;\r\n    }\r\n    onModuleLoaded(module) {\r\n        // skip any module that does not implement .getDriver() method (e.g. not webdriver based)\r\n        if (!module || !module.getDriver || typeof module.getDriver !== 'function' || !module.getCapabilities || typeof module.getCapabilities !== 'function') {\r\n            return;\r\n        }\r\n\r\n        const networkSubmodule = new NetworkSubModule('network', module);\r\n        module.addSubModule('network', networkSubmodule);\r\n        this._subModules[module.name] = networkSubmodule;\r\n    }\r\n    async onModuleInitialized(module) {\r\n        // skip any module that does not implement getDriver method (e.g. not webdriver based)\r\n        if (!module || !module.getDriver || typeof module.getDriver !== 'function' || !module.getCapabilities || typeof module.getCapabilities !== 'function') {\r\n            return;\r\n        }\r\n        const submodule = this._subModules[module.name];\r\n        if (!submodule || submodule.isInitialized) {\r\n            return;\r\n        }\r\n\r\n        let options = {};\r\n        const capabilities = module.getCapabilities() || {};\r\n        const { browserName } = capabilities;\r\n        this._driver = module.getDriver();\r\n\r\n        if (\r\n            this._driver &&\r\n            this._driver.capabilities &&\r\n            this._driver.capabilities['goog:chromeOptions'] &&\r\n            this._driver.capabilities['goog:chromeOptions']['debuggerAddress']\r\n        ) {\r\n            options.debuggerAddress = this._driver.capabilities['goog:chromeOptions']['debuggerAddress'];\r\n        }\r\n\r\n        // if we are not using any 3rd party provider\r\n        if (this._driver.provider === null && browserName && browserName.toLowerCase() === CHROME_BROWSER) {\r\n            // initialize DevToolsService and hook it to the current webdriver object\r\n            const devToolsSvc = new WDIODevToolsService(options);\r\n            const UNSUPPORTED_ERROR_MESSAGE = devToolsSvc.beforeSession(null, capabilities);\r\n\r\n            if (UNSUPPORTED_ERROR_MESSAGE) {\r\n                console.log('UNSUPPORTED_ERROR_MESSAGE', UNSUPPORTED_ERROR_MESSAGE);\r\n            }\r\n\r\n            if (devToolsSvc._isSupported) {\r\n                // change global.browser to the current module's webdriver instance\r\n                // const orgGlobalBrowser = global.browser;\r\n                global.browser = module.getDriver();\r\n                await devToolsSvc.before(null, null, this._driver);\r\n                submodule.init(devToolsSvc);\r\n                // global.browser = orgGlobalBrowser;\r\n            }\r\n        }\r\n    }\r\n    onModuleWillDispose(module) {\r\n        const submodule = this._subModules[module.name];\r\n        if (!submodule) {\r\n            return;\r\n        }\r\n        submodule.dispose();\r\n    }\r\n}"]}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "oxygen-cli",
|
|
3
|
-
"version": "1.
|
|
3
|
+
"version": "1.23.0",
|
|
4
4
|
"description": "Automation framework for testing modern applications",
|
|
5
5
|
"main": "./build/index.js",
|
|
6
6
|
"bin": {
|
|
@@ -47,41 +47,41 @@
|
|
|
47
47
|
"npm-run-all": "4.1.5"
|
|
48
48
|
},
|
|
49
49
|
"dependencies": {
|
|
50
|
-
"@applitools/eyes-webdriverio": "5.
|
|
51
|
-
"@lambdatest/node-rest-client": "1.0.
|
|
50
|
+
"@applitools/eyes-webdriverio": "5.35.3",
|
|
51
|
+
"@lambdatest/node-rest-client": "1.0.2",
|
|
52
52
|
"@oxygenhq/chrome-remote-interface": "0.30.0",
|
|
53
53
|
"@oxygenhq/logger": "0.5.1",
|
|
54
54
|
"@oxygenhq/mitmproxy-node": "1.0.1",
|
|
55
|
-
"@wdio/cli": "7.
|
|
56
|
-
"@wdio/devtools-service": "7.
|
|
57
|
-
"@wdio/sync": "7.
|
|
58
|
-
"async": "3.2.
|
|
59
|
-
"chai": "4.3.
|
|
55
|
+
"@wdio/cli": "7.20.2",
|
|
56
|
+
"@wdio/devtools-service": "7.20.2",
|
|
57
|
+
"@wdio/sync": "7.20.2",
|
|
58
|
+
"async": "3.2.4",
|
|
59
|
+
"chai": "4.3.6",
|
|
60
60
|
"chrome-har": "0.11.12",
|
|
61
|
-
"config": "3.3.
|
|
61
|
+
"config": "3.3.7",
|
|
62
62
|
"cross-spawn": "7.0.3",
|
|
63
63
|
"csv-parse": "4.16.0",
|
|
64
64
|
"cucumber": "6.0.5",
|
|
65
|
-
"deasync": "0.1.
|
|
66
|
-
"decache": "4.6.
|
|
65
|
+
"deasync": "0.1.26",
|
|
66
|
+
"decache": "4.6.1",
|
|
67
67
|
"easyxml": "2.0.1",
|
|
68
68
|
"ejs": "3.0.2",
|
|
69
69
|
"esm": "3.2.25",
|
|
70
|
-
"fast-xml-parser": "
|
|
70
|
+
"fast-xml-parser": "4.0.8",
|
|
71
71
|
"fibers": "5.0.0",
|
|
72
72
|
"glob": "7.1.7",
|
|
73
73
|
"glob-to-regexp": "0.4.1",
|
|
74
74
|
"global-agent": "3.0.0",
|
|
75
75
|
"got": "11.8.2",
|
|
76
76
|
"imap-simple": "5.1.0",
|
|
77
|
-
"is-glob": "4.0.
|
|
77
|
+
"is-glob": "4.0.3",
|
|
78
78
|
"jimp": "0.16.1",
|
|
79
79
|
"junit-report-builder": "3.0.0",
|
|
80
80
|
"lodash": "4.17.21",
|
|
81
|
-
"mailparser": "3.
|
|
82
|
-
"minimist": "1.2.
|
|
81
|
+
"mailparser": "3.5.0",
|
|
82
|
+
"minimist": "1.2.6",
|
|
83
83
|
"mockery": "2.1.0",
|
|
84
|
-
"moment": "2.29.
|
|
84
|
+
"moment": "2.29.3",
|
|
85
85
|
"node-addon-api": "3.0.2",
|
|
86
86
|
"objects-to-csv": "1.3.6",
|
|
87
87
|
"pdf2json": "1.2.5",
|
|
@@ -89,19 +89,19 @@
|
|
|
89
89
|
"request": "2.88.2",
|
|
90
90
|
"saucelabs": "3.0.1",
|
|
91
91
|
"serialport": "9.2.8",
|
|
92
|
-
"soap": "0.
|
|
92
|
+
"soap": "0.44.0",
|
|
93
93
|
"source-map-support": "0.5.21",
|
|
94
94
|
"stacktrace-parser": "0.1.10",
|
|
95
|
-
"testdouble": "3.16.
|
|
95
|
+
"testdouble": "3.16.6",
|
|
96
96
|
"testingbot-api": "1.0.7",
|
|
97
97
|
"text-to-image": "2.4.4",
|
|
98
|
-
"twilio": "3.
|
|
99
|
-
"webdriverio": "7.
|
|
98
|
+
"twilio": "3.77.2",
|
|
99
|
+
"webdriverio": "7.20.2",
|
|
100
100
|
"when": "3.7.8",
|
|
101
|
-
"xlsx": "0.
|
|
101
|
+
"xlsx": "0.18.5"
|
|
102
102
|
},
|
|
103
103
|
"optionalDependencies": {
|
|
104
|
-
"odbc": "2.4.
|
|
104
|
+
"odbc": "2.4.4"
|
|
105
105
|
},
|
|
106
106
|
"scripts": {
|
|
107
107
|
"build": "run-s clean compile",
|