Tidy log output into groups

This commit is contained in:
Peter Evans 2020-07-16 19:13:28 +09:00
parent 803cc5ea8a
commit 3c32fac1fe
2 changed files with 37 additions and 46 deletions

39
dist/index.js vendored
View file

@ -10505,10 +10505,10 @@ function createPullRequest(inputs) {
// Create a git command manager // Create a git command manager
const git = yield git_command_manager_1.GitCommandManager.create(repoPath); const git = yield git_command_manager_1.GitCommandManager.create(repoPath);
// Unset and save the extraheader config option if it exists // Unset and save the extraheader config option if it exists
core.startGroup('Save persisted git credentials');
gitConfigHelper = new git_config_helper_1.GitConfigHelper(git); gitConfigHelper = new git_config_helper_1.GitConfigHelper(git);
extraHeaderOption = yield gitConfigHelper.getAndUnsetConfigOption(EXTRAHEADER_OPTION, EXTRAHEADER_VALUE_REGEX); extraHeaderOption = yield gitConfigHelper.getAndUnsetConfigOption(EXTRAHEADER_OPTION, EXTRAHEADER_VALUE_REGEX);
//github_token = inputs.token core.endGroup();
//path = repoPath
// Set defaults // Set defaults
inputs.commitMessage = inputs.commitMessage inputs.commitMessage = inputs.commitMessage
? inputs.commitMessage ? inputs.commitMessage
@ -10518,11 +10518,13 @@ function createPullRequest(inputs) {
inputs.branch = inputs.branch ? inputs.branch : DEFAULT_BRANCH; inputs.branch = inputs.branch ? inputs.branch : DEFAULT_BRANCH;
// Determine the GitHub repository from git config // Determine the GitHub repository from git config
// This will be the target repository for the pull request branch // This will be the target repository for the pull request branch
core.startGroup('Determining the checked out repository');
const remoteOriginUrlConfig = yield gitConfigHelper.getConfigOption('remote.origin.url'); const remoteOriginUrlConfig = yield gitConfigHelper.getConfigOption('remote.origin.url');
const remote = yield utils.getRemoteDetail(remoteOriginUrlConfig.value); const remote = utils.getRemoteDetail(remoteOriginUrlConfig.value);
core.endGroup();
core.info(`Pull request branch target repository set to ${remote.repository}`); core.info(`Pull request branch target repository set to ${remote.repository}`);
if (remote.protocol == 'HTTPS') { if (remote.protocol == 'HTTPS') {
core.debug('Using HTTPS protocol'); core.startGroup('Configuring credential for HTTPS authentication');
// Encode and configure the basic credential for HTTPS access // Encode and configure the basic credential for HTTPS access
const basicCredential = Buffer.from(`x-access-token:${inputs.token}`, 'utf8').toString('base64'); const basicCredential = Buffer.from(`x-access-token:${inputs.token}`, 'utf8').toString('base64');
core.setSecret(basicCredential); core.setSecret(basicCredential);
@ -10530,6 +10532,7 @@ function createPullRequest(inputs) {
'-c', '-c',
`http.https://github.com/.extraheader=AUTHORIZATION: basic ${basicCredential}` `http.https://github.com/.extraheader=AUTHORIZATION: basic ${basicCredential}`
]); ]);
core.endGroup();
} }
// Determine if the checked out ref is a valid base for a pull request // Determine if the checked out ref is a valid base for a pull request
// The action needs the checked out HEAD ref to be a branch // The action needs the checked out HEAD ref to be a branch
@ -10537,6 +10540,7 @@ function createPullRequest(inputs) {
// - HEAD is detached // - HEAD is detached
// - HEAD is a merge commit (pull_request events) // - HEAD is a merge commit (pull_request events)
// - HEAD is a tag // - HEAD is a tag
core.startGroup('Checking the checked out ref');
const symbolicRefResult = yield git.exec(['symbolic-ref', 'HEAD', '--short'], true); const symbolicRefResult = yield git.exec(['symbolic-ref', 'HEAD', '--short'], true);
if (symbolicRefResult.exitCode != 0) { if (symbolicRefResult.exitCode != 0) {
core.debug(`${symbolicRefResult.stderr}`); core.debug(`${symbolicRefResult.stderr}`);
@ -10549,6 +10553,7 @@ function createPullRequest(inputs) {
if (workingBase.startsWith(inputs.branch)) { if (workingBase.startsWith(inputs.branch)) {
throw new Error(`Working base branch '${workingBase}' was created by this action. Unable to continue.`); throw new Error(`Working base branch '${workingBase}' was created by this action. Unable to continue.`);
} }
core.endGroup();
// Apply the branch suffix if set // Apply the branch suffix if set
if (inputs.branchSuffix) { if (inputs.branchSuffix) {
switch (inputs.branchSuffix) { switch (inputs.branchSuffix) {
@ -10573,6 +10578,7 @@ function createPullRequest(inputs) {
// Output head branch // Output head branch
core.info(`Pull request branch to create or update set to '${inputs.branch}'`); core.info(`Pull request branch to create or update set to '${inputs.branch}'`);
// Determine the committer and author // Determine the committer and author
core.startGroup('Configuring the committer and author');
const gitIdentityHelper = new git_identity_helper_1.GitIdentityHelper(git); const gitIdentityHelper = new git_identity_helper_1.GitIdentityHelper(git);
const identity = yield gitIdentityHelper.getIdentity(inputs.author, inputs.committer); const identity = yield gitIdentityHelper.getIdentity(inputs.author, inputs.committer);
git.setIdentityGitOptions([ git.setIdentityGitOptions([
@ -10587,35 +10593,22 @@ function createPullRequest(inputs) {
]); ]);
core.info(`Configured git committer as '${identity.committerName} <${identity.committerEmail}>'`); core.info(`Configured git committer as '${identity.committerName} <${identity.committerEmail}>'`);
core.info(`Configured git author as '${identity.authorName} <${identity.authorEmail}>'`); core.info(`Configured git author as '${identity.authorName} <${identity.authorEmail}>'`);
core.endGroup();
// Create or update the pull request branch // Create or update the pull request branch
core.startGroup('Create or update the pull request branch');
const result = yield create_or_update_branch_1.createOrUpdateBranch(git, inputs.commitMessage, inputs.base, inputs.branch); const result = yield create_or_update_branch_1.createOrUpdateBranch(git, inputs.commitMessage, inputs.base, inputs.branch);
core.endGroup();
if (['created', 'updated'].includes(result.action)) { if (['created', 'updated'].includes(result.action)) {
// The branch was created or updated // The branch was created or updated
core.info(`Pushing pull request branch to 'origin/${inputs.branch}'`); core.startGroup(`Pushing pull request branch to 'origin/${inputs.branch}'`);
yield git.push(['--force', 'origin', `HEAD:refs/heads/${inputs.branch}`]); yield git.push(['--force', 'origin', `HEAD:refs/heads/${inputs.branch}`]);
core.endGroup();
// Set the base. It would have been '' if not specified as an input // Set the base. It would have been '' if not specified as an input
inputs.base = result.base; inputs.base = result.base;
if (result.hasDiffWithBase) { if (result.hasDiffWithBase) {
// Create or update the pull request // Create or update the pull request
const githubHelper = new github_helper_1.GitHubHelper(inputs.token); const githubHelper = new github_helper_1.GitHubHelper(inputs.token);
yield githubHelper.createOrUpdatePullRequest(inputs, remote.repository); yield githubHelper.createOrUpdatePullRequest(inputs, remote.repository);
// coupr.create_or_update_pull_request(
// github_token,
// github_repository,
// branch,
// base,
// title,
// body,
// os.environ.get("CPR_LABELS"),
// os.environ.get("CPR_ASSIGNEES"),
// os.environ.get("CPR_MILESTONE"),
// os.environ.get("CPR_REVIEWERS"),
// os.environ.get("CPR_TEAM_REVIEWERS"),
// os.environ.get("CPR_PROJECT_NAME"),
// os.environ.get("CPR_PROJECT_COLUMN_NAME"),
// os.environ.get("CPR_DRAFT"),
// os.environ.get("CPR_REQUEST_TO_PARENT"),
// )
} }
else { else {
// If there is no longer a diff with the base delete the branch // If there is no longer a diff with the base delete the branch
@ -10635,10 +10628,12 @@ function createPullRequest(inputs) {
} }
finally { finally {
// Restore the extraheader config option // Restore the extraheader config option
core.startGroup('Restore persisted git credentials');
if (extraHeaderOption.value != '') { if (extraHeaderOption.value != '') {
if (yield gitConfigHelper.addConfigOption(EXTRAHEADER_OPTION, extraHeaderOption.value)) if (yield gitConfigHelper.addConfigOption(EXTRAHEADER_OPTION, extraHeaderOption.value))
core.debug(`Restored config option '${EXTRAHEADER_OPTION}'`); core.debug(`Restored config option '${EXTRAHEADER_OPTION}'`);
} }
core.endGroup();
} }
}); });
} }

View file

@ -43,15 +43,15 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
const repoPath = utils.getRepoPath(inputs.path) const repoPath = utils.getRepoPath(inputs.path)
// Create a git command manager // Create a git command manager
const git = await GitCommandManager.create(repoPath) const git = await GitCommandManager.create(repoPath)
// Unset and save the extraheader config option if it exists // Unset and save the extraheader config option if it exists
core.startGroup('Save persisted git credentials')
gitConfigHelper = new GitConfigHelper(git) gitConfigHelper = new GitConfigHelper(git)
extraHeaderOption = await gitConfigHelper.getAndUnsetConfigOption( extraHeaderOption = await gitConfigHelper.getAndUnsetConfigOption(
EXTRAHEADER_OPTION, EXTRAHEADER_OPTION,
EXTRAHEADER_VALUE_REGEX EXTRAHEADER_VALUE_REGEX
) )
core.endGroup()
//github_token = inputs.token
//path = repoPath
// Set defaults // Set defaults
inputs.commitMessage = inputs.commitMessage inputs.commitMessage = inputs.commitMessage
@ -63,16 +63,18 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
// Determine the GitHub repository from git config // Determine the GitHub repository from git config
// This will be the target repository for the pull request branch // This will be the target repository for the pull request branch
core.startGroup('Determining the checked out repository')
const remoteOriginUrlConfig = await gitConfigHelper.getConfigOption( const remoteOriginUrlConfig = await gitConfigHelper.getConfigOption(
'remote.origin.url' 'remote.origin.url'
) )
const remote = await utils.getRemoteDetail(remoteOriginUrlConfig.value) const remote = utils.getRemoteDetail(remoteOriginUrlConfig.value)
core.endGroup()
core.info( core.info(
`Pull request branch target repository set to ${remote.repository}` `Pull request branch target repository set to ${remote.repository}`
) )
if (remote.protocol == 'HTTPS') { if (remote.protocol == 'HTTPS') {
core.debug('Using HTTPS protocol') core.startGroup('Configuring credential for HTTPS authentication')
// Encode and configure the basic credential for HTTPS access // Encode and configure the basic credential for HTTPS access
const basicCredential = Buffer.from( const basicCredential = Buffer.from(
`x-access-token:${inputs.token}`, `x-access-token:${inputs.token}`,
@ -83,6 +85,7 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
'-c', '-c',
`http.https://github.com/.extraheader=AUTHORIZATION: basic ${basicCredential}` `http.https://github.com/.extraheader=AUTHORIZATION: basic ${basicCredential}`
]) ])
core.endGroup()
} }
// Determine if the checked out ref is a valid base for a pull request // Determine if the checked out ref is a valid base for a pull request
@ -91,6 +94,7 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
// - HEAD is detached // - HEAD is detached
// - HEAD is a merge commit (pull_request events) // - HEAD is a merge commit (pull_request events)
// - HEAD is a tag // - HEAD is a tag
core.startGroup('Checking the checked out ref')
const symbolicRefResult = await git.exec( const symbolicRefResult = await git.exec(
['symbolic-ref', 'HEAD', '--short'], ['symbolic-ref', 'HEAD', '--short'],
true true
@ -102,7 +106,6 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
) )
} }
const workingBase = symbolicRefResult.stdout.trim() const workingBase = symbolicRefResult.stdout.trim()
// Exit if the working base is a PR branch created by this action. // Exit if the working base is a PR branch created by this action.
// This may occur when using a PAT instead of GITHUB_TOKEN because // This may occur when using a PAT instead of GITHUB_TOKEN because
// a PAT allows workflow actions to trigger further events. // a PAT allows workflow actions to trigger further events.
@ -111,6 +114,7 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
`Working base branch '${workingBase}' was created by this action. Unable to continue.` `Working base branch '${workingBase}' was created by this action. Unable to continue.`
) )
} }
core.endGroup()
// Apply the branch suffix if set // Apply the branch suffix if set
if (inputs.branchSuffix) { if (inputs.branchSuffix) {
@ -142,6 +146,7 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
) )
// Determine the committer and author // Determine the committer and author
core.startGroup('Configuring the committer and author')
const gitIdentityHelper = new GitIdentityHelper(git) const gitIdentityHelper = new GitIdentityHelper(git)
const identity = await gitIdentityHelper.getIdentity( const identity = await gitIdentityHelper.getIdentity(
inputs.author, inputs.author,
@ -163,19 +168,25 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
core.info( core.info(
`Configured git author as '${identity.authorName} <${identity.authorEmail}>'` `Configured git author as '${identity.authorName} <${identity.authorEmail}>'`
) )
core.endGroup()
// Create or update the pull request branch // Create or update the pull request branch
core.startGroup('Create or update the pull request branch')
const result = await createOrUpdateBranch( const result = await createOrUpdateBranch(
git, git,
inputs.commitMessage, inputs.commitMessage,
inputs.base, inputs.base,
inputs.branch inputs.branch
) )
core.endGroup()
if (['created', 'updated'].includes(result.action)) { if (['created', 'updated'].includes(result.action)) {
// The branch was created or updated // The branch was created or updated
core.info(`Pushing pull request branch to 'origin/${inputs.branch}'`) core.startGroup(
`Pushing pull request branch to 'origin/${inputs.branch}'`
)
await git.push(['--force', 'origin', `HEAD:refs/heads/${inputs.branch}`]) await git.push(['--force', 'origin', `HEAD:refs/heads/${inputs.branch}`])
core.endGroup()
// Set the base. It would have been '' if not specified as an input // Set the base. It would have been '' if not specified as an input
inputs.base = result.base inputs.base = result.base
@ -184,23 +195,6 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
// Create or update the pull request // Create or update the pull request
const githubHelper = new GitHubHelper(inputs.token) const githubHelper = new GitHubHelper(inputs.token)
await githubHelper.createOrUpdatePullRequest(inputs, remote.repository) await githubHelper.createOrUpdatePullRequest(inputs, remote.repository)
// coupr.create_or_update_pull_request(
// github_token,
// github_repository,
// branch,
// base,
// title,
// body,
// os.environ.get("CPR_LABELS"),
// os.environ.get("CPR_ASSIGNEES"),
// os.environ.get("CPR_MILESTONE"),
// os.environ.get("CPR_REVIEWERS"),
// os.environ.get("CPR_TEAM_REVIEWERS"),
// os.environ.get("CPR_PROJECT_NAME"),
// os.environ.get("CPR_PROJECT_COLUMN_NAME"),
// os.environ.get("CPR_DRAFT"),
// os.environ.get("CPR_REQUEST_TO_PARENT"),
// )
} else { } else {
// If there is no longer a diff with the base delete the branch // If there is no longer a diff with the base delete the branch
core.info( core.info(
@ -219,6 +213,7 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
core.setFailed(error.message) core.setFailed(error.message)
} finally { } finally {
// Restore the extraheader config option // Restore the extraheader config option
core.startGroup('Restore persisted git credentials')
if (extraHeaderOption.value != '') { if (extraHeaderOption.value != '') {
if ( if (
await gitConfigHelper.addConfigOption( await gitConfigHelper.addConfigOption(
@ -228,5 +223,6 @@ export async function createPullRequest(inputs: Inputs): Promise<void> {
) )
core.debug(`Restored config option '${EXTRAHEADER_OPTION}'`) core.debug(`Restored config option '${EXTRAHEADER_OPTION}'`)
} }
core.endGroup()
} }
} }