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
|
SOURCE_ROOT = os.path.dirname(os.path.dirname(__file__))
|
||||||
[ -z $1 ] || NODE_VERSION=$1
|
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
|
def main():
|
||||||
darwin*) NODE_PLATFORM=darwin ;;
|
os.chdir(SOURCE_ROOT)
|
||||||
linux*) NODE_PLATFORM=linux ;;
|
|
||||||
*) echo "Unsupported platform $OSTYPE" && exit 1 ;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
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
|
url, filename = get_node_url(args.url, args.version)
|
||||||
NODE_TARBALL_URL="https://gh-contractor-zcbenz.s3.amazonaws.com/node/dist/$NODE_DIST_NAME.tar.gz"
|
directory = download('Download node', url, filename)
|
||||||
TARGET_DIR='node'
|
|
||||||
[ -d "$TARGET_DIR" ] || mkdir "$TARGET_DIR"
|
|
||||||
cd "$TARGET_DIR"
|
|
||||||
curl -fsSkL $NODE_TARBALL_URL | tar -zx || exit 1
|
|
||||||
|
|
||||||
cp "$NODE_DIST_NAME/bin/node" .
|
if IS_POSIX:
|
||||||
rm -rf "$NODE_DIST_NAME"
|
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