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

Merge branch 'develop' of github.com:Aradhya-Tripathi/bench into dependency-resolution

This commit is contained in:
Aradhya 2022-02-25 16:27:41 +05:30
commit 6d05fe2f53
4 changed files with 16 additions and 8 deletions

View File

@ -10,6 +10,7 @@ import sys
import typing import typing
from collections import OrderedDict from collections import OrderedDict
from datetime import date from datetime import date
from urllib.parse import urlparse
# imports - third party imports # imports - third party imports
import click import click
@ -65,6 +66,9 @@ class AppMeta:
self.from_apps = False self.from_apps = False
self.is_url = False self.is_url = False
self.branch = branch self.branch = branch
self.mount_path = os.path.abspath(
os.path.join(urlparse(self.name).netloc, urlparse(self.name).path)
)
self.setup_details() self.setup_details()
def setup_details(self): def setup_details(self):
@ -78,7 +82,7 @@ class AppMeta:
self._setup_details_from_installed_apps() self._setup_details_from_installed_apps()
# fetch meta for repo on mounted disk # fetch meta for repo on mounted disk
elif os.path.exists(self.name): elif os.path.exists(self.mount_path):
self.on_disk = True self.on_disk = True
self._setup_details_from_mounted_disk() self._setup_details_from_mounted_disk()
@ -94,7 +98,9 @@ class AppMeta:
self._setup_details_from_name_tag() self._setup_details_from_name_tag()
def _setup_details_from_mounted_disk(self): def _setup_details_from_mounted_disk(self):
self.org, self.repo, self.tag = os.path.split(self.name)[-2:] + (self.branch,) self.org, self.repo, self.tag = os.path.split(self.mount_path)[-2:] + (
self.branch,
)
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)
@ -125,7 +131,7 @@ class AppMeta:
return os.path.abspath(os.path.join("apps", self.name)) return os.path.abspath(os.path.join("apps", self.name))
if self.on_disk: if self.on_disk:
return os.path.abspath(self.name) return self.mount_path
if self.is_url: if self.is_url:
return self.name return self.name

View File

@ -360,7 +360,7 @@ class BenchSetup(Base):
@job(title="Setting Up Bench Dependencies", success="Bench Dependencies Set Up") @job(title="Setting Up Bench Dependencies", success="Bench Dependencies Set Up")
def requirements(self, apps=None): def requirements(self, apps=None):
"""Install and upgrade all installed apps on given Bench if apps not specified """Install and upgrade specified / all installed apps on given Bench
""" """
from bench.app import App from bench.app import App
@ -375,7 +375,7 @@ class BenchSetup(Base):
App(app, bench=self.bench, to_clone=False).install( skip_assets=True, restart_bench=False) App(app, bench=self.bench, to_clone=False).install( skip_assets=True, restart_bench=False)
def python(self, apps=None): def python(self, apps=None):
"""Install and upgrade Python dependencies for installed apps on given Bench if app not specified """Install and upgrade Python dependencies for specified / all installed apps on given Bench
""" """
import bench.cli import bench.cli
@ -392,7 +392,7 @@ class BenchSetup(Base):
self.run(f"{self.bench.python} -m pip install {quiet_flag} --upgrade -e {app_path}") self.run(f"{self.bench.python} -m pip install {quiet_flag} --upgrade -e {app_path}")
def node(self, apps=None): def node(self, apps=None):
"""Install and upgrade Node dependencies for all apps on given Bench if app not specified """Install and upgrade Node dependencies for specified / all apps on given Bench
""" """
from bench.utils.bench import update_node_packages from bench.utils.bench import update_node_packages

View File

@ -140,7 +140,7 @@ def setup_requirements(node=False, python=False, dev=False, apps=None):
""" """
Setup Python and Node dependencies. Setup Python and Node dependencies.
You can optionally specify one or more apps to specify dependencies for. You can optionally specify one or more apps to setup dependencies for.
""" """
from bench.bench import Bench from bench.bench import Bench

View File

@ -10,6 +10,7 @@ import git
# imports - module imports # imports - module imports
from bench.utils import exec_cmd from bench.utils import exec_cmd
from bench.release import get_bumped_version from bench.release import get_bumped_version
from bench.app import App
from bench.tests.test_base import FRAPPE_BRANCH, TestBenchBase from bench.tests.test_base import FRAPPE_BRANCH, TestBenchBase
@ -34,9 +35,10 @@ class TestBenchInit(TestBenchBase):
def test_utils(self): def test_utils(self):
self.assertEqual(subprocess.call("bench"), 0) self.assertEqual(subprocess.call("bench"), 0)
def test_init(self, bench_name="test-bench", **kwargs): def test_init(self, bench_name="test-bench", **kwargs):
self.init_bench(bench_name, **kwargs) self.init_bench(bench_name, **kwargs)
app = App("file:///tmp/frappe")
self.assertEqual(app.url, "/tmp/frappe")
self.assert_folders(bench_name) self.assert_folders(bench_name)
self.assert_virtual_env(bench_name) self.assert_virtual_env(bench_name)
self.assert_config(bench_name) self.assert_config(bench_name)