Tidy log output into groups
This commit is contained in:
parent
803cc5ea8a
commit
3c32fac1fe
2 changed files with 37 additions and 46 deletions
39
dist/index.js
vendored
39
dist/index.js
vendored
|
@ -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();
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
|
@ -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()
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue