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…
	
	Add table
		Add a link
		
	
		Reference in a new issue