2
0
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:
Aradhya Tripathi 2022-05-04 18:11:11 +05:30 committed by GitHub
commit da49ec9832
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
4 changed files with 33 additions and 35 deletions

View File

@ -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

View File

@ -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:

View File

@ -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"))

View File

@ -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):