From e69b612035a4e376ea7372bb190ce41957d8918c Mon Sep 17 00:00:00 2001 From: Devin Slauenwhite Date: Fri, 3 Jun 2022 04:47:23 +0000 Subject: [PATCH 1/3] feat: get-app ln -s --- bench/app.py | 17 ++++++++++++++--- bench/commands/make.py | 3 +++ 2 files changed, 17 insertions(+), 3 deletions(-) diff --git a/bench/app.py b/bench/app.py index 4b527366..e6180c29 100755 --- a/bench/app.py +++ b/bench/app.py @@ -13,6 +13,8 @@ from datetime import date from urllib.parse import urlparse import os +from markupsafe import soft_str + # imports - third party imports import click from git import Repo @@ -158,8 +160,9 @@ class AppMeta: @functools.lru_cache(maxsize=None) class App(AppMeta): - def __init__(self, name: str, branch: str = None, bench: "Bench" = None, *args, **kwargs): + def __init__(self, name: str, branch: str = None, bench: "Bench" = None, soft_link : bool = False, *args, **kwargs): self.bench = bench + self.soft_link = soft_link self.required_by = None self.local_resolution = [] super().__init__(name, branch, *args, **kwargs) @@ -169,12 +172,19 @@ class App(AppMeta): branch = f"--branch {self.tag}" if self.tag else "" shallow = "--depth 1" if self.bench.shallow_clone else "" + if not self.soft_link: + cmd = "git clone" + args = f"{self.url} {branch} {shallow} --origin upstream" + else: + cmd = "ln -s" + args = f"{self.name}" + fetch_txt = f"Getting {self.repo}" click.secho(fetch_txt, fg="yellow") logger.log(fetch_txt) self.bench.run( - f"git clone {self.url} {branch} {shallow} --origin upstream", + f"{cmd} {args}", cwd=os.path.join(self.bench.name, "apps"), ) @@ -338,6 +348,7 @@ def get_app( skip_assets=False, verbose=False, overwrite=False, + soft_link=False, init_bench=False, resolve_deps=False, ): @@ -354,7 +365,7 @@ def get_app( from bench.utils.app import check_existing_dir bench = Bench(bench_path) - app = App(git_url, branch=branch, bench=bench) + app = App(git_url, branch=branch, bench=bench, soft_link=soft_link) git_url = app.url repo_name = app.repo branch = app.tag diff --git a/bench/commands/make.py b/bench/commands/make.py index 8fe6382b..a3401c99 100755 --- a/bench/commands/make.py +++ b/bench/commands/make.py @@ -130,6 +130,7 @@ def drop(path): @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("--soft-link", is_flag=True, default=False, help="Create a soft link to git repo instead of clone.") @click.option( "--init-bench", is_flag=True, default=False, help="Initialize Bench if not in one" ) @@ -145,6 +146,7 @@ def get_app( name=None, overwrite=False, skip_assets=False, + soft_link=False, init_bench=False, resolve_deps=False, ): @@ -156,6 +158,7 @@ def get_app( branch=branch, skip_assets=skip_assets, overwrite=overwrite, + soft_link=soft_link, init_bench=init_bench, resolve_deps=resolve_deps, ) From 5f37135ff283e7540811e8100008e03ae3907176 Mon Sep 17 00:00:00 2001 From: Aradhya Date: Wed, 8 Jun 2022 19:17:54 +0530 Subject: [PATCH 2/3] fix: using local clones if path is passed in get-app --- bench/app.py | 2 +- 1 file changed, 1 insertion(+), 1 deletion(-) diff --git a/bench/app.py b/bench/app.py index 4b527366..bd1b03be 100755 --- a/bench/app.py +++ b/bench/app.py @@ -141,7 +141,7 @@ class AppMeta: @property def url(self): - if self.is_url: + if self.is_url or self.from_apps or self.on_disk: return self.name if self.use_ssh: From 011332da14a88223c10a67e800b07b4d4a68925f Mon Sep 17 00:00:00 2001 From: Aradhya Date: Thu, 9 Jun 2022 10:25:13 +0530 Subject: [PATCH 3/3] tests: Updated tests --- bench/tests/test_init.py | 6 ++++-- 1 file changed, 4 insertions(+), 2 deletions(-) diff --git a/bench/tests/test_init.py b/bench/tests/test_init.py index 0e2f1964..e9e9b8b4 100755 --- a/bench/tests/test_init.py +++ b/bench/tests/test_init.py @@ -39,8 +39,10 @@ class TestBenchInit(TestBenchBase): def test_init(self, bench_name="test-bench", **kwargs): self.init_bench(bench_name, **kwargs) app = App("file:///tmp/frappe") - self.assertEqual(app.mount_path, "/tmp/frappe") - self.assertEqual(app.url, "https://github.com/frappe/frappe.git") + self.assertTupleEqual( + (app.mount_path, app.url, app.repo, app.org), + ("/tmp/frappe", "file:///tmp/frappe", "frappe", "frappe"), + ) self.assert_folders(bench_name) self.assert_virtual_env(bench_name) self.assert_config(bench_name)