From 0bb5ffeb693d17a164bb6d9d924a170f089cd8ee Mon Sep 17 00:00:00 2001 From: David Date: Tue, 26 Nov 2024 13:44:12 +0100 Subject: [PATCH 1/2] fix: apps init; apps might be an empty folder still --- bench/bench.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bench/bench.py b/bench/bench.py index dd2afc98..1b2ca261 100644 --- a/bench/bench.py +++ b/bench/bench.py @@ -283,7 +283,7 @@ class BenchApps(MutableSequence): ] self.apps.remove("frappe") self.apps.insert(0, "frappe") - except FileNotFoundError: + except (FileNotFoundError, ValueError): self.apps = [] def __getitem__(self, key): From ac08ec6dee895dbcf9ede1a99d7ce83908262f0e Mon Sep 17 00:00:00 2001 From: David Date: Tue, 26 Nov 2024 12:54:30 +0100 Subject: [PATCH 2/2] feat: add more flexibility to procfile render --- bench/config/procfile.py | 13 +++++++++---- bench/config/templates/Procfile | 13 ++++++++----- 2 files changed, 17 insertions(+), 9 deletions(-) diff --git a/bench/config/procfile.py b/bench/config/procfile.py index 7feaab72..5b881a3e 100755 --- a/bench/config/procfile.py +++ b/bench/config/procfile.py @@ -4,12 +4,14 @@ import platform import click import bench -from bench.app import use_rq from bench.bench import Bench from bench.utils import which -def setup_procfile(bench_path, yes=False, skip_redis=False): +def setup_procfile(bench_path, yes=False, skip_redis=False, skip_web=False, skip_watch=None, skip_socketio=False, skip_schedule=False, with_coverage=False): + if skip_watch is None: + # backwards compatibilty; may be eventually removed + skip_watch = os.environ.get("CI") config = Bench(bench_path).conf procfile_path = os.path.join(bench_path, "Procfile") @@ -25,10 +27,13 @@ def setup_procfile(bench_path, yes=False, skip_redis=False): .get_template("Procfile") .render( node=which("node") or which("nodejs"), - use_rq=use_rq(bench_path), webserver_port=config.get("webserver_port"), - CI=os.environ.get("CI"), skip_redis=skip_redis, + skip_web=skip_web, + skip_watch=skip_watch, + skip_socketio=skip_socketio, + skip_schedule=skip_schedule, + with_coverage=with_coverage, workers=config.get("workers", {}), is_mac=is_mac, ) diff --git a/bench/config/templates/Procfile b/bench/config/templates/Procfile index 1f2440fb..199b8b2b 100644 --- a/bench/config/templates/Procfile +++ b/bench/config/templates/Procfile @@ -2,15 +2,18 @@ redis_cache: redis-server config/redis_cache.conf redis_queue: redis-server config/redis_queue.conf {% endif %} -web: bench serve {% if webserver_port -%} --port {{ webserver_port }} {%- endif %} - +{% if not skip_web %} +web: bench serve {% if with_coverage -%} --with-coverage {%- endif %} {% if webserver_port -%} --port {{ webserver_port }} {%- endif %} +{% endif %} +{% if not skip_socketio %} socketio: {{ node }} apps/frappe/socketio.js - -{% if not CI %} +{% endif %} +{% if not skip_watch %} watch: bench watch {% endif %} - +{% if not skip_schedule %} schedule: bench schedule +{% endif %} worker: {{ 'OBJC_DISABLE_INITIALIZE_FORK_SAFETY=YES NO_PROXY=*' if is_mac else '' }} bench worker 1>> logs/worker.log 2>> logs/worker.error.log {% for worker_name, worker_details in workers.items() %} worker_{{ worker_name }}: {{ 'OBJC_DISABLE_INITIALIZE_FORK_SAFETY=YES NO_PROXY=*' if is_mac else '' }} bench worker --queue {{ worker_name }} 1>> logs/worker.log 2>> logs/worker.error.log