change plugin (#1663)

* change plugin

* fix

* fix upload
This commit is contained in:
Eugenio Romano 2020-09-09 14:42:47 +01:00 committed by GitHub
parent eee0c65f26
commit 9d52b366a1
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
5 changed files with 122 additions and 118 deletions

View File

@ -1,10 +0,0 @@
const buildNumber = () => {
let buildNumber = process.env.TRAVIS_BUILD_NUMBER;
if (!buildNumber) {
process.env.TRAVIS_BUILD_NUMBER = Date.now();
}
return process.env.TRAVIS_BUILD_NUMBER;
}
module.exports = buildNumber;

View File

@ -1,69 +1,67 @@
const path = require('path');
const fs = require('fs'); const fs = require('fs');
const path = require('path');
const AlfrescoApi = require('@alfresco/js-api').AlfrescoApiCompatibility; const AlfrescoApi = require('@alfresco/js-api').AlfrescoApiCompatibility;
const buildNumber = require('./build-number');
const configScreenshotsPath = path.join(`${path.resolve(__dirname)}/../../../e2e-output/screenshots/`);
const rimraf = require('rimraf');
uploadOutput = async function() { function buildNumber() {
let buildNumber = process.env.TRAVIS_BUILD_NUMBER;
let alfrescoJsApi = new AlfrescoApi({ provider: 'ECM', hostEcm: process.env.SCREENSHOT_URL }); if (!buildNumber) {
alfrescoJsApi.login(process.env.SCREENSHOT_USERNAME, process.env.SCREENSHOT_PASSWORD); process.env.TRAVIS_BUILD_NUMBER = Date.now();
await saveScreenshots(alfrescoJsApi);
rimraf(configScreenshotsPath, function () {
console.log('done delete screenshot');
});
} }
async function saveScreenshots(alfrescoJsApi) { return process.env.TRAVIS_BUILD_NUMBER;
let files = fs.readdirSync(configScreenshotsPath); }
if (files && files.length > 0) { async function uploadScreenshot(retryCount, suffixFileName) {
console.log(`Start uploading report ${retryCount}`);
let folder; let alfrescoJsApi = new AlfrescoApi({
provider: 'ECM',
hostEcm: process.env.SCREENSHOT_URL
});
await alfrescoJsApi.login(process.env.SCREENSHOT_USERNAME, process.env.SCREENSHOT_PASSWORD);
let folderNode;
try { try {
folder = await alfrescoJsApi.nodes.addNode('-my-', { folderNode = await alfrescoJsApi.nodes.addNode('-my-', {
'name': `screenshot`, 'name': `retry-${retryCount}`,
'relativePath': `Builds/ACA-${buildNumber()}`, 'relativePath': `Builds/ACA/${buildNumber()}/`,
'nodeType': 'cm:folder' 'nodeType': 'cm:folder'
}, {}, { }, {}, {
'overwrite': true 'overwrite': true
}); });
} catch (error) { } catch (error) {
folder = await alfrescoJsApi.nodes.getNode('-my-', { folderNode = await alfrescoJsApi.nodes.getNode('-my-', {
'relativePath': `Builds/ACA-${buildNumber()}/screenshot`, 'relativePath': `Builds/ACA/${buildNumber()}/retry-${retryCount}`,
'nodeType': 'cm:folder' 'nodeType': 'cm:folder'
}, {}, { }, {}, {
'overwrite': true 'overwrite': true
}); });
} }
for (const fileName of files) { fs.renameSync(path.resolve(__dirname, '../../e2e-output/'), path.resolve(__dirname, `../../e2e-output-${retryCount}/`))
let pathFile = path.join(configScreenshotsPath, fileName);
const child_process = require("child_process");
child_process.execSync(` tar -czvf ../e2e-result-${suffixFileName}-${retryCount}.tar .`, {
cwd: path.resolve(__dirname, `../../e2e-output-${retryCount}/`)
});
let pathFile = path.join(__dirname, `../../e2e-result-${suffixFileName}-${retryCount}.tar`);
let file = fs.createReadStream(pathFile); let file = fs.createReadStream(pathFile);
let safeFileName = fileName.replace(new RegExp('"', 'g'), '');
try {
await alfrescoJsApi.upload.uploadFile( await alfrescoJsApi.upload.uploadFile(
file, file,
'', '',
folder.entry.id, folderNode.entry.id,
null, null,
{ {
'name': safeFileName, 'name': `e2e-result-${suffixFileName}-${retryCount}.tar`,
'nodeType': 'cm:content', 'nodeType': 'cm:content',
'autoRename': true 'autoRename': true
} }
); );
}catch(error){
console.log(error);
} }
}
}
};
module.exports = uploadOutput; module.exports = {
uploadScreenshot: uploadScreenshot
};

96
package-lock.json generated
View File

@ -4533,6 +4533,12 @@
"integrity": "sha512-7p4Kn/gffhQaavNfyDFg7LS5S/UT1JAjyGd4UqR2+jzoYF02eDkj0Ec3+48TsIa4zghjLY87nQHIh/ecK9qLdw==", "integrity": "sha512-7p4Kn/gffhQaavNfyDFg7LS5S/UT1JAjyGd4UqR2+jzoYF02eDkj0Ec3+48TsIa4zghjLY87nQHIh/ecK9qLdw==",
"dev": true "dev": true
}, },
"circular-json": {
"version": "0.5.9",
"resolved": "https://registry.npmjs.org/circular-json/-/circular-json-0.5.9.tgz",
"integrity": "sha512-4ivwqHpIFJZBuhN3g/pEcdbnGUywkBblloGbkglyloVjjR3uT6tieI89MVOfbP2tHX5sgb01FuLgAOzebNlJNQ==",
"dev": true
},
"class-utils": { "class-utils": {
"version": "0.3.6", "version": "0.3.6",
"resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz", "resolved": "https://registry.npmjs.org/class-utils/-/class-utils-0.3.6.tgz",
@ -9703,41 +9709,6 @@
"colors": "1.4.0" "colors": "1.4.0"
} }
}, },
"jasmine2-protractor-utils": {
"version": "1.3.0",
"resolved": "https://registry.npmjs.org/jasmine2-protractor-utils/-/jasmine2-protractor-utils-1.3.0.tgz",
"integrity": "sha1-lARqq7x0rQpLdGvNTcMFB1h7Z+M=",
"dev": true,
"requires": {
"fs-extra": "^0.26.5",
"mkdirp": "^0.5.1",
"q": "^1.4.1"
},
"dependencies": {
"fs-extra": {
"version": "0.26.7",
"resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-0.26.7.tgz",
"integrity": "sha1-muH92UiXeY7at20JGM9C0MMYT6k=",
"dev": true,
"requires": {
"graceful-fs": "^4.1.2",
"jsonfile": "^2.1.0",
"klaw": "^1.0.0",
"path-is-absolute": "^1.0.0",
"rimraf": "^2.2.8"
}
},
"jsonfile": {
"version": "2.4.0",
"resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-2.4.0.tgz",
"integrity": "sha1-NzaitCi4e72gzIO1P6PWM6NcKug=",
"dev": true,
"requires": {
"graceful-fs": "^4.1.6"
}
}
}
},
"jasminewd2": { "jasminewd2": {
"version": "2.2.0", "version": "2.2.0",
"resolved": "https://registry.npmjs.org/jasminewd2/-/jasminewd2-2.2.0.tgz", "resolved": "https://registry.npmjs.org/jasminewd2/-/jasminewd2-2.2.0.tgz",
@ -10356,13 +10327,13 @@
"integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==", "integrity": "sha512-dcS1ul+9tmeD95T+x28/ehLgd9mENa3LsvDTtzm3vyBEO7RPptvAD+t44WVXaUjTBRcrpFeFlC8WCruUR456hw==",
"dev": true "dev": true
}, },
"klaw": { "klaw-sync": {
"version": "1.3.1", "version": "6.0.0",
"resolved": "https://registry.npmjs.org/klaw/-/klaw-1.3.1.tgz", "resolved": "https://registry.npmjs.org/klaw-sync/-/klaw-sync-6.0.0.tgz",
"integrity": "sha1-QIhDO0azsbolnXh4XY6W9zugJDk=", "integrity": "sha512-nIeuVSzdCCs6TDPTqI8w1Yre34sSq7AkZ4B3sfOBbI2CgVSB4Du4aLQijFU2+lhAFCwt9+42Hel6lQNIv6AntQ==",
"dev": true, "dev": true,
"requires": { "requires": {
"graceful-fs": "^4.1.9" "graceful-fs": "^4.1.11"
} }
}, },
"kleur": { "kleur": {
@ -13695,6 +13666,45 @@
} }
} }
}, },
"protractor-screenshoter-plugin": {
"version": "0.10.3",
"resolved": "https://registry.npmjs.org/protractor-screenshoter-plugin/-/protractor-screenshoter-plugin-0.10.3.tgz",
"integrity": "sha512-OF9kGe1rMxBQY4uXzXQUFT14EB83rz8DlDcxmH5HcOHPBpUhGh+Nwo7+K87w1LoLcTuGdG7Bz+/hGwoGguDfsA==",
"dev": true,
"requires": {
"circular-json": "^0.5.1",
"fs-extra": "^7.0.0",
"klaw-sync": "^6.0.0",
"lodash": "^4.17.11",
"mkdirp": "^0.5.1",
"moment": "^2.20.1",
"q": "^1.5.1",
"screenshoter-report-analyzer": "^0.6",
"uuid": "^3.1.0"
},
"dependencies": {
"fs-extra": {
"version": "7.0.1",
"resolved": "https://registry.npmjs.org/fs-extra/-/fs-extra-7.0.1.tgz",
"integrity": "sha512-YJDaCJZEnBmcbw13fvdAM9AwNOJwOzrE4pqMqBq5nFiEqXUqHwlK4B+3pUw6JNvfSPtX05xFHtYy/1ni01eGCw==",
"dev": true,
"requires": {
"graceful-fs": "^4.1.2",
"jsonfile": "^4.0.0",
"universalify": "^0.1.0"
}
},
"jsonfile": {
"version": "4.0.0",
"resolved": "https://registry.npmjs.org/jsonfile/-/jsonfile-4.0.0.tgz",
"integrity": "sha1-h3Gq4HmbZAdrdmQPygWPnBDjPss=",
"dev": true,
"requires": {
"graceful-fs": "^4.1.6"
}
}
}
},
"protractor-smartrunner": { "protractor-smartrunner": {
"version": "0.1.1", "version": "0.1.1",
"resolved": "https://registry.npmjs.org/protractor-smartrunner/-/protractor-smartrunner-0.1.1.tgz", "resolved": "https://registry.npmjs.org/protractor-smartrunner/-/protractor-smartrunner-0.1.1.tgz",
@ -14795,6 +14805,12 @@
"ajv-keywords": "^3.4.1" "ajv-keywords": "^3.4.1"
} }
}, },
"screenshoter-report-analyzer": {
"version": "0.6.0",
"resolved": "https://registry.npmjs.org/screenshoter-report-analyzer/-/screenshoter-report-analyzer-0.6.0.tgz",
"integrity": "sha1-Cm+I1fXRrBa2z3Ji7/ujH+5I7RI=",
"dev": true
},
"select-hose": { "select-hose": {
"version": "2.0.0", "version": "2.0.0",
"resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz", "resolved": "https://registry.npmjs.org/select-hose/-/select-hose-2.0.0.tgz",

View File

@ -95,7 +95,7 @@
"husky": "^4.2.5", "husky": "^4.2.5",
"jasmine-core": "~3.6.0", "jasmine-core": "~3.6.0",
"jasmine-spec-reporter": "~5.0.2", "jasmine-spec-reporter": "~5.0.2",
"jasmine2-protractor-utils": "1.3.0", "protractor-screenshoter-plugin": "0.10.3",
"karma": "^5.1.1", "karma": "^5.1.1",
"karma-chrome-launcher": "^3.1.0", "karma-chrome-launcher": "^3.1.0",
"karma-coverage-istanbul-reporter": "^3.0.3", "karma-coverage-istanbul-reporter": "^3.0.3",

View File

@ -7,7 +7,7 @@ const fs = require('fs');
const resolve = require('path').resolve; const resolve = require('path').resolve;
const logger = require('./tools/helpers/logger'); const logger = require('./tools/helpers/logger');
const retry = require('protractor-retry').retry; const retry = require('protractor-retry').retry;
const uploadOutput = require('./e2e/e2e-config/utils/upload-output'); const { uploadScreenshot } = require('./e2e/e2e-config/utils/upload-output');
require('dotenv').config({path: process.env.ENV_FILE}); require('dotenv').config({path: process.env.ENV_FILE});
@ -163,16 +163,16 @@ exports.config = {
...(process.env.CI ? SmartRunner.withOptionalExclusions(resolve(__dirname, './e2e/protractor.excludes.json')) : {}) ...(process.env.CI ? SmartRunner.withOptionalExclusions(resolve(__dirname, './e2e/protractor.excludes.json')) : {})
}, },
plugins: [ plugins: [{
{ package: 'protractor-screenshoter-plugin',
package: 'jasmine2-protractor-utils', screenshotPath: path.resolve(__dirname, '../e2e-output/'),
disableScreenshot: false, screenshotOnExpect: 'failure',
screenshotOnExpectFailure: true, withLogs: true,
screenshotOnSpecFailure: false, writeReportFreq: 'end',
clearFoldersBeforeTest: true, imageToAscii: 'none',
screenshotPath: path.resolve(__dirname, 'e2e-output/screenshots/') htmlOnExpect: 'none',
} htmlOnSpec: 'none'
], }],
onCleanUp(results) { onCleanUp(results) {
if (process.env.CI) { if (process.env.CI) {
@ -230,7 +230,7 @@ exports.config = {
console.log(`Save screenshot is ${SAVE_SCREENSHOT}, trying to save screenshots.`); console.log(`Save screenshot is ${SAVE_SCREENSHOT}, trying to save screenshots.`);
try { try {
await uploadOutput(); await uploadScreenshot(1, 'ACA');
console.log('Screenshots saved successfully.'); console.log('Screenshots saved successfully.');
} catch (e) { } catch (e) {
console.log('Error happened while trying to upload screenshots and test reports: ', e); console.log('Error happened while trying to upload screenshots and test reports: ', e);