mirror of
https://github.com/frappe/bench.git
synced 2025-01-25 16:08:23 +00:00
fix: Initialize bench in get-app with --init-bench
This commit is contained in:
parent
877e812fbb
commit
a2ccc30bc3
@ -3,6 +3,7 @@ PROJECT_NAME = "frappe-bench"
|
||||
FRAPPE_VERSION = None
|
||||
current_path = None
|
||||
updated_path = None
|
||||
LOG_BUFFER = []
|
||||
|
||||
|
||||
def set_frappe_version(bench_path="."):
|
||||
|
16
bench/app.py
16
bench/app.py
@ -15,6 +15,7 @@ import click
|
||||
|
||||
# imports - module imports
|
||||
import bench
|
||||
from bench.exceptions import NotInBenchDirectoryError
|
||||
from bench.utils import (
|
||||
fetch_details_from_tag,
|
||||
get_available_folder_name,
|
||||
@ -271,6 +272,7 @@ def get_app(
|
||||
skip_assets=False,
|
||||
verbose=False,
|
||||
overwrite=False,
|
||||
init_bench=False,
|
||||
):
|
||||
"""bench get-app clones a Frappe App from remote (GitHub or any other git server),
|
||||
and installs it on the current bench. This also resolves dependencies based on the
|
||||
@ -280,7 +282,8 @@ def get_app(
|
||||
git_url parameter.
|
||||
"""
|
||||
from bench.bench import Bench
|
||||
import bench as bench_cli
|
||||
import bench as _bench
|
||||
import bench.cli as bench_cli
|
||||
|
||||
bench = Bench(bench_path)
|
||||
app = App(git_url, branch=branch, bench=bench)
|
||||
@ -290,6 +293,12 @@ def get_app(
|
||||
bench_setup = False
|
||||
|
||||
if not is_bench_directory(bench_path):
|
||||
if not init_bench:
|
||||
raise NotInBenchDirectoryError(
|
||||
f"{os.path.realpath(bench_path)} is not a valid bench directory. "
|
||||
"Run with --init-bench if you'd like to create a Bench too."
|
||||
)
|
||||
|
||||
from bench.utils.system import init
|
||||
|
||||
bench_path = get_available_folder_name(f"{app.repo}-bench", bench_path)
|
||||
@ -297,8 +306,9 @@ def get_app(
|
||||
os.chdir(bench_path)
|
||||
bench_setup = True
|
||||
|
||||
if bench_setup and bench_cli.cli.from_command_line and bench_cli.cli.dynamic_feed:
|
||||
bench_cli.LOG_BUFFER.append({
|
||||
|
||||
if bench_setup and bench_cli.from_command_line and bench_cli.dynamic_feed:
|
||||
_bench.LOG_BUFFER.append({
|
||||
"message": f"Fetching App {repo_name}",
|
||||
"prefix": click.style('⏼', fg='bright_yellow'),
|
||||
"is_parent": True,
|
||||
|
@ -13,6 +13,7 @@ from bench.config.common_site_config import setup_config
|
||||
from bench.utils import (
|
||||
paths_in_bench,
|
||||
exec_cmd,
|
||||
is_bench_directory,
|
||||
is_frappe_app,
|
||||
get_cmd_output,
|
||||
get_git_version,
|
||||
@ -54,7 +55,7 @@ class Bench(Base, Validator):
|
||||
def __init__(self, path):
|
||||
self.name = path
|
||||
self.cwd = os.path.abspath(path)
|
||||
self.exists = os.path.exists(self.name)
|
||||
self.exists = is_bench_directory(self.name)
|
||||
|
||||
self.setup = BenchSetup(self)
|
||||
self.teardown = BenchTearDown(self)
|
||||
|
@ -76,16 +76,31 @@ def drop(path):
|
||||
|
||||
|
||||
|
||||
@click.command(['get', 'get-app'], help='Clone an app from the internet or filesystem and set it up in your bench')
|
||||
@click.argument('name', nargs=-1) # Dummy argument for backward compatibility
|
||||
@click.argument('git-url')
|
||||
@click.option('--branch', default=None, help="branch to checkout")
|
||||
@click.option('--overwrite', is_flag=True, default=False)
|
||||
@click.option('--skip-assets', is_flag=True, default=False, help="Do not build assets")
|
||||
def get_app(git_url, branch, name=None, overwrite=False, skip_assets=False):
|
||||
@click.command(
|
||||
["get", "get-app"],
|
||||
help="Clone an app from the internet or filesystem and set it up in your bench",
|
||||
)
|
||||
@click.argument("name", nargs=-1) # Dummy argument for backward compatibility
|
||||
@click.argument("git-url")
|
||||
@click.option("--branch", default=None, help="branch to checkout")
|
||||
@click.option("--overwrite", is_flag=True, default=False)
|
||||
@click.option("--skip-assets", is_flag=True, default=False, help="Do not build assets")
|
||||
@click.option(
|
||||
"--init-bench", is_flag=True, default=False, help="Initialize Bench if not in one"
|
||||
)
|
||||
def get_app(
|
||||
git_url, branch, name=None, overwrite=False, skip_assets=False, init_bench=False
|
||||
):
|
||||
"clone an app from the internet and set it up in your bench"
|
||||
from bench.app import get_app
|
||||
get_app(git_url, branch=branch, skip_assets=skip_assets, overwrite=overwrite)
|
||||
|
||||
get_app(
|
||||
git_url,
|
||||
branch=branch,
|
||||
skip_assets=skip_assets,
|
||||
overwrite=overwrite,
|
||||
init_bench=init_bench,
|
||||
)
|
||||
|
||||
|
||||
@click.command('new-app', help='Create a new Frappe application under apps folder')
|
||||
|
@ -26,3 +26,7 @@ class CannotUpdateReleaseBench(ValidationError):
|
||||
|
||||
class FeatureDoesNotExistError(CommandFailedError):
|
||||
pass
|
||||
|
||||
|
||||
class NotInBenchDirectoryError(Exception):
|
||||
pass
|
||||
|
Loading…
x
Reference in New Issue
Block a user