mirror of
https://github.com/angular/angular-cli.git
synced 2025-05-16 18:43:42 +08:00
Branch support in snapshots (#12692)
* ci: snapshots can push to specific branches Can take either a branch argument, or use CIRCLE_BRANCH if available. * ci: run snapshots on all branches
This commit is contained in:
parent
9ae9757048
commit
a53cf44e1d
@ -196,7 +196,8 @@ workflows:
|
|||||||
- e2e-cli
|
- e2e-cli
|
||||||
filters:
|
filters:
|
||||||
branches:
|
branches:
|
||||||
only: master
|
ignore:
|
||||||
|
- /pull\/.*/
|
||||||
- publish:
|
- publish:
|
||||||
requires:
|
requires:
|
||||||
- test
|
- test
|
||||||
|
@ -67,11 +67,72 @@ function _exec(command: string, args: string[], opts: { cwd?: string }, logger:
|
|||||||
return stdout.toString('utf-8');
|
return stdout.toString('utf-8');
|
||||||
}
|
}
|
||||||
|
|
||||||
|
async function _publishSnapshot(
|
||||||
|
pkg: PackageInfo,
|
||||||
|
branch: string,
|
||||||
|
message: string,
|
||||||
|
logger: logging.Logger,
|
||||||
|
githubToken: string,
|
||||||
|
) {
|
||||||
|
if (!pkg.snapshot) {
|
||||||
|
logger.warn(`Skipping ${pkg.name}.`);
|
||||||
|
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
logger.info(`Publishing ${pkg.name} to repo ${JSON.stringify(pkg.snapshotRepo)}.`);
|
||||||
|
|
||||||
|
const root = process.cwd();
|
||||||
|
const publishLogger = logger.createChild('publish');
|
||||||
|
publishLogger.debug('Temporary directory: ' + root);
|
||||||
|
|
||||||
|
const url = `https://${githubToken ? githubToken + '@' : ''}github.com/${pkg.snapshotRepo}.git`;
|
||||||
|
const destPath = path.join(root, path.basename(pkg.snapshotRepo));
|
||||||
|
|
||||||
|
_exec('git', ['clone', url], { cwd: root }, publishLogger);
|
||||||
|
if (branch) {
|
||||||
|
_exec('git', ['checkout', '-B', branch], { cwd: destPath }, publishLogger);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Clear snapshot directory before publishing to remove deleted build files.
|
||||||
|
try {
|
||||||
|
_exec('git', ['rm', '-rf', './'], {cwd: destPath}, publishLogger);
|
||||||
|
} catch {
|
||||||
|
// Ignore errors on delete. :shrug:
|
||||||
|
}
|
||||||
|
_copy(pkg.dist, destPath);
|
||||||
|
|
||||||
|
if (githubToken) {
|
||||||
|
_exec('git', ['config', 'commit.gpgSign', 'false'], { cwd: destPath }, publishLogger);
|
||||||
|
}
|
||||||
|
|
||||||
|
// Add the header to the existing README.md (or create a README if it doesn't exist).
|
||||||
|
const readmePath = path.join(destPath, 'README.md');
|
||||||
|
let readme = readmeHeaderFn(pkg);
|
||||||
|
try {
|
||||||
|
readme += fs.readFileSync(readmePath, 'utf-8');
|
||||||
|
} catch {}
|
||||||
|
|
||||||
|
fs.writeFileSync(readmePath, readme);
|
||||||
|
|
||||||
|
// Make sure that every snapshots is unique (otherwise we would need to make sure git accepts
|
||||||
|
// empty commits).
|
||||||
|
fs.writeFileSync(path.join(destPath, 'uniqueId'), '' + new Date());
|
||||||
|
|
||||||
|
// Commit and push.
|
||||||
|
_exec('git', ['add', '.'], { cwd: destPath }, publishLogger);
|
||||||
|
_exec('git', ['commit', '-a', '-m', message], { cwd: destPath }, publishLogger);
|
||||||
|
_exec('git', ['tag', pkg.snapshotHash], { cwd: destPath }, publishLogger);
|
||||||
|
_exec('git', ['push', 'origin', branch], { cwd: destPath }, publishLogger);
|
||||||
|
_exec('git', ['push', '--tags', 'origin', branch], { cwd: destPath }, publishLogger);
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
export interface SnapshotsOptions {
|
export interface SnapshotsOptions {
|
||||||
force?: boolean;
|
force?: boolean;
|
||||||
githubTokenFile?: string;
|
githubTokenFile?: string;
|
||||||
githubToken?: string;
|
githubToken?: string;
|
||||||
|
branch?: string;
|
||||||
}
|
}
|
||||||
|
|
||||||
export default async function(opts: SnapshotsOptions, logger: logging.Logger) {
|
export default async function(opts: SnapshotsOptions, logger: logging.Logger) {
|
||||||
@ -83,6 +144,12 @@ export default async function(opts: SnapshotsOptions, logger: logging.Logger) {
|
|||||||
|
|
||||||
const root = fs.mkdtempSync(path.join(os.tmpdir(), 'angular-cli-publish-'));
|
const root = fs.mkdtempSync(path.join(os.tmpdir(), 'angular-cli-publish-'));
|
||||||
const message = execSync(`git log --format="%h %s" -n1`).toString().trim();
|
const message = execSync(`git log --format="%h %s" -n1`).toString().trim();
|
||||||
|
let branch = opts.branch || 'master';
|
||||||
|
|
||||||
|
// CIRCLE_BRANCH
|
||||||
|
if (typeof process.env['CIRCLE_BRANCH'] == 'string') {
|
||||||
|
branch = '' + process.env['CIRCLE_BRANCH'];
|
||||||
|
}
|
||||||
|
|
||||||
const githubToken = (
|
const githubToken = (
|
||||||
opts.githubToken
|
opts.githubToken
|
||||||
@ -129,53 +196,8 @@ export default async function(opts: SnapshotsOptions, logger: logging.Logger) {
|
|||||||
}
|
}
|
||||||
|
|
||||||
for (const packageName of Object.keys(packages)) {
|
for (const packageName of Object.keys(packages)) {
|
||||||
const pkg = packages[packageName];
|
process.chdir(root);
|
||||||
|
await _publishSnapshot(packages[packageName], branch, message, logger, githubToken);
|
||||||
if (!pkg.snapshot) {
|
|
||||||
logger.warn(`Skipping ${pkg.name}.`);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
logger.info(`Publishing ${pkg.name} to repo ${JSON.stringify(pkg.snapshotRepo)}.`);
|
|
||||||
|
|
||||||
const publishLogger = logger.createChild('publish');
|
|
||||||
publishLogger.debug('Temporary directory: ' + root);
|
|
||||||
|
|
||||||
const url = `https://${githubToken ? githubToken + '@' : ''}github.com/${pkg.snapshotRepo}.git`;
|
|
||||||
_exec('git', ['clone', url], { cwd: root }, publishLogger);
|
|
||||||
|
|
||||||
const destPath = path.join(root, path.basename(pkg.snapshotRepo));
|
|
||||||
// Clear snapshot directory before publishing to remove deleted build files.
|
|
||||||
try {
|
|
||||||
_exec('git', ['rm', '-rf', './'], {cwd: destPath}, publishLogger);
|
|
||||||
} catch {
|
|
||||||
// Ignore errors on delete. :shrug:
|
|
||||||
}
|
|
||||||
_copy(pkg.dist, destPath);
|
|
||||||
|
|
||||||
if (githubToken) {
|
|
||||||
_exec('git', ['config', 'commit.gpgSign', 'false'], { cwd: destPath }, publishLogger);
|
|
||||||
}
|
|
||||||
|
|
||||||
// Add the header to the existing README.md (or create a README if it doesn't exist).
|
|
||||||
const readmePath = path.join(destPath, 'README.md');
|
|
||||||
let readme = readmeHeaderFn(pkg);
|
|
||||||
try {
|
|
||||||
readme += fs.readFileSync(readmePath, 'utf-8');
|
|
||||||
} catch {}
|
|
||||||
|
|
||||||
fs.writeFileSync(readmePath, readme);
|
|
||||||
|
|
||||||
// Make sure that every snapshots is unique (otherwise we would need to make sure git accepts
|
|
||||||
// empty commits).
|
|
||||||
fs.writeFileSync(path.join(destPath, 'uniqueId'), '' + new Date());
|
|
||||||
|
|
||||||
// Commit and push.
|
|
||||||
_exec('git', ['add', '.'], { cwd: destPath }, publishLogger);
|
|
||||||
_exec('git', ['commit', '-a', '-m', message], { cwd: destPath }, publishLogger);
|
|
||||||
_exec('git', ['tag', pkg.snapshotHash], { cwd: destPath }, publishLogger);
|
|
||||||
_exec('git', ['push', 'origin'], { cwd: destPath }, publishLogger);
|
|
||||||
_exec('git', ['push', '--tags', 'origin'], { cwd: destPath }, publishLogger);
|
|
||||||
}
|
}
|
||||||
|
|
||||||
return 0;
|
return 0;
|
||||||
|
Loading…
x
Reference in New Issue
Block a user