mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-05-12 17:04:46 +00:00
[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:
parent
39541bf078
commit
fa998cdd3e
10
e2e/e2e-config/utils/build-number.js
Normal file
10
e2e/e2e-config/utils/build-number.js
Normal 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;
|
@ -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}`);
|
|
||||||
try {
|
|
||||||
console.log('--- trying to get the Builds folder ');
|
|
||||||
folderNode = await alfrescoJsApi.nodes.getNode('-my-', {
|
folderNode = await alfrescoJsApi.nodes.getNode('-my-', {
|
||||||
'relativePath': `${screenshotSavePath}/retry-${retryCount}`,
|
'relativePath': `Builds/ACA-${buildNumber()}/${folderName}/retry-${retryCount}`,
|
||||||
'nodeType': 'cm:folder'
|
'nodeType': 'cm:folder'
|
||||||
}, {}, {
|
}, {}, {
|
||||||
'overwrite': true
|
'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);
|
|
||||||
|
|
||||||
try {
|
let file = fs.createReadStream(pathFile);
|
||||||
await alfrescoJsApi.upload.uploadFile(
|
await alfrescoJsApi.upload.uploadFile(
|
||||||
file,
|
file,
|
||||||
'',
|
'',
|
||||||
folderNode.entry.id,
|
folderNode.entry.id,
|
||||||
null,
|
null,
|
||||||
{
|
{
|
||||||
'name': `e2e-result-${process.env.TRAVIS_JOB_NUMBER}-${retryCount}.tar`,
|
'name': `e2e-result-${folderName}-${retryCount}.tar`,
|
||||||
'nodeType': 'cm:content',
|
'nodeType': 'cm:content',
|
||||||
'autoRename': true
|
'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
|
|
||||||
};
|
|
||||||
|
@ -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 };
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
@ -185,7 +185,9 @@
|
|||||||
]
|
]
|
||||||
}
|
}
|
||||||
]
|
]
|
||||||
}
|
},
|
||||||
|
"multi-value-pipe-separator": ", ",
|
||||||
|
"multi-value-chips": true
|
||||||
},
|
},
|
||||||
"search": {
|
"search": {
|
||||||
"filterWithContains": true,
|
"filterWithContains": true,
|
||||||
|
@ -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);
|
||||||
});
|
});
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -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);
|
||||||
}
|
}
|
||||||
|
Loading…
x
Reference in New Issue
Block a user