[ADF-5391] Cannot update multi-value metadata property (#2146)

* [ADF-5391] Cannot update multi-value metadata property

* * fix lint

* * remove unwanted lints

* fix upload screenshot

* fix upload screenshot

Co-authored-by: Eugenio Romano <eugenio.romano@alfresco.com>
This commit is contained in:
Dharan 2021-05-19 02:02:47 +05:30 committed by GitHub
parent 39541bf078
commit fa998cdd3e
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
7 changed files with 71 additions and 99 deletions

View File

@ -0,0 +1,10 @@
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,112 +1,65 @@
const fs = require('fs');
const path = require('path'); const path = require('path');
const fs = require('fs');
const AlfrescoApi = require('@alfresco/js-api').AlfrescoApiCompatibility; const AlfrescoApi = require('@alfresco/js-api').AlfrescoApiCompatibility;
const buildNumber = require('./build-number');
const outputDir = path.resolve(__dirname, '../../../e2e-output/');
function buildNumber() { uploadOutput = async function (retryCount = 1) {
let buildNumber = process.env.TRAVIS_BUILD_NUMBER; await saveScreenshots(retryCount);
if (!buildNumber) { };
process.env.TRAVIS_BUILD_NUMBER = Date.now();
}
return process.env.TRAVIS_BUILD_NUMBER; async function saveScreenshots(retryCount) {
} const folderName = process.env.TRAVIS_JOB_NAME.replace(/[^a-z0-9]/gi, '_').toLowerCase();
console.log(`Start uploading report in ${folderName}`);
async function uploadScreenshot(retryCount) {
console.log(`Start uploading report ${retryCount} on ${process.env.SCREENSHOT_URL}`);
let alfrescoJsApi = new AlfrescoApi({ let alfrescoJsApi = new AlfrescoApi({
provider: 'ECM', provider: 'ECM',
hostEcm: process.env.SCREENSHOT_URL hostEcm: process.env.SCREENSHOT_URL
}); });
try { await alfrescoJsApi.login(process.env.SCREENSHOT_USERNAME, process.env.SCREENSHOT_PASSWORD);
await alfrescoJsApi.login(process.env.SCREENSHOT_USERNAME, process.env.SCREENSHOT_PASSWORD);
} catch (error) {
console.log(` ---- Upload output - login failed : ${error}`);
}
let folderNode; let folderNode;
const screenshotSavePath = `Builds/ACA/${buildNumber()}/${process.env.TRAVIS_JOB_NAME.replace(/[^a-z0-9]/gi, '_').toLowerCase()}`;
try { try {
folderNode = await alfrescoJsApi.nodes.addNode('-my-', { folderNode = await alfrescoJsApi.nodes.addNode('-my-', {
'name': `retry-${retryCount}`, 'name': `retry-${retryCount}`,
'relativePath': screenshotSavePath, 'relativePath': `Builds/ACA-${buildNumber()}/${folderName}/`,
'nodeType': 'cm:folder' 'nodeType': 'cm:folder'
}, {}, { }, {}, {
'overwrite': true 'overwrite': true
}); });
} catch (error) { } catch (error) {
console.log(`--- Upload output - add node failed. Maybe already exists. ${error}`); folderNode = await alfrescoJsApi.nodes.getNode('-my-', {
try { 'relativePath': `Builds/ACA-${buildNumber()}/${folderName}/retry-${retryCount}`,
console.log('--- trying to get the Builds folder '); 'nodeType': 'cm:folder'
folderNode = await alfrescoJsApi.nodes.getNode('-my-', { }, {}, {
'relativePath': `${screenshotSavePath}/retry-${retryCount}`, 'overwrite': true
'nodeType': 'cm:folder' });
}, {}, {
'overwrite': true
});
} catch (error) {
console.log(`--- Upload out - get node failed. ${error}`);
}
} }
const screenShotsPath = path.resolve(__dirname, '../../../e2e-output/screenshots/'); fs.renameSync(outputDir, path.join(`${outputDir}-${folderName}-${retryCount}/`));
let files = fs.readdirSync(screenShotsPath);
try {
for (const fileName of files) {
let pathFile = path.join(screenShotsPath, fileName);
let file = fs.createReadStream(pathFile);
let safeFileName = fileName.replace(new RegExp('"', 'g'), '');
await alfrescoJsApi.upload.uploadFile(
file,
'',
folderNode.entry.id,
null,
{
name: safeFileName,
nodeType: 'cm:content',
autoRename: true,
}
);
}
} catch (error) {
console.log(`Upload failed: ${error}`);
}
fs.renameSync(path.resolve(__dirname, '../../../e2e-output/'), path.resolve(__dirname, `../../e2e-output-${retryCount}/`))
const child_process = require("child_process"); const child_process = require("child_process");
child_process.execSync(` tar -czvf ../e2e-result-${process.env.TRAVIS_JOB_NUMBER}-${retryCount}.tar .`, { child_process.execSync(` tar -czvf ../e2e-result-${folderName}-${retryCount}.tar .`, {
cwd: path.resolve(__dirname, `../../e2e-output-${retryCount}/`) cwd: `${outputDir}-${folderName}-${retryCount}/`
}); });
let pathFile = path.join(__dirname, `../../e2e-result-${process.env.TRAVIS_JOB_NUMBER}-${retryCount}.tar`); let pathFile = path.join(outputDir, `../e2e-result-${folderName}-${retryCount}.tar`);
let file = fs.createReadStream(pathFile); let file = fs.createReadStream(pathFile);
await alfrescoJsApi.upload.uploadFile(
file,
'',
folderNode.entry.id,
null,
{
'name': `e2e-result-${folderName}-${retryCount}.tar`,
'nodeType': 'cm:content',
'autoRename': true
}
);
try {
await alfrescoJsApi.upload.uploadFile(
file,
'',
folderNode.entry.id,
null,
{
'name': `e2e-result-${process.env.TRAVIS_JOB_NUMBER}-${retryCount}.tar`,
'nodeType': 'cm:content',
'autoRename': true
}
);
} catch (error) {
throw new Error(`--- Upload output failed. ${error}`);
}
fs.rmdirSync(path.resolve(__dirname, `../../e2e-output-${retryCount}/`), { recursive: true });
} }
module.exports = { module.exports = uploadOutput;
uploadScreenshot: uploadScreenshot
};

View File

@ -278,9 +278,9 @@ export class AppExtensionService implements RuleContext {
presets = this.filterDisabled(mergeObjects(presets, ...elements)); presets = this.filterDisabled(mergeObjects(presets, ...elements));
try { try {
this.appConfig.config['content-metadata'] = { presets }; this.appConfig.config['content-metadata'].presets = presets;
} catch (error) { } catch (error) {
this.logger.error(error, '- could not change content-metadata from app.config -'); this.logger.error(error, '- could not change content-metadata presets from app.config -');
} }
return { presets }; return { presets };

View File

@ -4,11 +4,8 @@
require('dotenv').config({ path: process.env.ENV_FILE }); require('dotenv').config({ path: process.env.ENV_FILE });
const path = require('path'); const path = require('path');
const { SpecReporter } = require('jasmine-spec-reporter'); const { SpecReporter } = require('jasmine-spec-reporter');
const fs = require('fs');
const resolve = require('path').resolve;
const logger = require('./tools/helpers/logger');
const retry = require('protractor-retry-angular-cli').retry; const retry = require('protractor-retry-angular-cli').retry;
const { uploadScreenshot } = require('./e2e/e2e-config/utils/upload-output'); const { uploadOutput } = require('./e2e/e2e-config/utils/upload-output');
const smartRunnerFactory = require('./e2e/smartrunner-factory'); const smartRunnerFactory = require('./e2e/smartrunner-factory');
const projectRoot = path.resolve(__dirname); const projectRoot = path.resolve(__dirname);
@ -206,19 +203,24 @@ exports.config = {
afterLaunch: async function (statusCode) { afterLaunch: async function (statusCode) {
if (SAVE_SCREENSHOT && statusCode !== 0) { if (SAVE_SCREENSHOT && statusCode !== 0) {
console.log(`Save screenshot is ${SAVE_SCREENSHOT}, trying to save screenshots.`); console.log(`Status code is ${statusCode}, trying to save screenshots.`);
let retryCount = 1;
if (argv.retry) {
retryCount = ++argv.retry;
}
try { try {
await uploadScreenshot(1); await uploadOutput(retryCount);
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);
} }
} else { } else {
console.log(`Save screenshot is ${SAVE_SCREENSHOT}, no need to save screenshots.`); console.log(`Status code is ${statusCode}, no need to save screenshots.`);
} }
if (process.env.CI) { if (process.env.CI) {
return retry.afterLaunch(MAX_RETRIES); return retry.afterLaunch(process.env.RETRY_COUNT || 4, statusCode);
} }
} }
}; };

