Creates a tool for staging and publishing releases as per the new branching and versioning that has been outlined in the following document. The tool is intended to be used across the organization to ensure consistent branching/versioning and labeling: https://docs.google.com/document/d/197kVillDwx-RZtSVOBtPb4BBIAw0E9RT3q3v6DZkykU/edit#heading=h.s3qlps8f4zq7dd The tool implements the actions as outlined in the following initial plan: https://hackmd.io/2Le8leq0S6G_R5VEVTNK9A. The implementation slightly diverged in so far that it performs staging and publishing together so that releasing is a single convenient command. In case of errors for which re-running the full command is not sufficient, we want to consider adding recover functionality. e.g. when the staging completed, but the actual NPM publishing aborted unexpectedly due to build errors. PR Close #38656
43 lines
1.6 KiB
TypeScript
43 lines
1.6 KiB
TypeScript
/**
|
|
* @license
|
|
* Copyright Google LLC All Rights Reserved.
|
|
*
|
|
* Use of this source code is governed by an MIT-style license that can be
|
|
* found in the LICENSE file at https://angular.io/license
|
|
*/
|
|
|
|
|
|
import {URL} from 'url';
|
|
import {GithubConfig} from '../config';
|
|
import {GitClient} from './index';
|
|
|
|
/** URL to the Github page where personal access tokens can be managed. */
|
|
export const GITHUB_TOKEN_SETTINGS_URL = `https://github.com/settings/tokens`;
|
|
|
|
/** URL to the Github page where personal access tokens can be generated. */
|
|
export const GITHUB_TOKEN_GENERATE_URL = `https://github.com/settings/tokens/new`;
|
|
|
|
/** Adds the provided token to the given Github HTTPs remote url. */
|
|
export function addTokenToGitHttpsUrl(githubHttpsUrl: string, token: string) {
|
|
const url = new URL(githubHttpsUrl);
|
|
url.username = token;
|
|
return url.toString();
|
|
}
|
|
|
|
/** Gets the repository Git URL for the given github config. */
|
|
export function getRepositoryGitUrl(config: GithubConfig, githubToken?: string): string {
|
|
if (config.useSsh) {
|
|
return `git@github.com:${config.owner}/${config.name}.git`;
|
|
}
|
|
const baseHttpUrl = `https://github.com/${config.owner}/${config.name}.git`;
|
|
if (githubToken !== undefined) {
|
|
return addTokenToGitHttpsUrl(baseHttpUrl, githubToken);
|
|
}
|
|
return baseHttpUrl;
|
|
}
|
|
|
|
/** Gets a Github URL that refers to a lists of recent commits within a specified branch. */
|
|
export function getListCommitsInBranchUrl({remoteParams}: GitClient, branchName: string) {
|
|
return `https://github.com/${remoteParams.owner}/${remoteParams.repo}/commits/${branchName}`;
|
|
}
|