mirror of
https://github.com/frappe/bench.git
synced 2025-01-10 00:37:51 +00:00
Merge branch 'develop' into fixes
This commit is contained in:
commit
da49ec9832
15
.travis.yml
15
.travis.yml
@ -60,21 +60,6 @@ matrix:
|
|||||||
env: TEST=bench
|
env: TEST=bench
|
||||||
script: python -m unittest -v bench.tests.test_utils && python -m unittest -v bench.tests.test_init
|
script: python -m unittest -v bench.tests.test_utils && python -m unittest -v bench.tests.test_init
|
||||||
|
|
||||||
- name: "Python 3.7 Easy Install"
|
|
||||||
python: 3.7
|
|
||||||
env: TEST=easy_install
|
|
||||||
script: sudo python $TRAVIS_BUILD_DIR/install.py --user travis --run-travis --production --verbose
|
|
||||||
|
|
||||||
- name: "Python 3.8 Easy Install"
|
|
||||||
python: 3.8
|
|
||||||
env: TEST=easy_install
|
|
||||||
script: sudo python $TRAVIS_BUILD_DIR/install.py --user travis --run-travis --production --verbose
|
|
||||||
|
|
||||||
- name: "Python 3.9 Easy Install"
|
|
||||||
python: 3.9
|
|
||||||
env: TEST=easy_install
|
|
||||||
script: sudo python $TRAVIS_BUILD_DIR/install.py --user travis --run-travis --production --verbose
|
|
||||||
|
|
||||||
install:
|
install:
|
||||||
- pip3 install urllib3 pyOpenSSL ndg-httpsclient pyasn1
|
- pip3 install urllib3 pyOpenSSL ndg-httpsclient pyasn1
|
||||||
|
|
||||||
|
@ -116,7 +116,7 @@ class AppMeta:
|
|||||||
name = url if url else self.name
|
name = url if url else self.name
|
||||||
if name.startswith("git@") or name.startswith("ssh://"):
|
if name.startswith("git@") or name.startswith("ssh://"):
|
||||||
self.use_ssh = True
|
self.use_ssh = True
|
||||||
_first_part, _second_part = name.split(":")
|
_first_part, _second_part = self.name.rsplit(":", 1)
|
||||||
self.remote_server = _first_part.split("@")[-1]
|
self.remote_server = _first_part.split("@")[-1]
|
||||||
self.org, _repo = _second_part.rsplit("/", 1)
|
self.org, _repo = _second_part.rsplit("/", 1)
|
||||||
else:
|
else:
|
||||||
@ -486,6 +486,13 @@ def new_app(app, no_git=None, bench_path="."):
|
|||||||
|
|
||||||
# For backwards compatibility
|
# For backwards compatibility
|
||||||
app = app.lower().replace(" ", "_").replace("-", "_")
|
app = app.lower().replace(" ", "_").replace("-", "_")
|
||||||
|
if app[0].isdigit() or "." in app:
|
||||||
|
click.secho(
|
||||||
|
"App names cannot start with numbers(digits) or have dot(.) in them",
|
||||||
|
fg="red"
|
||||||
|
)
|
||||||
|
return
|
||||||
|
|
||||||
apps = os.path.abspath(os.path.join(bench_path, "apps"))
|
apps = os.path.abspath(os.path.join(bench_path, "apps"))
|
||||||
args = ["make-app", apps, app]
|
args = ["make-app", apps, app]
|
||||||
if no_git:
|
if no_git:
|
||||||
|
@ -73,3 +73,7 @@ class TestUtils(unittest.TestCase):
|
|||||||
self.assertEqual("11.0", fake_bench.apps.states["frappe"]["version"])
|
self.assertEqual("11.0", fake_bench.apps.states["frappe"]["version"])
|
||||||
|
|
||||||
shutil.rmtree(bench_dir)
|
shutil.rmtree(bench_dir)
|
||||||
|
|
||||||
|
def test_ssh_ports(self):
|
||||||
|
app = App("git@github.com:22:frappe/frappe")
|
||||||
|
self.assertEqual((app.use_ssh, app.org, app.repo), (True, "frappe", "frappe"))
|
@ -51,10 +51,9 @@ def is_frappe_app(directory: str) -> bool:
|
|||||||
|
|
||||||
|
|
||||||
def is_valid_frappe_branch(frappe_path:str, frappe_branch:str):
|
def is_valid_frappe_branch(frappe_path:str, frappe_branch:str):
|
||||||
""" Check if a branch exists in a repo. Throws InvalidRemoteException if branch is not found
|
"""Check if a branch exists in a repo. Throws InvalidRemoteException if branch is not found
|
||||||
|
|
||||||
Uses github's api without auth to query branch.
|
Uses native git command to check for branches on a remote.
|
||||||
If rate limited by gitapi, requests are sent to github.com
|
|
||||||
|
|
||||||
:param frappe_path: git url
|
:param frappe_path: git url
|
||||||
:type frappe_path: str
|
:type frappe_path: str
|
||||||
@ -62,23 +61,26 @@ def is_valid_frappe_branch(frappe_path:str, frappe_branch:str):
|
|||||||
:type frappe_branch: str
|
:type frappe_branch: str
|
||||||
:raises InvalidRemoteException: branch for this repo doesn't exist
|
:raises InvalidRemoteException: branch for this repo doesn't exist
|
||||||
"""
|
"""
|
||||||
if "http" in frappe_path and frappe_branch:
|
import subprocess
|
||||||
frappe_path = frappe_path.replace(".git", "")
|
|
||||||
|
if frappe_branch:
|
||||||
try:
|
try:
|
||||||
owner, repo = frappe_path.split("/")[3], frappe_path.split("/")[4]
|
ret = subprocess.check_output(
|
||||||
except IndexError:
|
(
|
||||||
raise InvalidRemoteException("Invalid git url")
|
"git",
|
||||||
git_api_req = f"https://api.github.com/repos/{owner}/{repo}/branches"
|
"ls-remote",
|
||||||
res = requests.get(git_api_req).json()
|
"--heads",
|
||||||
|
frappe_path,
|
||||||
if "message" in res:
|
frappe_branch,
|
||||||
# slower alternative with no rate limit
|
),
|
||||||
github_req = f'https://github.com/{owner}/{repo}/tree/{frappe_branch}'
|
encoding="UTF-8",
|
||||||
if requests.get(github_req).status_code != 200:
|
)
|
||||||
raise InvalidRemoteException("Invalid git url")
|
if not ret:
|
||||||
|
raise InvalidRemoteException(
|
||||||
elif frappe_branch not in [x["name"] for x in res]:
|
f"Invalid {frappe_branch} for the remote {frappe_path}"
|
||||||
raise InvalidRemoteException("Frappe branch does not exist")
|
)
|
||||||
|
except subprocess.CalledProcessError:
|
||||||
|
raise InvalidRemoteException(f"Invalid frappe path {frappe_path}")
|
||||||
|
|
||||||
|
|
||||||
def log(message, level=0, no_log=False):
|
def log(message, level=0, no_log=False):
|
||||||
|
Loading…
Reference in New Issue
Block a user