2
0
mirror of https://github.com/frappe/bench.git synced 2025-01-10 09:02:10 +00:00
Commit Graph

2318 Commits

Author SHA1 Message Date
Gavin D'souza
b1b8d70055 feat: Add pre-commit checks
* Base pre-commit checks for trailing whitespces, valid files, etc
* pyupgrade with PY37+ syntax
* Aditya's black fork for codebases with tabs
* Flake8 with Frappe's config
2022-07-27 14:38:17 +05:30
gavin
a481934d53
Merge pull request #1334 from gavindsouza/better-cli-resolution
refactor(cli): Commands Resolution
2022-07-27 14:37:16 +05:30
gavin
41b9deb66a
Merge pull request #1336 from gavindsouza/reinstall-app-fix
fix: get-app on existing apps
2022-07-27 14:34:45 +05:30
Gavin D'souza
e03f597ac6 fix: get-app on existing apps
get-app to replace existing folder would fail due to bad url generation.

Changes
* Archive old repo instead of overwritting
* Resetting flags in App instance
2022-07-27 14:24:10 +05:30
Gavin D'souza
8a0b78451b fix: Add support for options on bench main group
Options like --use-feature, --version are tested and support maintained
by the changes defined in this commit
2022-07-27 14:23:16 +05:30
Gavin D'souza
a6f196440a refactor(cli): Commands Resolution
The implementations so far were hacks that worked for the most used
commands but broken down when challenged or expected to maintain
documented usages [eg: custom app commands].

The current implementation consists of a two step approach:
1. figure out command name that user is trying to execute
2. pass the directive to the app (bench, frappe or other) that consists of the cmd

---

For tackling #1, get_cmd_from_sysargv contains exhaustive rules that
cover all (that i know and ive come across) combinations of valid
frappe commands.

For problem #2, a simple check in click's Group object does the trick.

Tested with possible known commands with combinations of context flags
and params, with bench, frappe & external app's commands
2022-07-27 11:08:19 +05:30
Jared L
7da62f96f2
fix(nginx): set proxy_http_version to 1.1
This sets the `proxy_http_version` to `1.1`.

The reason this change should be implemented is that when this is deployed in a Kubernetes environment with Istio, the proxy request fails with HTTP error 426 as the HTTP version is too low for envoy to handle. Setting it to `1.1` will solve the issue.
2022-07-25 10:38:47 +10:00
semantic-release-bot
aae3ffc34e chore(release): Bumped to Version 5.12.1
## [5.12.1](https://github.com/frappe/bench/compare/v5.12.0...v5.12.1) (2022-06-29)

### Bug Fixes

* Use == to define had pinned requirement ([beac865](beac865153))
2022-06-29 14:03:37 +00:00
Gavin D'souza
1ff8b05fd8 Merge branch 'staging' into v5.x 2022-06-29 19:32:23 +05:30
Gavin D'souza
db1dc6225f Merge branch 'develop' into staging 2022-06-29 19:31:54 +05:30
Gavin D'souza
beac865153 fix: Use == to define had pinned requirement
This allows one to add a dependency like `PyPika = '5.1.0'` directly
instead of `PyPika = '==5.1.0'`
2022-06-29 19:29:31 +05:30
semantic-release-bot
b2a48f0dba chore(release): Bumped to Version 5.12.0
# [5.12.0](https://github.com/frappe/bench/compare/v5.11.0...v5.12.0) (2022-06-29)

### Bug Fixes

