axmol/tools/jenkins-scripts/pull-request-builder.py

165 lines
5.1 KiB
Python
Raw Normal View History

#Github pull reqest builder for Jenkins
import json
import os
import re
import urllib2
import urllib
import base64
import requests
2014-01-02 10:19:48 +08:00
import sys
2014-01-02 17:09:49 +08:00
import traceback
2014-01-06 20:58:00 +08:00
import platform
import subprocess
#set Jenkins build description using submitDescription to mock browser behavior
#TODO: need to set parent build description
2014-01-06 20:58:00 +08:00
def set_description(desc, url):
req_data = urllib.urlencode({'description': desc})
2014-01-06 20:58:00 +08:00
req = urllib2.Request(url + 'submitDescription', req_data)
#print(os.environ['BUILD_URL'])
req.add_header('Content-Type', 'application/x-www-form-urlencoded')
base64string = base64.encodestring(os.environ['JENKINS_ADMIN']+ ":" + os.environ['JENKINS_ADMIN_PW']).replace('\n', '')
req.add_header("Authorization", "Basic " + base64string)
2014-01-02 17:09:49 +08:00
try:
urllib2.urlopen(req)
except:
traceback.print_exc()
2014-01-02 17:09:49 +08:00
def main():
#get payload from os env
payload_str = os.environ['payload']
payload_str = payload_str.decode('utf-8','ignore')
2014-01-02 17:09:49 +08:00
#parse to json obj
payload = json.loads(payload_str)
#get pull number
pr_num = payload['number']
print 'pr_num:' + str(pr_num)
#build for pull request action 'open' and 'synchronize', skip 'close'
action = payload['action']
print 'action: ' + action
2014-01-06 20:58:00 +08:00
#pr = payload['pull_request']
2014-01-09 12:47:46 +08:00
url = payload['html_url']
2014-01-02 17:09:49 +08:00
print "url:" + url
2014-01-06 20:58:00 +08:00
pr_desc = '<h3><a href='+ url + '> pr#' + str(pr_num) + ' is '+ action +'</a></h3>'
2014-01-02 17:09:49 +08:00
#get statuses url
statuses_url = payload['statuses_url']
2014-01-02 17:09:49 +08:00
#get pr target branch
branch = payload['branch']
2014-01-02 17:09:49 +08:00
#set commit status to pending
2014-01-23 00:21:58 +08:00
#target_url = os.environ['BUILD_URL']
jenkins_url = os.environ['JENKINS_URL']
job_name = os.environ['JOB_NAME'].split('/')[0]
build_number = os.environ['BUILD_NUMBER']
target_url = jenkins_url + 'job/' + job_name + '/' + build_number + '/'
2014-01-06 20:58:00 +08:00
set_description(pr_desc, target_url)
2014-01-09 12:47:46 +08:00
2014-01-02 17:09:49 +08:00
data = {"state":"pending", "target_url":target_url}
access_token = os.environ['GITHUB_ACCESS_TOKEN']
Headers = {"Authorization":"token " + access_token}
2014-01-02 17:09:49 +08:00
try:
requests.post(statuses_url, data=json.dumps(data), headers=Headers)
except:
traceback.print_exc()
2014-01-02 17:09:49 +08:00
#reset path to workspace root
os.system("cd " + os.environ['WORKSPACE']);
2014-01-07 15:41:18 +08:00
os.system("git checkout develop")
os.system("git branch -D pull" + str(pr_num))
#clean workspace
print "git clean -xdf"
2014-02-07 21:25:34 +08:00
os.system("git clean -xdf")
#fetch pull request to local repo
git_fetch_pr = "git fetch origin pull/" + str(pr_num) + "/merge"
os.system(git_fetch_pr)
#checkout
git_checkout = "git checkout -b " + "pull" + str(pr_num) + " FETCH_HEAD"
os.system(git_checkout)
#update submodule
git_update_submodule = "git submodule update --init --force"
os.system(git_update_submodule)
2014-01-06 20:58:00 +08:00
2014-01-08 16:21:11 +08:00
# Generate binding glue codes
os.system("python tools/jenkins-scripts/gen_jsb.py")
2014-01-08 16:21:11 +08:00
2014-01-07 15:41:18 +08:00
#make temp dir
print "current dir is" + os.environ['WORKSPACE']
os.system("cd " + os.environ['WORKSPACE']);
os.mkdir("android_build_objs")
2014-01-06 20:58:00 +08:00
#add symbol link
2014-02-26 21:47:23 +08:00
# PROJECTS=["test-cpp",
# "test-javascript","test-lua"]
# print platform.system()
# if(platform.system() == 'Darwin'):
# for item in PROJECTS:
# cmd = "ln -s " + os.environ['WORKSPACE']+"/android_build_objs/ " + os.environ['WORKSPACE']+"/tests/"+item+"/proj.android/obj"
# os.system(cmd)
# elif(platform.system() == 'Windows'):
# for item in PROJECTS:
# p = item.replace("/", os.sep)
# cmd = "mklink /J "+os.environ['WORKSPACE']+os.sep+"tests"+os.sep +p+os.sep+"proj.android"+os.sep+"obj " + os.environ['WORKSPACE']+os.sep+"android_build_objs"
# print cmd
# os.system(cmd)
2014-01-06 20:58:00 +08:00
2014-01-02 17:09:49 +08:00
#build
#TODO: add android-linux build
#TODO: add mac build
node_name = os.environ['NODE_NAME']
2014-01-02 17:09:49 +08:00
if(branch == 'develop'):
if(node_name == 'android_mac') or (node_name == 'android_win7'):
2014-03-07 10:51:17 +08:00
ret = os.system("python build/android-build.py -n -j10 testcpp")
elif(node_name == 'win32_win7'):
ret = subprocess.call('"%VS110COMNTOOLS%..\IDE\devenv.com" "build\cocos2d-win32.vc2012.sln" /Build "Debug|Win32"', shell=True)
elif(node_name == 'ios_mac'):
ret = os.system("tools/jenkins-scripts/ios-build.sh")
2014-03-07 11:25:35 +08:00
elif(node_name == 'linux_centos'):
os.chdir("build/")
ret = os.system("cmake ../")
ret = os.system("make -j10")
os.chdir("../")
2014-01-02 17:09:49 +08:00
elif(branch == 'master'):
if(platform.system() == 'Darwin'):
ret = os.system("samples/Cpp/TestCpp/proj.android/build_native.sh")
else:
ret = 0
2014-01-02 17:09:49 +08:00
#get build result
print "build finished and return " + str(ret)
2014-01-23 00:21:58 +08:00
exit_code = 1
2014-01-02 17:09:49 +08:00
if ret == 0:
exit_code = 0
else:
exit_code = 1
2014-01-23 00:21:58 +08:00
#clean workspace
os.system("cd " + os.environ['WORKSPACE']);
os.system("git checkout develop")
os.system("git branch -D pull" + str(pr_num))
2014-01-06 20:58:00 +08:00
return(exit_code)
2014-01-02 17:09:49 +08:00
# -------------- main --------------
if __name__ == '__main__':
2014-01-06 20:58:00 +08:00
sys_ret = 0
2014-01-02 17:09:49 +08:00
try:
2014-01-06 20:58:00 +08:00
sys_ret = main()
2014-01-02 17:09:49 +08:00
except:
traceback.print_exc()
2014-01-06 20:58:00 +08:00
sys_ret = 1
finally:
sys.exit(sys_ret)