2
0
mirror of https://github.com/frappe/bench.git synced 2025-01-25 07:58:24 +00:00

Merge branch 'develop' into staging

This commit is contained in:
Ankush Menat 2022-12-12 14:11:18 +05:30
commit b68e6eb033
4 changed files with 35 additions and 13 deletions

View File

@ -15,6 +15,7 @@ jobs:
timeout-minutes: 60 timeout-minutes: 60
strategy: strategy:
fail-fast: false
matrix: matrix:
python-version: [ '3.7', '3.8', '3.9', '3.10' ] python-version: [ '3.7', '3.8', '3.9', '3.10' ]
@ -89,6 +90,7 @@ jobs:
timeout-minutes: 60 timeout-minutes: 60
strategy: strategy:
fail-fast: false
matrix: matrix:
python-version: [ '3.7', '3.10' ] python-version: [ '3.7', '3.10' ]

View File

@ -586,7 +586,9 @@ def install_app(
build_assets(bench_path=bench_path, app=app) build_assets(bench_path=bench_path, app=app)
if restart_bench: if restart_bench:
bench.reload() # Avoiding exceptions here as production might not be set-up
# OR we might just be generating docker images.
bench.reload(_raise=False)
def pull_apps(apps=None, bench_path=".", reset=False): def pull_apps(apps=None, bench_path=".", reset=False):

View File

@ -44,8 +44,8 @@ logger = logging.getLogger(bench.PROJECT_NAME)
class Base: class Base:
def run(self, cmd, cwd=None): def run(self, cmd, cwd=None, _raise=True):
return exec_cmd(cmd, cwd=cwd or self.cwd) return exec_cmd(cmd, cwd=cwd or self.cwd, _raise=_raise)
class Validator: class Validator:
@ -133,7 +133,7 @@ class Bench(Base, Validator):
raise raise
self.apps.sync() self.apps.sync()
# self.build() - removed because it seems unnecessary # self.build() - removed because it seems unnecessary
self.reload() self.reload(_raise=False)
@step(title="Building Bench Assets", success="Bench Assets Built") @step(title="Building Bench Assets", success="Bench Assets Built")
def build(self): def build(self):
@ -141,16 +141,16 @@ class Bench(Base, Validator):
run_frappe_cmd("build", bench_path=self.name) run_frappe_cmd("build", bench_path=self.name)
@step(title="Reloading Bench Processes", success="Bench Processes Reloaded") @step(title="Reloading Bench Processes", success="Bench Processes Reloaded")
def reload(self, web=False, supervisor=True, systemd=True): def reload(self, web=False, supervisor=True, systemd=True, _raise=True):
"""If web is True, only web workers are restarted""" """If web is True, only web workers are restarted"""
conf = self.conf conf = self.conf
if conf.get("developer_mode"): if conf.get("developer_mode"):
restart_process_manager(bench_path=self.name, web_workers=web) restart_process_manager(bench_path=self.name, web_workers=web)
if supervisor or conf.get("restart_supervisor_on_update"): if supervisor or conf.get("restart_supervisor_on_update"):
restart_supervisor_processes(bench_path=self.name, web_workers=web) restart_supervisor_processes(bench_path=self.name, web_workers=web, _raise=_raise)
if systemd and conf.get("restart_systemd_on_update"): if systemd and conf.get("restart_systemd_on_update"):
restart_systemd_processes(bench_path=self.name, web_workers=web) restart_systemd_processes(bench_path=self.name, web_workers=web, _raise=_raise)
def get_installed_apps(self) -> List: def get_installed_apps(self) -> List:
"""Returns list of installed apps on bench, not in excluded_apps.txt""" """Returns list of installed apps on bench, not in excluded_apps.txt"""
@ -361,6 +361,7 @@ class BenchSetup(Base):
self.run(f"{venv} env", cwd=self.bench.name) self.run(f"{venv} env", cwd=self.bench.name)
self.pip() self.pip()
self.wheel()
if os.path.exists(frappe): if os.path.exists(frappe):
self.run( self.run(
@ -398,6 +399,19 @@ class BenchSetup(Base):
f"{self.bench.python} -m pip install {quiet_flag} --upgrade pip", cwd=self.bench.name f"{self.bench.python} -m pip install {quiet_flag} --upgrade pip", cwd=self.bench.name
) )
@step(title="Installing wheel", success="Installed wheel")
def wheel(self, verbose=False):
"""Wheel is required for building old setup.py packages.
ref: https://github.com/pypa/pip/issues/8559"""
import bench.cli
verbose = bench.cli.verbose or verbose
quiet_flag = "" if verbose else "--quiet"
return self.run(
f"{self.bench.python} -m pip install {quiet_flag} wheel", cwd=self.bench.name
)
def logging(self): def logging(self):
from bench.utils import setup_logging from bench.utils import setup_logging

View File

@ -276,7 +276,7 @@ def patch_sites(bench_path="."):
raise PatchError raise PatchError
def restart_supervisor_processes(bench_path=".", web_workers=False): def restart_supervisor_processes(bench_path=".", web_workers=False, _raise=False):
from bench.bench import Bench from bench.bench import Bench
bench = Bench(bench_path) bench = Bench(bench_path)
@ -285,7 +285,7 @@ def restart_supervisor_processes(bench_path=".", web_workers=False):
bench_name = get_bench_name(bench_path) bench_name = get_bench_name(bench_path)
if cmd: if cmd:
bench.run(cmd) bench.run(cmd, _raise=_raise)
else: else:
sudo = "" sudo = ""
@ -312,18 +312,22 @@ def restart_supervisor_processes(bench_path=".", web_workers=False):
else: else:
group = "frappe:" group = "frappe:"
bench.run(f"{sudo}supervisorctl restart {group}") failure = bench.run(f"{sudo}supervisorctl restart {group}", _raise=_raise)
if failure:
log("restarting supervisor failed. Use `bench restart` to retry.", level=3)
def restart_systemd_processes(bench_path=".", web_workers=False): def restart_systemd_processes(bench_path=".", web_workers=False, _raise=True):
bench_name = get_bench_name(bench_path) bench_name = get_bench_name(bench_path)
exec_cmd( exec_cmd(
f"sudo systemctl stop -- $(systemctl show -p Requires {bench_name}.target | cut" f"sudo systemctl stop -- $(systemctl show -p Requires {bench_name}.target | cut"
" -d= -f2)" " -d= -f2)",
_raise=_raise,
) )
exec_cmd( exec_cmd(
f"sudo systemctl start -- $(systemctl show -p Requires {bench_name}.target |" f"sudo systemctl start -- $(systemctl show -p Requires {bench_name}.target |"
" cut -d= -f2)" " cut -d= -f2)",
_raise=_raise,
) )