2
0
mirror of https://github.com/frappe/bench.git synced 2025-01-09 16:36:25 +00:00

Add logging, #4

This commit is contained in:
Pratik Vyas 2014-07-11 15:03:07 +05:30
parent a89963bc09
commit 7a5ace5dcb
3 changed files with 34 additions and 3 deletions

View File

@ -1,6 +1,9 @@
import os import os
from .utils import exec_cmd, get_frappe from .utils import exec_cmd, get_frappe
import logging
logger = logging.getLogger(__name__)
def get_apps(bench='.'): def get_apps(bench='.'):
try: try:
@ -17,14 +20,17 @@ def add_to_appstxt(app, bench='.'):
return f.write('\n'.join(apps)) return f.write('\n'.join(apps))
def get_app(app, git_url, bench='.'): def get_app(app, git_url, bench='.'):
logger.info('getting app {}'.format(app))
exec_cmd("git clone {} --origin upstream {}".format(git_url, app), cwd=os.path.join(bench, 'apps')) exec_cmd("git clone {} --origin upstream {}".format(git_url, app), cwd=os.path.join(bench, 'apps'))
install_app(app, bench=bench) install_app(app, bench=bench)
def new_app(app, bench='.'): def new_app(app, bench='.'):
logger.info('creating new app {}'.format(app))
exec_cmd("{frappe} --make_app {apps}".format(frappe=get_frappe(bench=bench), apps=os.path.join(bench, 'apps'))) exec_cmd("{frappe} --make_app {apps}".format(frappe=get_frappe(bench=bench), apps=os.path.join(bench, 'apps')))
install_app(app, bench=bench) install_app(app, bench=bench)
def install_app(app, bench='.'): def install_app(app, bench='.'):
logger.info('installing {}'.format(app))
exec_cmd("{pip} install -e {app}".format(pip=os.path.join(bench, 'env', 'bin', 'pip'), app=os.path.join(bench, 'apps', app))) exec_cmd("{pip} install -e {app}".format(pip=os.path.join(bench, 'env', 'bin', 'pip'), app=os.path.join(bench, 'apps', app)))
add_to_appstxt(app, bench=bench) add_to_appstxt(app, bench=bench)
@ -34,4 +40,5 @@ def pull_all_apps(bench='.'):
for app in apps: for app in apps:
app_dir = os.path.join(apps_dir, app) app_dir = os.path.join(apps_dir, app)
if os.path.exists(os.path.join(app_dir, '.git')): if os.path.exists(os.path.join(app_dir, '.git')):
logger.info('pulling {}'.format(app))
exec_cmd("git pull --rebase upstream HEAD", cwd=app_dir) exec_cmd("git pull --rebase upstream HEAD", cwd=app_dir)

View File

@ -5,13 +5,16 @@ from .utils import new_site as _new_site
from .utils import setup_backups as _setup_backups from .utils import setup_backups as _setup_backups
from .utils import setup_auto_update as _setup_auto_update from .utils import setup_auto_update as _setup_auto_update
from .utils import setup_sudoers as _setup_sudoers from .utils import setup_sudoers as _setup_sudoers
from .utils import build_assets, patch_sites, exec_cmd, update_bench, get_frappe from .utils import build_assets, patch_sites, exec_cmd, update_bench, get_frappe, setup_logging
from .app import get_app as _get_app from .app import get_app as _get_app
from .app import new_app as _new_app from .app import new_app as _new_app
from .app import pull_all_apps from .app import pull_all_apps
from .config import generate_config from .config import generate_config
import os import os
import sys import sys
import logging
logger = logging.getLogger('bench')
def cli(): def cli():
if sys.argv[1] == "frappe": if sys.argv[1] == "frappe":
@ -24,8 +27,9 @@ def frappe(bench='.'):
os.execv(f, [f] + sys.argv[2:]) os.execv(f, [f] + sys.argv[2:])
@click.group() @click.group()
def bench(): def bench(bench='.'):
pass # TODO add bench path context
setup_logging(bench=bench)
@click.command() @click.command()
@click.argument('path') @click.argument('path')

View File

