2
0
mirror of https://github.com/frappe/bench.git synced 2025-01-22 22:58:31 +00:00

fix(easy-install): install app configurable

This commit is contained in:
Revant Nandgaonkar 2024-10-29 12:09:48 +05:30
parent 502c9a2ccc
commit c07dfc59f3
2 changed files with 36 additions and 25 deletions

View File

@ -29,7 +29,7 @@ jobs:
- name: Perform production easy install - name: Perform production easy install
run: | run: |
python3 ${GITHUB_WORKSPACE}/easy-install.py build python3 ${GITHUB_WORKSPACE}/easy-install.py build
python3 ${GITHUB_WORKSPACE}/easy-install.py -p -n actions_test --email test@frappe.io --image custom-apps --version latest python3 ${GITHUB_WORKSPACE}/easy-install.py -p -n actions_test --email test@frappe.io --image custom-apps --version latest --app erpnext
docker compose -p actions_test exec backend bench version --format json docker compose -p actions_test exec backend bench version --format json
docker compose -p actions_test exec backend bench --site site1.localhost list-apps --format json docker compose -p actions_test exec backend bench --site site1.localhost list-apps --format json
result=$(curl -H "Host: site1.localhost" -sk https://127.0.0.1/api/method/ping | jq -r ."message") result=$(curl -H "Host: site1.localhost" -sk https://127.0.0.1/api/method/ping | jq -r ."message")

View File

@ -117,7 +117,7 @@ def check_repo_exists() -> bool:
return os.path.exists(os.path.join(os.getcwd(), "frappe_docker")) return os.path.exists(os.path.join(os.getcwd(), "frappe_docker"))
def setup_prod(project: str, sites, email: str, version: str = None, image = None) -> None: def setup_prod(project: str, sites, email: str, version: str = None, image = None, apps = []) -> None:
if len(sites) == 0: if len(sites) == 0:
sites = ["site1.localhost"] sites = ["site1.localhost"]
@ -208,12 +208,12 @@ def setup_prod(project: str, sites, email: str, version: str = None, image = Non
sys.exit(1) sys.exit(1)
for sitename in sites: for sitename in sites:
create_site(sitename, project, db_pass, admin_pass) create_site(sitename, project, db_pass, admin_pass, apps)
else: else:
install_docker() install_docker()
clone_frappe_docker_repo() clone_frappe_docker_repo()
setup_prod(project, sites, email, version, image) # Recursive setup_prod(project, sites, email, version, image, apps) # Recursive
def setup_dev_instance(project: str): def setup_dev_instance(project: str):
@ -286,30 +286,34 @@ def create_site(
project: str, project: str,
db_pass: str, db_pass: str,
admin_pass: str, admin_pass: str,
apps: List[str] = [],
): ):
cprint(f"\nCreating site: {sitename} \n", level=3) cprint(f"\nCreating site: {sitename} \n", level=3)
command = [
which("docker"),
"compose",
"-p",
project,
"exec",
"backend",
"bench",
"new-site",
sitename,
"--no-mariadb-socket",
"--db-root-password",
db_pass,
"--admin-password",
admin_pass,
"--set-default",
]
for app in apps:
command.append("--install-app")
command.append(app)
try: try:
subprocess.run( subprocess.run(
[ command,
which("docker"),
"compose",
"-p",
project,
"exec",
"backend",
"bench",
"new-site",
sitename,
"--no-mariadb-socket",
"--db-root-password",
db_pass,
"--admin-password",
admin_pass,
"--install-app",
"erpnext",
"--set-default",
],
check=True, check=True,
) )
logging.info("New site creation completed") logging.info("New site creation completed")
@ -330,7 +334,7 @@ def add_build_parser(argparser: argparse.ArgumentParser):
build.add_argument( build.add_argument(
"-r", "-r",
"--frappe-path", "--frappe-path",
help="Frappe Repository to use, default: https://github.com/frappe/frappe", # noqa: E501 help="Frappe Repository to use, default: https://github.com/frappe/frappe",
default="https://github.com/frappe/frappe", default="https://github.com/frappe/frappe",
) )
build.add_argument( build.add_argument(
@ -468,6 +472,13 @@ if __name__ == "__main__":
parser.add_argument( parser.add_argument(
"-v", "--version", help="ERPNext version to install, defaults to latest stable" "-v", "--version", help="ERPNext version to install, defaults to latest stable"
) )
parser.add_argument(
"-a",
"--app",
dest="apps",
help="list of app(s) to be installed",
action="append",
)
args = parser.parse_args() args = parser.parse_args()
if args.subcommand == 'build': if args.subcommand == 'build':
@ -493,6 +504,6 @@ if __name__ == "__main__":
if "example.com" in args.email: if "example.com" in args.email:
cprint("Emails with example.com not acceptable", level=1) cprint("Emails with example.com not acceptable", level=1)
sys.exit(1) sys.exit(1)
setup_prod(args.project, args.sites, args.email, args.version, args.image) setup_prod(args.project, args.sites, args.email, args.version, args.image, args.apps)
else: else:
parser.print_help() parser.print_help()