View File

@ -185,7 +185,9 @@
] ]
} }
] ]
} },
"multi-value-pipe-separator": ", ",
"multi-value-chips": true
}, },
"search": { "search": {
"filterWithContains": true, "filterWithContains": true,

View File

@ -40,6 +40,12 @@ describe('MetadataTabComponent', () => {
let store: Store<AppState>; let store: Store<AppState>;
let appConfig: AppConfigService; let appConfig: AppConfigService;
let extensions: AppExtensionService; let extensions: AppExtensionService;
const presets = {
default: {
includeAll: true
},
custom: []
};
setupTestBed({ setupTestBed({
imports: [CoreModule, AppTestingModule, ContentMetadataModule], imports: [CoreModule, AppTestingModule, ContentMetadataModule],
@ -54,25 +60,24 @@ describe('MetadataTabComponent', () => {
beforeEach(() => { beforeEach(() => {
appConfig = TestBed.inject(AppConfigService); appConfig = TestBed.inject(AppConfigService);
extensions = TestBed.inject(AppExtensionService); extensions = TestBed.inject(AppExtensionService);
appConfig.config['content-metadata'] = { presets };
}); });
it('should remain unchanged when metadata extension is missing', () => { it('should remain unchanged when metadata extension is missing', () => {
appConfig.config['content-metadata'] = 'initial config';
extensions.contentMetadata = null; extensions.contentMetadata = null;
fixture = TestBed.createComponent(MetadataTabComponent); fixture = TestBed.createComponent(MetadataTabComponent);
expect(appConfig.config['content-metadata']).toEqual('initial config'); expect(appConfig.config['content-metadata'].presets).toEqual(presets);
}); });
it('should be overwritten by the one from extension', () => { it('should be overwritten by the one from extension', () => {
appConfig.config['content-metadata'] = 'initial config'; extensions.contentMetadata = { presets: [{ 'new config': true }] };
extensions.contentMetadata = [{ 'new config': true }];
fixture = TestBed.createComponent(MetadataTabComponent); fixture = TestBed.createComponent(MetadataTabComponent);
expect(appConfig.config['content-metadata']).not.toEqual('initial config'); expect(appConfig.config['content-metadata'].presets).not.toEqual(presets);
expect(appConfig.config['content-metadata']).toEqual(extensions.contentMetadata); expect(appConfig.config['content-metadata'].presets).toEqual(extensions.contentMetadata.presets);
}); });
}); });

View File

@ -59,7 +59,7 @@ export class MetadataTabComponent implements OnInit, OnDestroy {
private contentMetadataService: ContentMetadataService private contentMetadataService: ContentMetadataService
) { ) {
if (this.extensions.contentMetadata) { if (this.extensions.contentMetadata) {
this.appConfig.config['content-metadata'] = this.extensions.contentMetadata; this.appConfig.config['content-metadata'].presets = this.extensions.contentMetadata.presets;
} }
this.displayAspect$ = this.store.select(infoDrawerMetadataAspect); this.displayAspect$ = this.store.select(infoDrawerMetadataAspect);
} }