From fc0461ffeb667b5151b6c1bf354388952a6fb119 Mon Sep 17 00:00:00 2001 From: =?utf8?q?Aleksander=20=C5=81ukasz?= Date: Fri, 20 Dec 2013 14:49:18 +0100 Subject: [PATCH] Build can now use configurable path to node_modules This allows for sharing node_modules directory across deployment releases. --- apps/build/management/commands/build.py | 12 ++++++++++++ deployment/base.py | 9 +++++++-- 2 files changed, 19 insertions(+), 2 deletions(-) diff --git a/apps/build/management/commands/build.py b/apps/build/management/commands/build.py index 8fca3208..d87d3b48 100644 --- a/apps/build/management/commands/build.py +++ b/apps/build/management/commands/build.py @@ -21,6 +21,12 @@ class Command(BaseCommand): type='string', default='npm', help='Path to npm binary'), + make_option('--editor-npm-env', + action='store', + dest='editor_npm_env', + type='string', + default=None, + help='Destination path of npm environment, defaults to ./node_modules'), ) def handle(self, **options): @@ -29,6 +35,12 @@ class Command(BaseCommand): build_dir = os.path.join(wiki_base_dir, 'build') self.stdout.write('Installing editor dependencies') + if options['editor_npm_env']: + npm_env = os.path.join(rng_base_dir, options['editor_npm_env']) + if not os.path.exists(npm_env): + os.makedirs(npm_env) + assert os.path.isdir(npm_env) + os.symlink(npm_env, os.path.join(rng_base_dir, 'node_modules')) try: call([options['npm_bin'], 'install'], cwd = rng_base_dir) except OSError: diff --git a/deployment/base.py b/deployment/base.py index 54333259..3c1de902 100644 --- a/deployment/base.py +++ b/deployment/base.py @@ -1,4 +1,6 @@ -from fabric.api import env +import os + +from fabric.api import env, require from fabric.tasks import Task from fnpdjango.deploy import Command @@ -17,7 +19,10 @@ class Environment(Task): for k,v in self.env_vars.items(): env[k] = v - build_cmd = '../../ve/bin/python manage.py build --npm-bin=%s' % self.npm_bin + require('app_path') + + build_cmd = '../../ve/bin/python manage.py build --npm-bin=%s --editor-npm-env=%s' \ + % (self.npm_bin, os.path.join(env['app_path'], 'npm_env')) if 'node_bin_path' in self.env_vars: build_cmd += ' --node-bin-path=%s' % self.env_vars['node_bin_path'] -- 2.20.1