Best JavaScript code snippet using cypress
util.js
Source:util.js
...38const plist = __importStar(require("plist"));39const semver = __importStar(require("semver"));40const findSystemNode = __importStar(require("../../../server/lib/util/find_system_node"));41/** parses Info.plist file from given application and returns a property */42function parsePlist(p, property) {43 const pl = path.join(p, 'Contents', 'Info.plist');44 (0, log_1.log)('reading property file "%s"', pl);45 const failed = (e) => {46 const msg = `Info.plist not found: ${pl}47 ${e.message}`;48 (0, log_1.log)('could not read Info.plist %o', { pl, e });49 throw (0, errors_1.notInstalledErr)('', msg);50 };51 return fs52 .readFile(pl, 'utf8')53 .then(plist.parse)54 .then((val) => val[property])55 .then(String) // explicitly convert value to String type56 .catch(failed); // to make TS compiler happy57}58exports.parsePlist = parsePlist;59/** uses mdfind to find app using Ma app id like 'com.google.Chrome.canary' */60function mdfind(id) {61 const cmd = `mdfind 'kMDItemCFBundleIdentifier=="${id}"' | head -1`;62 (0, log_1.log)('looking for bundle id %s using command: %s', id, cmd);63 const logFound = (str) => {64 (0, log_1.log)('found %s at %s', id, str);65 return str;66 };67 const failedToFind = () => {68 (0, log_1.log)('could not find %s', id);69 throw (0, errors_1.notInstalledErr)(id);70 };71 return utils_1.utils.execa(cmd)72 .then((val) => {73 return val.stdout;74 })75 .then((val) => {76 logFound(val);77 return val;78 })79 .catch(failedToFind);80}81exports.mdfind = mdfind;82function formApplicationPath(appName) {83 return path.join('/Applications', appName);84}85/** finds an application and its version */86function findApp({ appName, executable, appId, versionProperty }) {87 (0, log_1.log)('looking for app %s id %s', executable, appId);88 const findVersion = (foundPath) => {89 return parsePlist(foundPath, versionProperty).then((version) => {90 (0, log_1.log)('got plist: %o', { foundPath, version });91 return {92 path: path.join(foundPath, executable),93 version,94 };95 });96 };97 const tryMdFind = () => {98 return mdfind(appId).then(findVersion);99 };100 const tryFullApplicationFind = () => {101 const applicationPath = formApplicationPath(appName);102 (0, log_1.log)('looking for application %s', applicationPath);103 return findVersion(applicationPath);...
SpriteAtlas.js
Source:SpriteAtlas.js
1(function (Ω) {2 "use strict";3 var SpriteAtlas = Ω.Class.extend({4 images: null,5 path: "",6 plist: null,7 csv: null,8 init: function (type, data) {9 this.images = {};10 switch (type) {11 case "plist":12 this.initPList(data);13 break;14 case "csv":15 this.initCSV(data);16 break;17 }18 },19 initPList: function (plist) {20 var self = this;21 this.path = plist.split("/").slice(0, -1).join("/") + "/";22 var resolve = Ω.preload(plist);23 Ω.utils.ajax(plist, function (xhr) {24 var parser = new DOMParser(),25 xmlText = xhr.responseText,26 xmlDoc,27 root;28 xmlDoc = parser.parseFromString(xmlText, "application/xml");29 root = xmlDoc.getElementsByTagName("dict")[0];30 self.plist = self.parsePList(root);31 self.loadImages(self.plist.images);32 resolve();33 });34 },35 initCSV: function (path) {36 var self = this;37 var resolve = Ω.preload(path);38 Ω.utils.ajax(path + ".txt", function (xhr) {39 Ω.gfx.loadImage(path + ".png", function (img) {40 self.images.main = img;41 self.parseCSV(xhr.responseText, img);42 });43 resolve();44 });45 },46 loadImages: function (imageData) {47 var self = this;48 imageData.forEach(function (imgData) {49 Ω.gfx.loadImage(self.path + imgData.path, function (img) {50 self.images[imgData.path] = img;51 });52 });53 },54 parseCSV: function (csv, img) {55 var out = this.csv = {};56 csv.split("\n").forEach(function (line) {57 var parts = line.split(" "),58 w = img.width,59 h = img.height;60 out[parts[0]] = {61 name: parts[0],62 w: Math.round(parseInt(parts[1], 10)),63 h: Math.round(parseInt(parts[2], 10)),64 x: Math.round(parts[3] * w),65 y: Math.round(parts[4] * h)66 };67 });68 },69 parsePList: function (nodes) {70 var kids = nodes.children,71 key,72 value;73 var out = {},74 arrOut;75 for (var i = 0; i < kids.length; i += 2) {76 key = kids[i];77 value = kids[i + 1];78 switch (value.nodeName) {79 case "dict":80 value = this.parsePList(value);81 break;82 case "string":83 value = value.textContent;84 break;85 case "integer":86 value = value.textContent;87 break;88 case "array":89 arrOut = [];90 for(var j = 0; j < value.children.length; j++) {91 arrOut.push(this.parsePList(value.children[j]));92 }93 value = arrOut;94 break;95 case "true":96 value = true;97 break;98 case "false":99 value = false;100 break;101 default:102 console.error("unhandled plist type:", value.nodeName);103 break;104 }105 out[key.textContent] = value;106 }107 return out;108 },109 render: function (gfx, name, x, y) {110 if (this.plist) {111 this.renderPList(gfx, x, y);112 return;113 }114 var img = this.images.main,115 imgData = this.csv[name];116 if (!imgData) {117 return;118 }119 gfx.ctx.drawImage(120 img,121 imgData.x,122 imgData.y,123 imgData.w,124 imgData.h,125 x,126 y,127 imgData.w,128 imgData.h);129 },130 renderPList: function (gfx, x, y) {131 var img = this.images["sprites.1.png"];132 var si = ((Date.now() / 300 | 0) % 10) + 1;133 var subimg = this.plist.images[1].subimages[si].textureRect;134 var t = subimg.replace("{{", "").replace("}}","").replace("},{", ",").split(",");135 var x1 = t[0];136 var x2 = t[1];137 var w = t[2];138 var h = t[3];139 gfx.ctx.drawImage(140 img,141 x1,142 x2,143 w,144 h,145 x,146 y,147 w,148 h);149 }150 });151 Ω.SpriteAtlas = SpriteAtlas;...
ipa.js
Source:ipa.js
...21 this.getEntries([PlistName, ProvisionName]).then(buffers => {22 if (!buffers[PlistName]) {23 throw new Error('Info.plist can\'t be found.')24 }25 const plistInfo = this._parsePlist(buffers[PlistName])26 // parse mobileprovision27 const provisionInfo = this._parseProvision(buffers[ProvisionName])28 plistInfo.mobileProvision = provisionInfo29 // find icon path and parse icon30 const iconRegex = new RegExp(findIpaIconPath(plistInfo).toLowerCase())31 this.getEntry(iconRegex).then(iconBuffer => {32 // The ipa file's icon has been specially processed, should be converted33 plistInfo.icon = iconBuffer ? getBase64FromBuffer(cgbiToPng.revert(iconBuffer)) : null34 resolve(plistInfo)35 }).catch(e => {36 reject(e)37 })38 }).catch(e => {39 reject(e)40 })41 })42 }43 /**44 * Parse plist45 * @param {Buffer} buffer // plist file's buffer46 */47 _parsePlist (buffer) {48 let result49 const bufferType = buffer[0]50 if (bufferType === 60 || bufferType === '<' || bufferType === 239) {51 result = parsePlist(buffer.toString())52 } else if (bufferType === 98) {53 result = parseBplist(buffer)[0]54 } else {55 throw new Error('Unknow plist buffer type.')56 }57 return result58 }59 /**60 * parse provision61 * @param {Buffer} buffer // provision file's buffer62 */63 _parseProvision (buffer) {64 let info = {}65 if (buffer) {66 info = buffer.toString('utf-8')67 const firstIndex = info.indexOf('<')68 const endIndex = info.indexOf('</plist>')69 info = info.slice(firstIndex, endIndex + 8)70 info = parsePlist(info)71 }72 return info73 }74}...
add-background-modes.js
Source:add-background-modes.js
1const _ = require('lodash');2const fs = require('fs-extra');3const plist = require('plist');4function parsePlist(plistPath) {5 let plistResult = {};6 if (!fs.existsSync(plistPath)) {7 console.log(`No path found on ${plistPath}`);8 return null;9 }10 const plistContent = fs.readFileSync(plistPath, 'utf8');11 try {12 plistResult = plist.parse(plistContent);13 } catch (e) {14 console.error('Unable to parse plist', plistPath);15 }16 return plistResult;17}18function hasTrackPlayingShortcut(configuration) {19 const hasTrackPlayingShortcut = configuration.included.find(item => {20 const isShortcut = item.type === 'shoutem.core.shortcuts';21 if (!isShortcut) {22 return false;23 }24 const canonicalName = _.get(item, 'attributes.canonicalName', '');25 return (26 canonicalName.includes('Radio') ||27 canonicalName.includes('podcast-shortcut')28 );29 });30 return hasTrackPlayingShortcut;31}32/**33 * If radio or podcast shortcut is present, writes the required background34 * mode into extension's Info.plist file35 */36function updateInfoPlist(appConfiguration) {37 if (!hasTrackPlayingShortcut(appConfiguration)) {38 return;39 }40 console.log(41 '[shoutem.audio] - Adding audio background mode to extension Info.plist',42 );43 const plistPath = 'ios/Info.plist';44 const currentPlistContents = parsePlist(plistPath);45 const backgroundModePlistData = {46 UIBackgroundModes: ['audio'],47 };48 const audioInfoPlist = Object.assign(49 currentPlistContents,50 backgroundModePlistData,51 );52 fs.writeFileSync(plistPath, plist.build(audioInfoPlist));53}54module.exports = {55 updateInfoPlist,...
merge-info-plists.js
Source:merge-info-plists.js
2const fs = require('fs-extra');3const glob = require('glob');4const _ = require('lodash');5const plist = require('plist');6function parsePlist(plistPath) {7 const plistContent = fs.readFileSync(plistPath, 'utf8');8 let plistResult = {};9 try {10 plistResult = plist.parse(plistContent);11 } catch (e) {12 console.error('Unable to parse plist', plistPath);13 }14 return plistResult;15}16const projectInfoPlistPath = _.first(glob.sync('?(**)/Info.plist'));17const infoPlistWritePath = process.argv[2] || projectInfoPlistPath;18if (!projectInfoPlistPath) {19 console.error('Project Info.plist not found!');20 process.exit(1);21}22const projectPlist = parsePlist(projectInfoPlistPath);23const infoPlistFiles = glob.sync('../extensions/?(**)/app/ios/Info.plist');24/**25 * Merges all Info.plist files from extensions with one from the platform. If value of the key is26 * array it concatenate both arrays.27 */28const extensionsPlist = _.reduce(infoPlistFiles, (finalPlist, extPlistPath) => {29 const extPlist = parsePlist(extPlistPath);30 return _.mergeWith(finalPlist, extPlist, (objValue, srcValue) => {31 if (_.isArray(objValue)) {32 return _.uniq(objValue.concat(srcValue));33 }34 return srcValue;35 });36}, projectPlist);...
Apple.js
Source:Apple.js
...4describe("Apple", () => { // Hrm, how much time ya got?5 describe("#parsePlist", function() {6 this.timeout(0);7 it("should parse a sample library", () => {8 return Apple.parsePlist(EXAMPLE_LIBRARY);9 });10 });11 describe("#importFromFile", function() {12 it("should read a library from a file", () => {13 return Apple.importFromFile(EXAMPLE_LIBRARY);14 });15 });...
Using AI Code Generation
1const { parsePlist } = require('cypress/lib/util/parsePlist')2const { parsePlist } = require('cypress/lib/util/parsePlist')3const { parsePlist } = require('cypress/lib/util/parsePlist')4const { parsePlist } = require('cypress/lib/util/parsePlist')5const { parsePlist } = require('cypress/lib/util/parsePlist')6const { parsePlist } = require('cypress/lib/util/parsePlist')7const { parsePlist } = require('cypress/lib/util/parsePlist')8const { parsePlist } = require('cypress/lib/util/parsePlist')9const { parsePlist } = require('cypress/lib/util/parsePlist')
Using AI Code Generation
1const cypress = require('cypress')2const fs = require('fs')3const plist = require('plist')4const options = {5 reporterOptions: {6 }7}8cypress.run(options)9 .then((results) => {10 const plistResults = plist.build(jsonResults)11 fs.writeFileSync('test-results/results.plist', plistResults)12 })13 .catch((err) => {14 console.error(err)15 })16{17 "reporterOptions": {18 }19}20![Test Results in Azure DevOps](./images/test-results-in-azure-devops.png)
Using AI Code Generation
1Cypress.Commands.add("parsePlist", (path) => {2 cy.task("parsePlist", path).then((plist) => {3 return plist;4 });5});6Cypress.Commands.add("parsePlist", (path) => {7 cy.task("parsePlist", path).then((plist) => {8 return plist;9 });10});11Cypress.Commands.add("parsePlist", (path) => {12 cy.task("parsePlist", path).then((plist) => {13 return plist;14 });15});16Cypress.Commands.add("parsePlist", (path) => {17 cy.task("parsePlist", path).then((plist) => {18 return plist;19 });20});21Cypress.Commands.add("parsePlist", (path) => {22 cy.task("parsePlist", path).then((plist) => {23 return plist;24 });25});26Cypress.Commands.add("parsePlist", (path) => {27 cy.task("parsePlist", path).then((plist) => {28 return plist;29 });30});31Cypress.Commands.add("parsePlist", (path) => {32 cy.task("parsePlist", path).then((plist) => {33 return plist;34 });35});
Using AI Code Generation
1const cypress = require("cypress");2const fs = require("fs");3 .parsePlist("path/to/Info.plist")4 .then((plist) => {5 console.log(plist);6 })7 .catch((err) => {8 console.error(err);9 });
Using AI Code Generation
1const cypress = require('cypress')2const fs = require('fs')3const plist = require('plist')4const runCypress = () => {5 cypress.run({6 }).then((results) => {7 const resultsPlist = fs.readFileSync(results.runs[0].reporterOptions.reporterOptions.reportDir + '/results.plist', 'utf8')8 const resultsJSON = plist.parse(resultsPlist)9 console.log(resultsJSON)10 })11}12runCypress()13{14 "reporterOptions": {15 "mochawesomeReporterOptions": {16 }17 },18 "env": {19 }20}21const cypress = require('cypress')22const fs = require('fs')23const plist = require('plist')24const { merge } = require('m
Using AI Code Generation
1const fs = require('fs')2const plist = require('plist')3describe('parse plist file', () => {4 it('parses plist file', () => {5 const plistData = fs.readFileSync('path/to/plist/file', 'utf-8')6 const jsonObj = plist.parse(plistData)7 console.log(jsonObj)8 })9})
Cypress is a renowned Javascript-based open-source, easy-to-use end-to-end testing framework primarily used for testing web applications. Cypress is a relatively new player in the automation testing space and has been gaining much traction lately, as evidenced by the number of Forks (2.7K) and Stars (42.1K) for the project. LambdaTest’s Cypress Tutorial covers step-by-step guides that will help you learn from the basics till you run automation tests on LambdaTest.
You can elevate your expertise with end-to-end testing using the Cypress automation framework and stay one step ahead in your career by earning a Cypress certification. Check out our Cypress 101 Certification.
Watch this 3 hours of complete tutorial to learn the basics of Cypress and various Cypress commands with the Cypress testing at LambdaTest.
Get 100 minutes of automation test minutes FREE!!