Instead of repeating the logic for adding the github token to a repository git url, we add a shared function for automatically computing the URls with token. Additionally, URLs for updating/generating tokens have been moved to a dedicated file in the `utils` folder. Also while being at it, the yargs github token helper is also moved into the dedicated Git/Github related util folder. PR Close #38656
		
			
				
	
	
		
			37 lines
		
	
	
		
			1.2 KiB
		
	
	
	
		
			TypeScript
		
	
	
	
	
	
			
		
		
	
	
			37 lines
		
	
	
		
			1.2 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 {Arguments, Argv, CommandModule} from 'yargs';
 | |
| 
 | |
| import {addGithubTokenOption} from '../../utils/git/github-yargs';
 | |
| import {checkOutPullRequestLocally} from '../common/checkout-pr';
 | |
| 
 | |
| export interface CheckoutOptions {
 | |
|   prNumber: number;
 | |
|   githubToken: string;
 | |
| }
 | |
| 
 | |
| /** Builds the checkout pull request command. */
 | |
| function builder(yargs: Argv) {
 | |
|   return addGithubTokenOption(yargs).positional('prNumber', {type: 'number', demandOption: true});
 | |
| }
 | |
| 
 | |
| /** Handles the checkout pull request command. */
 | |
| async function handler({prNumber, githubToken}: Arguments<CheckoutOptions>) {
 | |
|   const prCheckoutOptions = {allowIfMaintainerCannotModify: true, branchName: `pr-${prNumber}`};
 | |
|   await checkOutPullRequestLocally(prNumber, githubToken, prCheckoutOptions);
 | |
| }
 | |
| 
 | |
| /** yargs command module for checking out a PR  */
 | |
| export const CheckoutCommandModule: CommandModule<{}, CheckoutOptions> = {
 | |
|   handler,
 | |
|   builder,
 | |
|   command: 'checkout <pr-number>',
 | |
|   describe: 'Checkout a PR from the upstream repo',
 | |
| };
 |