mirror of
https://github.com/Alfresco/alfresco-ng2-components.git
synced 2025-07-24 17:32:15 +00:00
[AAE-7986] Migrate ADF from Travis to Github actions (#8050)
* rebased * [ci:force]
This commit is contained in:
@@ -31,6 +31,8 @@ enum TARGETS {
|
||||
const DOCKER_FILENAME = 'Dockerfile';
|
||||
export interface PublishArgs {
|
||||
tag?: string;
|
||||
dryrun?: boolean;
|
||||
verbose?: boolean;
|
||||
loginCheck?: boolean;
|
||||
loginUsername?: string;
|
||||
loginPassword?: string;
|
||||
@@ -44,7 +46,7 @@ export interface PublishArgs {
|
||||
|
||||
function loginPerform(args: PublishArgs) {
|
||||
logger.info(`Perform docker login...${args.loginRepo}`);
|
||||
const loginDockerRes = exec('docker', ['login', `-u=${args.loginUsername}`, `-p=${args.loginPassword}`, `${args.loginRepo}`], {});
|
||||
const loginDockerRes = exec('docker', ['login', `-u=${args.loginUsername}`, `-p=${args.loginPassword}`, `${args.loginRepo}`]);
|
||||
logger.info(loginDockerRes);
|
||||
}
|
||||
|
||||
@@ -53,14 +55,16 @@ function buildImagePerform(args: PublishArgs, tag: string) {
|
||||
|
||||
const buildArgs = [];
|
||||
|
||||
if (typeof args.buildArgs === 'string') {
|
||||
if (typeof args.buildArgs === 'string') {
|
||||
buildArgs.push(`--build-arg=${args.buildArgs}`);
|
||||
} else {
|
||||
args.buildArgs.forEach((envVar) => {
|
||||
buildArgs.push (`--build-arg=${envVar}`);
|
||||
buildArgs.push(`--build-arg=${envVar}`);
|
||||
});
|
||||
}
|
||||
|
||||
if (args.verbose) {
|
||||
logger.info(`Dry-run Perform docker build -t=${args.dockerRepo}:${tag} ${buildArgs} -f=${args.fileName} ${args.pathProject}`);
|
||||
}
|
||||
const response = exec('docker', ['build', `-t=${args.dockerRepo}:${tag}`, ...buildArgs, `-f=${args.fileName}`, args.pathProject], {});
|
||||
logger.info(response);
|
||||
}
|
||||
@@ -78,9 +82,13 @@ function pullImagePerform(dockerRepo: string, sourceTag: string) {
|
||||
}
|
||||
|
||||
function pushImagePerform(args: PublishArgs, tag: string) {
|
||||
logger.info(`Perform docker push... ${args.dockerRepo}:${tag}`);
|
||||
const response = exec('docker', ['push', `${args.dockerRepo}:${tag}`], {});
|
||||
logger.info(response);
|
||||
if (args.dryrun) {
|
||||
logger.info(`Dry-run Perform docker push... ${args.dockerRepo}:${tag}`);
|
||||
} else {
|
||||
logger.info(`Perform docker push... ${args.dockerRepo}:${tag}`);
|
||||
const response = exec('docker', ['push', `${args.dockerRepo}:${tag}`], {});
|
||||
logger.info(response);
|
||||
}
|
||||
}
|
||||
|
||||
function cleanImagePerform(args: PublishArgs, tag: string) {
|
||||
@@ -101,6 +109,8 @@ function main(args) {
|
||||
.option('--loginRepo [type]', 'URL registry')
|
||||
.option('--loginPassword [type]', ' password')
|
||||
.option('--loginUsername [type]', ' username')
|
||||
.option('--dryrun [type]', 'dryrun')
|
||||
.option('--verbose [type]', 'verbose')
|
||||
.option('--loginCheck [type]', 'perform login')
|
||||
.option('--pathProject [type]', 'the path build context')
|
||||
.option('--sourceTag [type]', 'sourceTag')
|
||||
|
@@ -28,6 +28,7 @@ export interface PublishArgs {
|
||||
npmRegistry?: string;
|
||||
tokenRegistry?: string;
|
||||
pathProject: string;
|
||||
dryrun?: boolean;
|
||||
}
|
||||
|
||||
const projects = [
|
||||
@@ -42,6 +43,10 @@ const projects = [
|
||||
];
|
||||
|
||||
async function npmPublish(args: PublishArgs, project: string) {
|
||||
if (args.dryrun) {
|
||||
logger.info(`Dry run mode, no publish will be done`);
|
||||
}
|
||||
|
||||
if (args.npmRegistry) {
|
||||
changeRegistry(args, project);
|
||||
}
|
||||
@@ -57,10 +62,14 @@ async function npmPublish(args: PublishArgs, project: string) {
|
||||
options.push('-tag');
|
||||
options.push(`${args.tag}`);
|
||||
}
|
||||
const response = exec('npm', options, { cwd: path.resolve(`${args.pathProject}/dist/libs/${project}`) });
|
||||
logger.info(response);
|
||||
if (args.npmRegistry) {
|
||||
removeNpmConfig(args, project);
|
||||
if (args.dryrun) {
|
||||
logger.info(`Dry-run npm publish. cwd: ${args.pathProject}/dist/libs/${project}`);
|
||||
} else {
|
||||
const response = exec('npm', options, { cwd: path.resolve(`${args.pathProject}/dist/libs/${project}`) });
|
||||
logger.info(response);
|
||||
if (args.npmRegistry) {
|
||||
removeNpmConfig(args, project);
|
||||
}
|
||||
}
|
||||
|
||||
await sleep(30000);
|
||||
@@ -72,8 +81,12 @@ async function npmPublish(args: PublishArgs, project: string) {
|
||||
|
||||
function npmCheckExist(project: string, version: string) {
|
||||
logger.info(`Check if lib ${project} is already in npm with version ${version}`);
|
||||
|
||||
const exist = exec(`npm`, [`view`, `@alfresco/adf-${project}@${version} version`] );
|
||||
let exist = '';
|
||||
try {
|
||||
exist = exec(`npm`, [`view`, `@alfresco/adf-${project}@${version} version`]);
|
||||
} catch (e) {
|
||||
logger.info(`Error: '@alfresco/adf-${project}@${version} version' is not available `);
|
||||
}
|
||||
|
||||
return exist !== '';
|
||||
}
|
||||
@@ -117,6 +130,7 @@ async function main(args) {
|
||||
.option('--npmRegistry [type]', 'npm Registry')
|
||||
.option('--tokenRegistry [type]', 'token Registry')
|
||||
.option('--pathProject [type]', 'pathProject')
|
||||
.option('--dryrun [type]', 'dryrun')
|
||||
.parse(process.argv);
|
||||
|
||||
if (process.argv.includes('-h') || process.argv.includes('--help')) {
|
||||
|
Reference in New Issue
Block a user