Rewrite update-node script in python.
This commit is contained in:
parent
e3803bc499
commit
07260731ca
2 changed files with 122 additions and 23 deletions
|
@ -1,31 +1,130 @@
|
|||
#!/bin/bash
|
||||
#!/usr/bin/env python
|
||||
|
||||
set -e
|
||||
import argparse
|
||||
import atexit
|
||||
import errno
|
||||
import shutil
|
||||
import subprocess
|
||||
import sys
|
||||
import tarfile
|
||||
import tempfile
|
||||
import os
|
||||
import urllib2
|
||||
|
||||
cd "$(dirname $0)/.."
|
||||
|
||||
NODE_VERSION=v0.10.5
|
||||
[ -z $1 ] || NODE_VERSION=$1
|
||||
SOURCE_ROOT = os.path.dirname(os.path.dirname(__file__))
|
||||
NODE_VERSION = 'v0.10.9'
|
||||
NODE_DIST_URL = 'https://gh-contractor-zcbenz.s3.amazonaws.com/node/dist'
|
||||
IS_POSIX = (sys.platform != 'win32') and (sys.platform != 'cygwin')
|
||||
|
||||
# Test whether we need update.
|
||||
if [ -f "node/node" ] && [[ `node/node --version` == $NODE_VERSION ]] ; then
|
||||
exit 0
|
||||
fi
|
||||
|
||||
case $OSTYPE in
|
||||
darwin*) NODE_PLATFORM=darwin ;;
|
||||
linux*) NODE_PLATFORM=linux ;;
|
||||
*) echo "Unsupported platform $OSTYPE" && exit 1 ;;
|
||||
esac
|
||||
def main():
|
||||
os.chdir(SOURCE_ROOT)
|
||||
|
||||
NODE_DIST_NAME="node-$NODE_VERSION-$NODE_PLATFORM-x86"
|
||||
args = parse_args()
|
||||
if not node_needs_update(args.version):
|
||||
return 0
|
||||
|
||||
# Download node and untar
|
||||
NODE_TARBALL_URL="https://gh-contractor-zcbenz.s3.amazonaws.com/node/dist/$NODE_DIST_NAME.tar.gz"
|
||||
TARGET_DIR='node'
|
||||
[ -d "$TARGET_DIR" ] || mkdir "$TARGET_DIR"
|
||||
cd "$TARGET_DIR"
|
||||
curl -fsSkL $NODE_TARBALL_URL | tar -zx || exit 1
|
||||
url, filename = get_node_url(args.url, args.version)
|
||||
directory = download('Download node', url, filename)
|
||||
|
||||
cp "$NODE_DIST_NAME/bin/node" .
|
||||
rm -rf "$NODE_DIST_NAME"
|
||||
if IS_POSIX:
|
||||
root_name = 'node-{0}-{1}-x86'.format(args.version, sys.platform)
|
||||
member = os.path.join(root_name, 'bin', 'node')
|
||||
extract_tarball(os.path.join(directory, filename), member, directory)
|
||||
node_path = os.path.join(directory, member)
|
||||
|
||||
copy_node(node_path)
|
||||
|
||||
|
||||
def parse_args():
|
||||
parser = argparse.ArgumentParser(description='Update node binary')
|
||||
parser.add_argument('--version',
|
||||
help='Version of node',
|
||||
default=NODE_VERSION,
|
||||
required=False)
|
||||
parser.add_argument('--url',
|
||||
help='URL to download node',
|
||||
default=NODE_DIST_URL,
|
||||
required=False)
|
||||
return parser.parse_args()
|
||||
|
||||
|
||||
def node_needs_update(target_version):
|
||||
try:
|
||||
node = os.path.join('node', 'node')
|
||||
if not IS_POSIX:
|
||||
node += '.exe'
|
||||
version = subprocess.check_output([node, '--version'])
|
||||
return version.strip() != target_version
|
||||
except OSError as e:
|
||||
if e.errno != errno.ENOENT:
|
||||
raise
|
||||
return True
|
||||
|
||||
|
||||
def get_node_url(base_url, target_version):
|
||||
if IS_POSIX:
|
||||
distname = 'node-{0}-{1}-x86.tar.gz'.format(target_version, sys.platform)
|
||||
else:
|
||||
distname = 'node-{0}.exe'.format(target_version)
|
||||
return '{0}/{1}'.format(base_url, distname), distname
|
||||
|
||||
|
||||
def copy_node(node_path):
|
||||
safe_mkdir('node')
|
||||
node = os.path.join('node', 'node')
|
||||
safe_unlink(node)
|
||||
os.rename(node_path, node)
|
||||
|
||||
|
||||
def download(text, url, filename):
|
||||
directory = tempfile.mkdtemp(prefix='atom-shell-')
|
||||
atexit.register(shutil.rmtree, directory)
|
||||
|
||||
web_file = urllib2.urlopen(url)
|
||||
file_size = int(web_file.info().getheaders("Content-Length")[0])
|
||||
downloaded_size = 0
|
||||
block_size = 128
|
||||
|
||||
with open(os.path.join(directory, filename), 'w+') as local_file:
|
||||
while True:
|
||||
buf = web_file.read(block_size)
|
||||
if not buf:
|
||||
break
|
||||
|
||||
downloaded_size += len(buf)
|
||||
local_file.write(buf)
|
||||
|
||||
percent = downloaded_size * 100. / file_size
|
||||
status = "\r%s %10d [%3.1f%%]" % (text, downloaded_size, percent)
|
||||
print status,
|
||||
|
||||
print
|
||||
|
||||
return directory
|
||||
|
||||
|
||||
def extract_tarball(tarball_path, member, path):
|
||||
with tarfile.open(tarball_path) as tarball:
|
||||
tarball.extract(member, path)
|
||||
|
||||
|
||||
def safe_unlink(path):
|
||||
try:
|
||||
os.unlink(path)
|
||||
except OSError as e:
|
||||
if e.errno != errno.ENOENT:
|
||||
raise
|
||||
|
||||
|
||||
def safe_mkdir(path):
|
||||
try:
|
||||
os.makedirs(path)
|
||||
except OSError as e:
|
||||
if e.errno != errno.EEXIST:
|
||||
raise
|
||||
|
||||
|
||||
if __name__ == '__main__':
|
||||
sys.exit(main())
|
||||
|
|
Loading…
Reference in a new issue