mirror of
https://github.com/Alfresco/alfresco-content-app.git
synced 2025-07-24 17:31:52 +00:00
[ACS-8153] delete protractor e2e configuration and files (#3885)
* [ACS-8153] delete protractor e2e configuration and files * [ACS-8153] util fix * [ACS-8153] pr fix * [ACS-81532] remove e2e package.json * [ACS-81532] remove chrome configuration * package-lock file
This commit is contained in:
@@ -26,7 +26,7 @@ import * as fs from 'fs';
|
||||
import { ApiClientFactory } from './api-client-factory';
|
||||
import { Utils } from '../utils';
|
||||
import { NodeBodyCreate, NodeEntry, ResultSetPaging } from '@alfresco/js-api';
|
||||
import { waitForApi } from '@alfresco/aca-testing-shared';
|
||||
import { waitForApi } from '@alfresco/playwright-shared';
|
||||
|
||||
export class FileActionsApi {
|
||||
private apiService: ApiClientFactory;
|
||||
|
@@ -23,7 +23,7 @@
|
||||
*/
|
||||
|
||||
import { Page } from '@playwright/test';
|
||||
import { GenericLogger, LoggerLike } from '@alfresco/aca-testing-shared';
|
||||
import { GenericLogger, LoggerLike } from '@alfresco/playwright-shared';
|
||||
|
||||
export abstract class PlaywrightBase {
|
||||
public page: Page;
|
||||
|
46
projects/aca-playwright-shared/src/utils/api.ts
Normal file
46
projects/aca-playwright-shared/src/utils/api.ts
Normal file
@@ -0,0 +1,46 @@
|
||||
/*!
|
||||
* Copyright © 2005-2024 Hyland Software, Inc. and its affiliates. All rights reserved.
|
||||
*
|
||||
* Alfresco Example Content Application
|
||||
*
|
||||
* This file is part of the Alfresco Example Content Application.
|
||||
* If the software was purchased under a paid Alfresco license, the terms of
|
||||
* the paid license agreement will prevail. Otherwise, the software is
|
||||
* provided under the following open source license terms:
|
||||
*
|
||||
* The Alfresco Example Content Application is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Lesser General Public License as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* The Alfresco Example Content Application is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* along with Alfresco. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
export type ApiResultPredicate<T> = (result: T) => boolean;
|
||||
export type ApiCall<T> = () => Promise<T>;
|
||||
|
||||
export async function waitForApi<T>(apiCall: ApiCall<T>, predicate: ApiResultPredicate<T>, retry: number = 30, delay: number = 1000) {
|
||||
const apiCallWithPredicateChecking = async () => {
|
||||
const apiCallResult = await apiCall();
|
||||
if (predicate(apiCallResult)) {
|
||||
return Promise.resolve(apiCallResult);
|
||||
} else {
|
||||
return Promise.reject(new Error(`API call did not satisfy predicate: ${JSON.stringify(apiCallResult)}`));
|
||||
}
|
||||
};
|
||||
|
||||
return retryCall(apiCallWithPredicateChecking, retry, delay);
|
||||
}
|
||||
|
||||
function retryCall(fn: () => Promise<any>, retry: number = 30, delay: number = 1000): Promise<string> {
|
||||
const pause = (duration) => new Promise((res) => setTimeout(res, duration));
|
||||
const run = (retries) => fn().catch((err) => (retries > 1 ? pause(delay).then(() => run(retries - 1)) : Promise.reject(new Error(`API call did not satisfy predicate: ${JSON.stringify(err)}`))));
|
||||
|
||||
return run(retry);
|
||||
}
|
@@ -30,3 +30,5 @@ export * from './utils';
|
||||
export * from './library-errors';
|
||||
export * from './config';
|
||||
export * from './error-strings';
|
||||
export * from './api';
|
||||
export * from './logger';
|
||||
|
88
projects/aca-playwright-shared/src/utils/logger.ts
Normal file
88
projects/aca-playwright-shared/src/utils/logger.ts
Normal file
@@ -0,0 +1,88 @@
|
||||
/*!
|
||||
* Copyright © 2005-2024 Hyland Software, Inc. and its affiliates. All rights reserved.
|
||||
*
|
||||
* Alfresco Example Content Application
|
||||
*
|
||||
* This file is part of the Alfresco Example Content Application.
|
||||
* If the software was purchased under a paid Alfresco license, the terms of
|
||||
* the paid license agreement will prevail. Otherwise, the software is
|
||||
* provided under the following open source license terms:
|
||||
*
|
||||
* The Alfresco Example Content Application is free software: you can redistribute it and/or modify
|
||||
* it under the terms of the GNU Lesser General Public License as published by
|
||||
* the Free Software Foundation, either version 3 of the License, or
|
||||
* (at your option) any later version.
|
||||
*
|
||||
* The Alfresco Example Content Application is distributed in the hope that it will be useful,
|
||||
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||
* GNU Lesser General Public License for more details.
|
||||
*
|
||||
* You should have received a copy of the GNU Lesser General Public License
|
||||
* from Hyland Software. If not, see <http://www.gnu.org/licenses/>.
|
||||
*/
|
||||
|
||||
/* eslint-disable @typescript-eslint/naming-convention */
|
||||
|
||||
export const infoColor = '\x1b[36m%s\x1b[0m';
|
||||
export const logColor = '\x1b[35m%s\x1b[0m';
|
||||
export const warnColor = '\x1b[33m%s\x1b[0m';
|
||||
export const errorColor = '\x1b[31m%s\x1b[0m';
|
||||
|
||||
export type LOG_LEVEL = 'TRACE' | 'DEBUG' | 'INFO' | 'WARN' | 'ERROR' | 'SILENT';
|
||||
|
||||
export class LogLevelsEnum extends Number {
|
||||
public static readonly TRACE: number = 5;
|
||||
public static readonly DEBUG: number = 4;
|
||||
public static readonly INFO: number = 3;
|
||||
public static readonly WARN: number = 2;
|
||||
public static readonly ERROR: number = 1;
|
||||
public static readonly SILENT: number = 0;
|
||||
}
|
||||
|
||||
export const logLevels: { level: LogLevelsEnum; name: LOG_LEVEL }[] = [
|
||||
{ level: LogLevelsEnum.TRACE, name: 'TRACE' },
|
||||
{ level: LogLevelsEnum.DEBUG, name: 'DEBUG' },
|
||||
{ level: LogLevelsEnum.INFO, name: 'INFO' },
|
||||
{ level: LogLevelsEnum.WARN, name: 'WARN' },
|
||||
{ level: LogLevelsEnum.ERROR, name: 'ERROR' },
|
||||
{ level: LogLevelsEnum.SILENT, name: 'SILENT' }
|
||||
];
|
||||
|
||||
export interface LoggerLike {
|
||||
info(...messages: string[]): void;
|
||||
log(...messages: string[]): void;
|
||||
warn(...messages: string[]): void;
|
||||
error(...messages: string[]): void;
|
||||
}
|
||||
|
||||
/* eslint-disable no-console */
|
||||
export class GenericLogger implements LoggerLike {
|
||||
private readonly level: LogLevelsEnum;
|
||||
|
||||
constructor(logLevel: string) {
|
||||
this.level = logLevels.find(({ name }) => name === logLevel)?.level || LogLevelsEnum.ERROR;
|
||||
}
|
||||
|
||||
info(...messages: string[]): void {
|
||||
if (Number(this.level) >= LogLevelsEnum.INFO) {
|
||||
console.log(infoColor, messages.join(''));
|
||||
}
|
||||
}
|
||||
|
||||
log(...messages: string[]): void {
|
||||
if (Number(this.level) >= LogLevelsEnum.TRACE) {
|
||||
console.log(logColor, messages.join(''));
|
||||
}
|
||||
}
|
||||
|
||||
warn(...messages: string[]): void {
|
||||
if (Number(this.level) >= LogLevelsEnum.WARN) {
|
||||
console.log(warnColor, messages.join(''));
|
||||
}
|
||||
}
|
||||
|
||||
error(...messages: string[]): void {
|
||||
console.log(errorColor, messages.join(''));
|
||||
}
|
||||
}
|
Reference in New Issue
Block a user