Add a check for user config set in the workflow
This commit is contained in:
parent
efbd4fa1ef
commit
4f8d5b9d3e
4 changed files with 84 additions and 16 deletions
4
dist/src/create_or_update_branch.py
vendored
4
dist/src/create_or_update_branch.py
vendored
|
@ -134,9 +134,7 @@ def create_or_update_branch(repo, repo_url, commit_message, base, branch):
|
||||||
action = "updated"
|
action = "updated"
|
||||||
print(f"Updated branch '{branch}'")
|
print(f"Updated branch '{branch}'")
|
||||||
else:
|
else:
|
||||||
print(
|
print(f"Branch '{branch}' is even with its remote and will not be updated")
|
||||||
f"Branch '{branch}' is even with its remote and will not be updated"
|
|
||||||
)
|
|
||||||
|
|
||||||
# Check if the pull request branch is ahead of the base
|
# Check if the pull request branch is ahead of the base
|
||||||
diff = is_ahead(repo, base, branch)
|
diff = is_ahead(repo, base, branch)
|
||||||
|
|
46
dist/src/create_pull_request.py
vendored
46
dist/src/create_pull_request.py
vendored
|
@ -3,7 +3,7 @@
|
||||||
import common as cmn
|
import common as cmn
|
||||||
import create_or_update_branch as coub
|
import create_or_update_branch as coub
|
||||||
import create_or_update_pull_request as coupr
|
import create_or_update_pull_request as coupr
|
||||||
from git import Repo
|
from git import Repo, GitCommandError
|
||||||
import json
|
import json
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
@ -17,6 +17,41 @@ DEFAULT_AUTHOR = (
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def get_git_config_value(repo, name):
|
||||||
|
try:
|
||||||
|
return repo.git.config("--get", name)
|
||||||
|
except GitCommandError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
|
||||||
|
def git_user_config_is_set(repo):
|
||||||
|
name = get_git_config_value(repo, "user.name")
|
||||||
|
email = get_git_config_value(repo, "user.email")
|
||||||
|
|
||||||
|
if name is not None and email is not None:
|
||||||
|
print(f"Git user already configured as '{name} <{email}>'")
|
||||||
|
return True
|
||||||
|
|
||||||
|
committer_name = get_git_config_value(repo, "committer.name")
|
||||||
|
committer_email = get_git_config_value(repo, "committer.email")
|
||||||
|
author_name = get_git_config_value(repo, "author.name")
|
||||||
|
author_email = get_git_config_value(repo, "author.email")
|
||||||
|
|
||||||
|
if (
|
||||||
|
committer_name is not None
|
||||||
|
and committer_email is not None
|
||||||
|
and author_name is not None
|
||||||
|
and author_email is not None
|
||||||
|
):
|
||||||
|
print(
|
||||||
|
f"Git committer already configured as '{committer_name} <{committer_email}>'"
|
||||||
|
)
|
||||||
|
print(f"Git author already configured as '{author_name} <{author_email}>'")
|
||||||
|
return True
|
||||||
|
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
def set_committer_author(repo, committer, author):
|
def set_committer_author(repo, committer, author):
|
||||||
# If either committer or author is supplied they will be cross used
|
# If either committer or author is supplied they will be cross used
|
||||||
if committer is None and author is not None:
|
if committer is None and author is not None:
|
||||||
|
@ -26,10 +61,11 @@ def set_committer_author(repo, committer, author):
|
||||||
print("Supplied committer will also be used as the author.")
|
print("Supplied committer will also be used as the author.")
|
||||||
author = committer
|
author = committer
|
||||||
|
|
||||||
# TODO If no overrides have been supplied, check if already set in config
|
# If no committer/author has been supplied but user configuration already
|
||||||
# If not set, continue to use defaults
|
# exists in git config we can exit and use the existing config as-is.
|
||||||
# If set, return
|
if committer is None and author is None:
|
||||||
# https://git-scm.com/docs/git-config#Documentation/git-config.txt-username
|
if git_user_config_is_set(repo):
|
||||||
|
return
|
||||||
|
|
||||||
# Set defaults if no committer/author has been supplied
|
# Set defaults if no committer/author has been supplied
|
||||||
if committer is None and author is None:
|
if committer is None and author is None:
|
||||||
|
|
|
@ -134,9 +134,7 @@ def create_or_update_branch(repo, repo_url, commit_message, base, branch):
|
||||||
action = "updated"
|
action = "updated"
|
||||||
print(f"Updated branch '{branch}'")
|
print(f"Updated branch '{branch}'")
|
||||||
else:
|
else:
|
||||||
print(
|
print(f"Branch '{branch}' is even with its remote and will not be updated")
|
||||||
f"Branch '{branch}' is even with its remote and will not be updated"
|
|
||||||
)
|
|
||||||
|
|
||||||
# Check if the pull request branch is ahead of the base
|
# Check if the pull request branch is ahead of the base
|
||||||
diff = is_ahead(repo, base, branch)
|
diff = is_ahead(repo, base, branch)
|
||||||
|
|
|
@ -3,7 +3,7 @@
|
||||||
import common as cmn
|
import common as cmn
|
||||||
import create_or_update_branch as coub
|
import create_or_update_branch as coub
|
||||||
import create_or_update_pull_request as coupr
|
import create_or_update_pull_request as coupr
|
||||||
from git import Repo
|
from git import Repo, GitCommandError
|
||||||
import json
|
import json
|
||||||
import os
|
import os
|
||||||
import sys
|
import sys
|
||||||
|
@ -17,6 +17,41 @@ DEFAULT_AUTHOR = (
|
||||||
)
|
)
|
||||||
|
|
||||||
|
|
||||||
|
def get_git_config_value(repo, name):
|
||||||
|
try:
|
||||||
|
return repo.git.config("--get", name)
|
||||||
|
except GitCommandError:
|
||||||
|
return None
|
||||||
|
|
||||||
|
|
||||||
|
def git_user_config_is_set(repo):
|
||||||
|
name = get_git_config_value(repo, "user.name")
|
||||||
|
email = get_git_config_value(repo, "user.email")
|
||||||
|
|
||||||
|
if name is not None and email is not None:
|
||||||
|
print(f"Git user already configured as '{name} <{email}>'")
|
||||||
|
return True
|
||||||
|
|
||||||
|
committer_name = get_git_config_value(repo, "committer.name")
|
||||||
|
committer_email = get_git_config_value(repo, "committer.email")
|
||||||
|
author_name = get_git_config_value(repo, "author.name")
|
||||||
|
author_email = get_git_config_value(repo, "author.email")
|
||||||
|
|
||||||
|
if (
|
||||||
|
committer_name is not None
|
||||||
|
and committer_email is not None
|
||||||
|
and author_name is not None
|
||||||
|
and author_email is not None
|
||||||
|
):
|
||||||
|
print(
|
||||||
|
f"Git committer already configured as '{committer_name} <{committer_email}>'"
|
||||||
|
)
|
||||||
|
print(f"Git author already configured as '{author_name} <{author_email}>'")
|
||||||
|
return True
|
||||||
|
|
||||||
|
return False
|
||||||
|
|
||||||
|
|
||||||
def set_committer_author(repo, committer, author):
|
def set_committer_author(repo, committer, author):
|
||||||
# If either committer or author is supplied they will be cross used
|
# If either committer or author is supplied they will be cross used
|
||||||
if committer is None and author is not None:
|
if committer is None and author is not None:
|
||||||
|
@ -26,10 +61,11 @@ def set_committer_author(repo, committer, author):
|
||||||
print("Supplied committer will also be used as the author.")
|
print("Supplied committer will also be used as the author.")
|
||||||
author = committer
|
author = committer
|
||||||
|
|
||||||
# TODO If no overrides have been supplied, check if already set in config
|
# If no committer/author has been supplied but user configuration already
|
||||||
# If not set, continue to use defaults
|
# exists in git config we can exit and use the existing config as-is.
|
||||||
# If set, return
|
if committer is None and author is None:
|
||||||
# https://git-scm.com/docs/git-config#Documentation/git-config.txt-username
|
if git_user_config_is_set(repo):
|
||||||
|
return
|
||||||
|
|
||||||
# Set defaults if no committer/author has been supplied
|
# Set defaults if no committer/author has been supplied
|
||||||
if committer is None and author is None:
|
if committer is None and author is None:
|
||||||
|
|
Loading…
Reference in a new issue