Merge pull request #6607 from lmskater/adds-download-deps.py-for-prb

[Jenkins][ci skip] Check external file to support build
This commit is contained in:
James Chen 2014-05-07 19:11:56 +08:00
commit 1a7ae40fac
1 changed files with 35 additions and 1 deletions

View File

@ -12,9 +12,11 @@ import traceback
import platform
import subprocess
import codecs
from shutil import copy
#set Jenkins build description using submitDescription to mock browser behavior
#TODO: need to set parent build description
def set_description(desc, url):
req_data = urllib.urlencode({'description': desc})
req = urllib2.Request(url + 'submitDescription', req_data)
@ -26,6 +28,32 @@ def set_description(desc, url):
urllib2.urlopen(req)
except:
traceback.print_exc()
def check_current_3rd_libs(build_status):
#get current_libs config
config_file_path = "external/config.json"
if not os.path.isfile(config_file_path):
raise Exception("Could not find 'external/config.json'")
with open(config_file_path) as data_file:
data = json.load(data_file)
current_3rd_libs_version = data["current_libs_version"]
filename = current_3rd_libs_version + '.zip'
node_name = os.environ['NODE_NAME']
backup_path = '../../../cocos-2dx-external/node/' + node_name + '/'
if(build_status == 'start'):
source_dir = backup_path + filename
dest_dir = filename
elif(build_status == 'finish'):
source_dir = filename
dest_dir = backup_path + filename
if not os.path.isfile(source_dir) and (build_status == 'start'):
os.system('python download-deps.py -r no')
else:
copy(source_dir, dest_dir)
def main():
#get payload from os env
payload_str = os.environ['payload']
@ -101,6 +129,9 @@ def main():
if(ret != 0):
return(2)
#copy check_current_3rd_libs
check_current_3rd_libs('start')
# Generate binding glue codes
if(branch == 'v3'):
ret = os.system("python tools/jenkins-scripts/gen_jsb.py")
@ -202,6 +233,9 @@ def main():
else:
ret = 0
#backup check_current_3rd_libs
check_current_3rd_libs('finish')
#get build result
print "build finished and return " + str(ret)