* (re)Install every Frappe app even if not installed to env ([ffae670](ffae670be7))
* fixed update_app_states call ([#1326](https://github.com/frappe/bench/issues/1326)) ([45267fc](45267fc897))

### Features

* Setup dev-dependencies defined via pyproject ([75957a5](75957a56ee))
2022-06-29 13:47:53 +00:00
Gavin D'souza
ffc434dfcc Merge branch 'staging' into v5.x 2022-06-29 19:16:46 +05:30
Gavin D'souza
777ac114cd Merge branch 'develop' into staging 2022-06-29 19:16:11 +05:30
Aradhya Tripathi
45267fc897
fix: fixed update_app_states call (#1326) 2022-06-23 00:10:41 +05:30
gavin
28549ff139
Merge pull request #1323 from gavindsouza/dev-deps-toml
feat: Dev Dependencies via pyproject.toml
2022-06-17 18:02:22 +05:30
Gavin D'souza
75957a56ee feat: Setup dev-dependencies defined via pyproject
Since support for pyproject.toml exists, Frappe has gotten rid of
requirements.txt file. However, dev-requirements.txt file still existed
in Frappe & other apps. With this, we can get rid of the separate
dev-reqs file as well and replace it by defining the deps in pyproject
under [tool.bench.dev-dependencies]

Example:

For Frappe, this transition will look like moving the contents of
dev-requirements.txt as follows:

```
\# dev-requirements.txt
coverage==5.5
Faker~=13.12.1
pyngrok~=5.0.5
unittest-xml-reporting~=3.0.4

```

```
\# pyproject.toml
[tool.bench.dev-dependencies]
coverage = "==5.5"
Faker = "~=13.12.1"
pyngrok = "~=5.0.5"
unittest-xml-reporting = "~=3.0.4"
```

Note: If dev-dependencies are defined in pyproject.toml, and a
dev-dependencies.txt file exists - the txt file will be ignored.
2022-06-16 18:16:57 +05:30
Gavin D'souza
ffae670be7 fix: (re)Install every Frappe app even if not installed to env 2022-06-16 17:54:21 +05:30
semantic-release-bot
7ec320fa40 chore(release): Bumped to Version 5.11.0
# [5.11.0](https://github.com/frappe/bench/compare/v5.10.1...v5.11.0) (2022-06-14)

### Features

* Support Frappe app distributions with pyproject.toml ([800394c](800394cdda))
2022-06-14 12:21:06 +00:00
Gavin D'souza
c968c10cde Merge branch 'staging' into v5.x 2022-06-14 17:50:08 +05:30
Gavin D'souza
3629262543 Merge branch 'develop' into staging 2022-06-14 17:49:01 +05:30
semantic-release-bot
85e3a363ee chore(release): Bumped to Version 5.10.1
## [5.10.1](https://github.com/frappe/bench/compare/v5.10.0...v5.10.1) (2022-06-14)

### Bug Fixes

* Bump Nodejs v12 => v14 ([cd0fccf](cd0fccfdb4))
2022-06-14 12:17:33 +00:00
Gavin D'souza
2a3cd9dcd2 Merge branch 'staging' into v5.x 2022-06-14 17:46:34 +05:30
Gavin D'souza
d8e6fbe34b Merge branch 'develop' into staging 2022-06-14 17:46:22 +05:30
gavin
39553b343b
Merge pull request #1322 from gavindsouza/pyproject-toml
feat: Support Frappe app distributions with pyproject.toml
2022-06-14 17:44:39 +05:30
Gavin D'souza
800394cdda feat: Support Frappe app distributions with pyproject.toml
Patches get_app_name which reads app name from pyproject's project.name
attribute, setup.cfg's metadata.name or setup.py's name variable.
2022-06-14 16:01:42 +05:30
Gavin D'souza
24e2dd37fe chore: Remove release related tests 2022-06-14 16:00:50 +05:30
Gavin D'souza
21eceae6ac chore: Drop dead code
tx [vulture](https://pypi.org/project/vulture/)
2022-06-14 15:48:56 +05:30
Gavin D'souza
4fcda9ae22 chore: Drop release project
Release is yet another dead / unmaintained project in bench. It used to
be in action - the tool to release ERPNext & Frappe for years but we've
moved to other automated pipelines (that have been around for a while
too). Time to say good-bye to these commands too 👋
2022-06-14 15:41:22 +05:30
Gavin D'souza
0f64446c17 chore: Drop vm project
VM project has been unmaintained and out of date for a long long time
now. The auto-build and publish pipeline has been dead for years and has
been de-listed too from erpnext.org. Nows a better time than ever to get
rid of this unmaintained piece of the project.
2022-06-14 15:36:20 +05:30
gavin
a1a0d5dae4
Merge pull request #1319 from rtdany10/patch-3
fix: Bump Nodejs v12 => v14
2022-06-14 11:13:41 +05:30
semantic-release-bot
175eff7bf7 chore(release): Bumped to Version 5.10.0
# [5.10.0](https://github.com/frappe/bench/compare/v5.9.0...v5.10.0) (2022-06-09)

### Bug Fixes

* using local clones if path is passed in get-app ([5f37135](5f37135ff2))

### Features

* get-app ln -s ([e69b612](e69b612035))
2022-06-09 05:58:53 +00:00
Gavin D'souza
40da1c5693 Merge branch 'staging' into v5.x 2022-06-09 11:27:49 +05:30
Gavin D'souza
07c3c75cd3 Merge branch 'develop' into staging 2022-06-09 11:27:20 +05:30
gavin
8922e8d35f
Merge pull request #1321 from Aradhya-Tripathi/fixes
fix: using local clones if path is passed in get-app
2022-06-09 11:26:29 +05:30
Aradhya Tripathi
dfed5c64a2
Merge branch 'develop' into fixes 2022-06-09 10:29:53 +05:30
Aradhya
011332da14 tests: Updated tests 2022-06-09 10:29:07 +05:30
Aradhya
5f37135ff2 fix: using local clones if path is passed in get-app 2022-06-09 10:27:53 +05:30
gavin
6498bacf07
Merge pull request #1315 from dj12djdjs/feat-softlink-getpp
feat: get-app support soft link as alternative to git clone
2022-06-08 13:48:41 +05:30
semantic-release-bot
508df3736f chore(release): Bumped to Version 5.9.0
# [5.9.0](https://github.com/frappe/bench/compare/v5.8.1...v5.9.0) (2022-06-08)

### Bug Fixes

* add code removed via erroneous commit ([b28cfab](b28cfab550))
* added code removed via erroneous commit ([5b64175](5b641758cf))
* added code removed via erroneous commit ([7e28a3d](7e28a3dd9e))
* allow bench init with git tags ([c943b30](c943b30c66))
* case-insensitive matching ([3f57616](3f57616803))
* check current branch ([2287f3f](2287f3f7ec))
* Check for unauthorized status code in response ([e9b0112](e9b0112a9c))
* check for valid branch in resolve ([79765e6](79765e6b25))
* checking status code to determine rate limit ([dbb1904](dbb19046df))
* Delete folder if --no-backup is passed ([f7f7459](f7f7459c51))
* Don't handle `BaseException`s ([ad000f1](ad000f1be7))
* empty states json condition ([67df07b](67df07b732))
* fixed app states and checking/updating frappe version on install ([30a4ec3](30a4ec3b42))
* fixed app states and checking/updating frappe version on install ([42f4d74](42f4d74beb))
* fixed args to sync-states ([c667be9](c667be9023))
* fixed frappe branch check ([6c15327](6c15327348))
* fixed init in get-app and frappe versions ([88c2367](88c23673d6))
* fixed init in get-app and frappe versions ([e3bd34c](e3bd34c12c))
* Fixed order of install ([281d96a](281d96ac16))
* fixed org, branch for apps mounted on disk ([#1293](https://github.com/frappe/bench/issues/1293)) ([c8ef822](c8ef8224d4))
* fixed states sync ([7f37488](7f374887f4))
* Handle tag fetching failures of disk mounted App inits ([117d456](117d456b16))
* logging when in init-bench ([a26f3ce](a26f3ce564))
* logging when in init-bench ([de315f2](de315f27ad))
* merge conflicts ([61a864d](61a864de11))
* merge conflicts ([ca45305](ca4530528c))
* minor fixes ([94105c0](94105c0aa8))
* minor fixes ([e629ca6](e629ca6f86))
* Misc fixes ([#1294](https://github.com/frappe/bench/issues/1294)) ([eb71573](eb715735bb))
* missing installed branch ([af3c871](af3c871632))
* print required by in output ([5bb3b52](5bb3b52f23))
* Remove virtualenv dependency ([e0f6b17](e0f6b1735d))
* **remove-app:** Use App.name instead of App.repo for consistent App name ([a3b859b](a3b859bf50))
* removed erroneous file push ([f2fe569](f2fe56962f))
* removed erroneous file push ([b7e46aa](b7e46aab6f))
* removed unnecessary requests while removing apps ([49900ce](49900ce74b))
* replace certbot-auto with certbot ([#1303](https://github.com/frappe/bench/issues/1303)) ([a889325](a88932592e))
* reverted changes made by erroneous commit ([b8aa008](b8aa00898f))
* reverted erroneous commits ([ff98aaf](ff98aaf198))
* support for local and remote apps when looking for dependencies ([2f17da1](2f17da1bf0))
* support single required app ([c8205e4](c8205e485d))
* updated apps.sync to support new app_name parameter ([7980709](7980709a20))
* User messages on get-app actions ([d33d987](d33d987b2c))

### Features

* add commit hash and branch in `states.json` ([9004e1d](9004e1dd6a))
* add required and order of install ([9ac091b](9ac091b4d9))
* Added app states ([fdab757](fdab757f9b))
* Added app states ([549e8e2](549e8e2a1d))
* Added app_name attribute to App class ([35504f8](35504f81b3))
* Added bench command for resolve and install ([cdaeea1](cdaeea1d4a))
* Added bench command for resolve and install ([7a311a2](7a311a242d))
* Added exception for invalid version ([ddd498e](ddd498ebd0))
* Added support for backward compatibility in states ([a1a35ee](a1a35eed0e))
* added support for fetching dependencies from hooks.py ([58319a2](58319a21b7))
* added support for fetching dependencies from hooks.py ([7f678a3](7f678a3047))
* Added support for mounted app in get_dependencies ([0b862c0](0b862c0745))
* alternative request to validate branch ([8dd92c3](8dd92c32b1))
* **config:** Add IPv6 listener to nginx site configuration ([#1312](https://github.com/frappe/bench/issues/1312)) ([593c7b7](593c7b737f))
* Exiting when app does not exist ([fc0be25](fc0be250c2))
* introduced simple resolver ([bfd69c3](bfd69c37eb))
* introduced simple resolver ([d41e05e](d41e05e24f))
* Made dynamic mount path if bench attr is passed to App class ([b36c072](b36c0723be))
* mimicking get-app behaviour when app is already installed ([bbca3e9](bbca3e9fab))
* printing resolved dependencies when using resolve-deps flag wih get-app ([95b0834](95b0834932))
* printing resolved dependencies when using resolve-deps flag wih get-app ([bba4019](bba4019579))
* **remove-app:** Options for no backup of app & force removal ([69e14e5](69e14e512f))
* slower alternative for get_required_deps ([d0bd294](d0bd294dc2))
* using gitpython for branch validation ([cb2b0b0](cb2b0b0d7c))
* verbose env setup & checking for compatible versions ([d178b08](d178b08abb))
* verbose error messages ([19f9325](19f932513f))

### Performance Improvements

* caching deps and orgs, repos to avoid time taking checks & added slower version to check org and repo ([bd105a6](bd105a6609))
* Using github API ([b0ae3ae](b0ae3ae359))
2022-06-08 08:03:25 +00:00
Gavin D'souza
1519f034b7 Merge branch 'staging' into v5.x 2022-06-08 13:31:59 +05:30
Gavin D'souza
2005fde2cd Merge branch 'develop' into staging 2022-06-08 13:28:22 +05:30
Dany Robert
cd0fccfdb4
fix: Bump Nodejs v12 => v14 2022-06-06 17:18:54 +05:30
Devin Slauenwhite
e69b612035 feat: get-app ln -s 2022-06-03 04:47:23 +00:00
Orsiris de Jong
593c7b737f
feat(config): Add IPv6 listener to nginx site configuration (#1312) 2022-05-30 17:05:08 +05:30
gavin
d194dc8bb1
Merge pull request #1314 from gavindsouza/rm-virtualenv
fix: Remove virtualenv dependency
2022-05-30 16:27:18 +05:30
Gavin D'souza
e0f6b1735d fix: Remove virtualenv dependency
Use virtualenv cli only if found in PATH. Else use
venv package of the invoker's Python installation.
venv was added in the std lib since PY33.

ref: https://docs.python.org/3/library/venv.html
2022-05-30 14:32:55 +05:30
Devin Slauenwhite
a88932592e
fix: replace certbot-auto with certbot (#1303)
* fix: replace certbot-auto references with certbot and add in prerequesites ansile tasks

* fix: config file flag fix

* fix: certbot path using find_executable instead of hardcoded

* fix: remove easy install entry for certbot

* fix: replace find_executable with which

* fix: no need to check and raise.

* fix: provide user with cerbot install instructions"

* fix: return certbot path

* fix: Use get_certbot_path instead of harcoded path

Co-authored-by: Abhishek Balam <abhishekbalam96@gmail.com>
Co-authored-by: gavin <gavin18d@gmail.com>
2022-05-23 12:44:25 +05:30
gavin
6790f6beaa
Merge pull request #1309 from gavindsouza/remove-app
feat(remove-app): --no-backup, --force
2022-05-19 15:08:42 +05:30
gavin
f7f7459c51 fix: Delete folder if --no-backup is passed 2022-05-19 13:09:18 +05:30