mirror of
https://github.com/frappe/bench.git
synced 2025-01-09 16:36:25 +00:00
feat: introduced simple resolver
This commit is contained in:
parent
dd4cda308a
commit
d41e05e24f
37
bench/app.py
37
bench/app.py
@ -1,4 +1,5 @@
|
|||||||
# imports - standard imports
|
# imports - standard imports
|
||||||
|
from collections import OrderedDict
|
||||||
import functools
|
import functools
|
||||||
import json
|
import json
|
||||||
import logging
|
import logging
|
||||||
@ -46,6 +47,7 @@ class AppMeta:
|
|||||||
3. frappe/healthcare@develop
|
3. frappe/healthcare@develop
|
||||||
4. healthcare
|
4. healthcare
|
||||||
5. healthcare@develop, healthcare@v13.12.1
|
5. healthcare@develop, healthcare@v13.12.1
|
||||||
|
6. erpnext
|
||||||
|
|
||||||
References for Version Identifiers:
|
References for Version Identifiers:
|
||||||
* https://www.python.org/dev/peps/pep-0440/#version-specifiers
|
* https://www.python.org/dev/peps/pep-0440/#version-specifiers
|
||||||
@ -91,6 +93,7 @@ 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.branch = subprocess.check_output(["git", "rev-parse", "--abbrev-ref", "HEAD"])
|
||||||
self.org, self.repo, self.tag = os.path.split(self.name)[-2:] + (self.branch,)
|
self.org, self.repo, self.tag = os.path.split(self.name)[-2:] + (self.branch,)
|
||||||
|
|
||||||
def _setup_details_from_name_tag(self):
|
def _setup_details_from_name_tag(self):
|
||||||
@ -98,6 +101,7 @@ class AppMeta:
|
|||||||
self.tag = self.tag or self.branch
|
self.tag = self.tag or self.branch
|
||||||
|
|
||||||
def _setup_details_from_installed_apps(self):
|
def _setup_details_from_installed_apps(self):
|
||||||
|
self.branch = subprocess.check_output(["git", "rev-parse", "--abbrev-ref", "HEAD"])
|
||||||
self.org, self.repo, self.tag = os.path.split(
|
self.org, self.repo, self.tag = os.path.split(
|
||||||
os.path.join(self.bench.name, "apps", self.name)
|
os.path.join(self.bench.name, "apps", self.name)
|
||||||
)[-2:] + (self.branch,)
|
)[-2:] + (self.branch,)
|
||||||
@ -197,6 +201,35 @@ class App(AppMeta):
|
|||||||
def uninstall(self):
|
def uninstall(self):
|
||||||
self.bench.run(f"{self.bench.python} -m pip uninstall -y {self.repo}")
|
self.bench.run(f"{self.bench.python} -m pip uninstall -y {self.repo}")
|
||||||
|
|
||||||
|
def _get_dependencies(self):
|
||||||
|
from bench.utils.app import get_required_deps_url
|
||||||
|
import toml
|
||||||
|
|
||||||
|
info_file = None
|
||||||
|
required_url = get_required_deps_url(self.url, self.tag)
|
||||||
|
print(required_url)
|
||||||
|
try:
|
||||||
|
info_file = toml.loads(requests.get(required_url).text)
|
||||||
|
except Exception:
|
||||||
|
click.echo("\nNo toml file found \n", err=True)
|
||||||
|
|
||||||
|
return info_file["required_apps"] if info_file else {}
|
||||||
|
|
||||||
|
def make_resolution_plan(app: App, bench):
|
||||||
|
"""
|
||||||
|
decide what apps and versions to install and in what order
|
||||||
|
"""
|
||||||
|
resolution = OrderedDict()
|
||||||
|
resolution[app.repo] = app
|
||||||
|
for app_name, branch in app._get_dependencies().items():
|
||||||
|
dep_app = App(app_name, branch=branch, bench=bench)
|
||||||
|
resolution[dep_app.repo] = dep_app
|
||||||
|
resolution.update(make_resolution_plan(dep_app, bench))
|
||||||
|
if app_name in resolution:
|
||||||
|
print("Resolve this conflict!")
|
||||||
|
return resolution
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
def add_to_appstxt(app, bench_path="."):
|
def add_to_appstxt(app, bench_path="."):
|
||||||
from bench.bench import Bench
|
from bench.bench import Bench
|
||||||
@ -310,6 +343,7 @@ def get_app(
|
|||||||
repo_name = app.repo
|
repo_name = app.repo
|
||||||
branch = app.tag
|
branch = app.tag
|
||||||
bench_setup = False
|
bench_setup = False
|
||||||
|
apps_to_install = make_resolution_plan(app, bench)
|
||||||
|
|
||||||
if not is_bench_directory(bench_path):
|
if not is_bench_directory(bench_path):
|
||||||
if not init_bench:
|
if not init_bench:
|
||||||
@ -320,8 +354,9 @@ def get_app(
|
|||||||
|
|
||||||
from bench.utils.system import init
|
from bench.utils.system import init
|
||||||
|
|
||||||
|
frappe_app = apps_to_install["frappe"]
|
||||||
bench_path = get_available_folder_name(f"{app.repo}-bench", bench_path)
|
bench_path = get_available_folder_name(f"{app.repo}-bench", bench_path)
|
||||||
init(path=bench_path, frappe_branch=branch)
|
init(path=bench_path, frappe_branch=frappe_app.tag)
|
||||||
os.chdir(bench_path)
|
os.chdir(bench_path)
|
||||||
bench_setup = True
|
bench_setup = True
|
||||||
|
|
||||||
|
@ -164,6 +164,12 @@ def get_current_branch(app, bench_path="."):
|
|||||||
repo_dir = get_repo_dir(app, bench_path=bench_path)
|
repo_dir = get_repo_dir(app, bench_path=bench_path)
|
||||||
return get_cmd_output("basename $(git symbolic-ref -q HEAD)", cwd=repo_dir)
|
return get_cmd_output("basename $(git symbolic-ref -q HEAD)", cwd=repo_dir)
|
||||||
|
|
||||||
|
def get_required_deps_url(git_url, branch="master", deps="info.toml"):
|
||||||
|
git_url = (
|
||||||
|
git_url.replace(".git", "").replace("github.com", "raw.github.com")
|
||||||
|
)
|
||||||
|
git_url += f"/{branch}/{deps}" if branch else f"/{deps}"
|
||||||
|
return git_url
|
||||||
|
|
||||||
def get_remote(app, bench_path="."):
|
def get_remote(app, bench_path="."):
|
||||||
repo_dir = get_repo_dir(app, bench_path=bench_path)
|
repo_dir = get_repo_dir(app, bench_path=bench_path)
|
||||||
|
Loading…
Reference in New Issue
Block a user