2
0
mirror of https://github.com/frappe/bench.git synced 2025-01-10 09:02:10 +00:00

Merge branch 'develop' into staging

This commit is contained in:
Gavin D'souza 2021-12-28 18:22:44 +05:30
commit ead462e1fb
3 changed files with 55 additions and 14 deletions

View File

@ -94,6 +94,7 @@ class AppMeta:
def _setup_details_from_name_tag(self): def _setup_details_from_name_tag(self):
self.org, self.repo, self.tag = fetch_details_from_tag(self.name) self.org, self.repo, self.tag = fetch_details_from_tag(self.name)
self.tag = self.tag or self.branch
def _setup_details_from_installed_apps(self): def _setup_details_from_installed_apps(self):
self.org, self.repo, self.tag = os.path.split( self.org, self.repo, self.tag = os.path.split(
@ -105,9 +106,11 @@ class AppMeta:
def __setup_details_from_git(self): def __setup_details_from_git(self):
if self.use_ssh: if self.use_ssh:
self.org, _repo = self.name.split(":")[1].split("/") _first_part, _second_part = self.name.split(":")
self.remote_server = _first_part.split("@")[-1]
self.org, _repo = _second_part.split("/")
else: else:
self.org, _repo = self.name.split("/")[-2:] self.remote_server, self.org, _repo = self.name.split("/")[-3:]
self.tag = self.branch self.tag = self.branch
self.repo = _repo.split(".")[0] self.repo = _repo.split(".")[0]

View File

@ -25,6 +25,7 @@ from bench.utils import (
is_root, is_root,
log, log,
setup_logging, setup_logging,
parse_sys_argv,
) )
from bench.utils.bench import get_env_cmd from bench.utils.bench import get_env_cmd
@ -34,19 +35,24 @@ verbose = False
is_envvar_warn_set = None is_envvar_warn_set = None
from_command_line = False # set when commands are executed via the CLI from_command_line = False # set when commands are executed via the CLI
bench.LOG_BUFFER = [] bench.LOG_BUFFER = []
sys_argv = None
change_uid_msg = "You should not run this command as root" change_uid_msg = "You should not run this command as root"
src = os.path.dirname(__file__) src = os.path.dirname(__file__)
def cli(): def cli():
global from_command_line, bench_config, is_envvar_warn_set global from_command_line, bench_config, is_envvar_warn_set, verbose, sys_argv
from_command_line = True from_command_line = True
command = " ".join(sys.argv) command = " ".join(sys.argv)
argv = set(sys.argv) argv = set(sys.argv)
is_envvar_warn_set = not (os.environ.get("BENCH_DEVELOPER") or os.environ.get("CI")) is_envvar_warn_set = not (os.environ.get("BENCH_DEVELOPER") or os.environ.get("CI"))
is_cli_command = len(sys.argv) > 1 and not argv.intersection({"src", "--version"}) is_cli_command = len(sys.argv) > 1 and not argv.intersection({"src", "--version"})
sys_argv = parse_sys_argv()
if "--verbose" in sys_argv.options:
verbose = True
change_working_directory() change_working_directory()
logger = setup_logging() logger = setup_logging()
@ -89,13 +95,10 @@ def cli():
print(get_frappe_help()) print(get_frappe_help())
return return
if sys.argv[1] in ["--site", "--force", "--profile"]: if (
frappe_cmd() sys_argv.commands.intersection(get_cached_frappe_commands())
or sys_argv.commands.intersection(get_frappe_commands())
if sys.argv[1] in get_cached_frappe_commands(): ):
frappe_cmd()
if sys.argv[1] in get_frappe_commands():
frappe_cmd() frappe_cmd()
if sys.argv[1] in Bench(".").apps: if sys.argv[1] in Bench(".").apps:
@ -185,15 +188,15 @@ def frappe_cmd(bench_path="."):
def get_cached_frappe_commands(): def get_cached_frappe_commands():
if os.path.exists(bench_cache_file): if os.path.exists(bench_cache_file):
command_dump = open(bench_cache_file, "r").read() or "[]" command_dump = open(bench_cache_file, "r").read() or "[]"
return json.loads(command_dump) return set(json.loads(command_dump))
return [] return set()
def get_frappe_commands(): def get_frappe_commands():
if not is_bench_directory(): if not is_bench_directory():
return [] return set()
return generate_command_cache() return set(generate_command_cache())
def get_frappe_help(bench_path="."): def get_frappe_help(bench_path="."):

View File

@ -471,3 +471,38 @@ def get_traceback() -> str:
trace_list = format_exception(exc_type, exc_value, exc_tb) trace_list = format_exception(exc_type, exc_value, exc_tb)
return "".join(trace_list) return "".join(trace_list)
class _dict(dict):
"""dict like object that exposes keys as attributes"""
# bench port of frappe._dict
def __getattr__(self, key):
ret = self.get(key)
# "__deepcopy__" exception added to fix frappe#14833 via DFP
if not ret and key.startswith("__") and key != "__deepcopy__":
raise AttributeError()
return ret
def __setattr__(self, key, value):
self[key] = value
def __getstate__(self):
return self
def __setstate__(self, d):
self.update(d)
def update(self, d):
"""update and return self -- the missing dict feature in python"""
super(_dict, self).update(d)
return self
def copy(self):
return _dict(dict(self).copy())
def parse_sys_argv():
sys_argv = _dict(options=set(), commands=set())
for c in sys.argv[1:]:
if c.startswith("-"):
sys_argv.options.add(c)
else:
sys_argv.commands.add(c)
return sys_argv