123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899 |
- /**
- * Yellow Lab Tools main file
- */
- var async = require('async');
- var phantomas = require('phantomas');
- var PhantomasWrapper = function() {
- 'use strict';
- /**
- * This is the phantomas launcher. It merges user chosen options into the default options
- * Available options :
- *
- * - timeout : in seconds (default 60)
- * - jsDeepAnalysis : should we inspect subrequests in the javascript execution tree (reported durations of main tasks will be slower than usual)
- *
- */
- this.execute = function(task, callback) {
- var options = {
- // Cusomizable options
- timeout: task.options.timeout || 60,
- 'js-deep-analysis': task.options.jsDeepAnalysis || false,
- // Mandatory
- reporter: 'json:pretty',
- 'skip-modules': [
- //'ajaxRequests',
- //'alerts',
- 'blockDomains',
- //'cacheHits',
- //'caching',
- //'console',
- //'cookies',
- //'documentHeight',
- //'domains',
- 'domComplexity',
- 'domMutations',
- 'domQueries',
- 'eventListeners',
- 'filmStrip',
- //'jQuery',
- //'jserrors',
- 'har',
- //'headers',
- //'localStorage',
- //'mainRequest',
- 'pageSource',
- //'redirects',
- //'requestsStats',
- 'screenshot',
- //'staticAssets',
- //'timeToFirst',
- 'waitForSelector',
- 'windowPerformance'
- ].join(','),
- 'include-dirs': [
- 'phantomas_custom/core',
- 'phantomas_custom/modules'
- ].join(',')
- };
- // Output the command line for debugging purpose
- console.log('If you want to reproduce the phantomas task only, copy the following command line:');
- var optionsString = '';
- for (var opt in options) {
- optionsString += ' ' + '--' + opt + '=' + options[opt];
- }
- console.log('node node_modules/phantomas/bin/phantomas.js --url=' + task.url + optionsString + ' --verbose');
- // It's time to launch the test!!!
- var triesNumber = 3;
- async.retry(triesNumber, function(cb) {
- phantomas(task.url, options, function(err, json, results) {
- console.log('Returning from Phantomas');
- // Adding some YellowLabTools errors here
- if (!json || !json.metrics || !json.metrics.javascriptExecutionTree) {
- err = 1001;
- }
- if (err) {
- console.log('Attempt failed for test id ' + task.testId + '. Error code ' + err);
- }
- cb(err, {json: json, results: results});
- });
- }, function(err, data) {
- if (err) {
- console.log('All ' + triesNumber + ' attemps failed for test id ' + task.testId);
- }
- callback(err, data.json, data.results);
- });
- };
- };
- module.exports = new PhantomasWrapper();
|