@ -2,6 +2,9 @@ import os
import sys import sys
import subprocess import subprocess
import getpass import getpass
import logging
logger = logging.getLogger(__name__)
def get_frappe(bench='.'): def get_frappe(bench='.'):
frappe = os.path.abspath(os.path.join(bench, 'env', 'bin', 'frappe')) frappe = os.path.abspath(os.path.join(bench, 'env', 'bin', 'frappe'))
@ -19,6 +22,9 @@ def init(path):
os.mkdir(path) os.mkdir(path)
for dirname in ('apps', 'sites', 'config', 'logs'): for dirname in ('apps', 'sites', 'config', 'logs'):
os.mkdir(os.path.join(path, dirname)) os.mkdir(os.path.join(path, dirname))
setup_logging()
setup_env(bench=path) setup_env(bench=path)
get_app('frappe', 'https://github.com/frappe/frappe.git', bench=path) get_app('frappe', 'https://github.com/frappe/frappe.git', bench=path)
setup_backups(bench=path) setup_backups(bench=path)
@ -35,6 +41,7 @@ def setup_env(bench='.'):
exec_cmd('virtualenv {} -p {}'.format('env', sys.executable), cwd=bench) exec_cmd('virtualenv {} -p {}'.format('env', sys.executable), cwd=bench)
def new_site(site, bench='.'): def new_site(site, bench='.'):
logger.info('creating new site {}'.format(site))
exec_cmd("{frappe} --install {site} {site}".format(frappe=get_frappe(bench=bench), site=site), cwd=os.path.join(bench, 'sites')) exec_cmd("{frappe} --install {site} {site}".format(frappe=get_frappe(bench=bench), site=site), cwd=os.path.join(bench, 'sites'))
if len(get_sites(bench=bench)) == 1: if len(get_sites(bench=bench)) == 1:
exec_cmd("{frappe} --use {site}".format(frappe=get_frappe(bench=bench), site=site), cwd=os.path.join(bench, 'sites')) exec_cmd("{frappe} --use {site}".format(frappe=get_frappe(bench=bench), site=site), cwd=os.path.join(bench, 'sites'))
@ -58,14 +65,17 @@ def get_bench_dir(bench='.'):
return os.path.abspath(bench) return os.path.abspath(bench)
def setup_auto_update(bench='.'): def setup_auto_update(bench='.'):
logger.info('setting up auto update')
exec_cmd('echo \"`crontab -l`\" | uniq | sed -e \"a0 10 * * * cd {bench_dir} && {bench} update\" | grep -v "^$" | uniq | crontab'.format(bench_dir=get_bench_dir(bench=bench), exec_cmd('echo \"`crontab -l`\" | uniq | sed -e \"a0 10 * * * cd {bench_dir} && {bench} update\" | grep -v "^$" | uniq | crontab'.format(bench_dir=get_bench_dir(bench=bench),
bench=os.path.join(get_bench_dir(bench=bench), 'env', 'bin', 'bench'))) bench=os.path.join(get_bench_dir(bench=bench), 'env', 'bin', 'bench')))
def setup_backups(bench='.'): def setup_backups(bench='.'):
logger.info('setting up backups')
exec_cmd('echo \"`crontab -l`\" | uniq | sed -e \"a0 */6 * * * cd {sites_dir} && {frappe} --backup all\" | grep -v "^$" | uniq | crontab'.format(sites_dir=get_sites_dir(bench=bench), exec_cmd('echo \"`crontab -l`\" | uniq | sed -e \"a0 */6 * * * cd {sites_dir} && {frappe} --backup all\" | grep -v "^$" | uniq | crontab'.format(sites_dir=get_sites_dir(bench=bench),
frappe=get_frappe(bench=bench))) frappe=get_frappe(bench=bench)))
def update_bench(): def update_bench():
logger.info('setting up sudoers')
cwd = os.path.dirname(os.path.abspath(__file__)) cwd = os.path.dirname(os.path.abspath(__file__))
exec_cmd("git pull", cwd=cwd) exec_cmd("git pull", cwd=cwd)
@ -74,3 +84,13 @@ def setup_sudoers():
f.write("{user} ALL=(ALL) NOPASSWD: {supervisorctl} restart frappe\:\n".format( f.write("{user} ALL=(ALL) NOPASSWD: {supervisorctl} restart frappe\:\n".format(
user=getpass.getuser()), user=getpass.getuser()),
supervisorctl=subprocess.check_output('which supervisorctl', shell=True).strip()) supervisorctl=subprocess.check_output('which supervisorctl', shell=True).strip())
def setup_logging(bench='.'):
if os.path.exists(os.path.join(bench, 'logs')):
logger = logging.getLogger('bench')
log_file = os.path.join(bench, 'logs', 'bench.log')
formatter = logging.Formatter('%(asctime)s %(levelname)s %(message)s')
hdlr = logging.FileHandler(log_file)
hdlr.setFormatter(formatter)
logger.addHandler(hdlr)
logger.setLevel(logging.DEBUG)