Skip to content

Commit

Permalink
add JSB to jenkins
Browse files Browse the repository at this point in the history
  • Loading branch information
zilongshanren committed May 25, 2015
1 parent a6a5318 commit c7d6983
Show file tree
Hide file tree
Showing 8 changed files with 56 additions and 16 deletions.
4 changes: 2 additions & 2 deletions CMakeLists.txt
Original file line number Diff line number Diff line change
Expand Up @@ -58,8 +58,8 @@ endif()
set(BUILD_CPP_TESTS_DEFAULT ON)
set(BUILD_LUA_LIBS_DEFAULT ON)
set(BUILD_LUA_TESTS_DEFAULT ON)
set(BUILD_JS_LIBS_DEFAULT OFF)
set(BUILD_JS_TESTS_DEFAULT OFF)
set(BUILD_JS_LIBS_DEFAULT ON)
set(BUILD_JS_TESTS_DEFAULT ON)
# TODO: fix test samples for MSVC
if(MSVC)
set(BUILD_CPP_TESTS_DEFAULT OFF)
Expand Down
28 changes: 17 additions & 11 deletions build/android-build.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,12 +4,12 @@

import sys
import os, os.path
import shutil
from optparse import OptionParser

CPP_SAMPLES = ['cpp-empty-test', 'cpp-tests', 'game-controller-test']
LUA_SAMPLES = ['lua-empty-test', 'lua-tests', 'lua-game-controller-test']
ALL_SAMPLES = CPP_SAMPLES + LUA_SAMPLES
JS_SAMPLES = ['js-tests']
ALL_SAMPLES = CPP_SAMPLES + LUA_SAMPLES + JS_SAMPLES

def caculate_built_samples(args):
''' Compute the sampels to be built
Expand All @@ -27,6 +27,9 @@ def caculate_built_samples(args):
if 'lua' in args:
targets += LUA_SAMPLES
args.remove('lua')
if 'js' in args:
targets += JS_SAMPLES
args.remove('js')

targets += args

Expand All @@ -36,8 +39,8 @@ def caculate_built_samples(args):
return list(targets)

def do_build(app_android_root, build_mode):
command = 'cocos compile -p android -s %s --ndk-mode %s' % (app_android_root, build_mode)

command = 'cocos compile -p android -s %s --ndk-mode %s' % (app_android_root, build_mode)
print command

if os.system(command) != 0:
Expand All @@ -49,7 +52,7 @@ def build_samples(target, build_mode):
build_mode = 'debug'
elif build_mode != 'release':
build_mode = 'debug'

build_targets = caculate_built_samples(target)

app_android_root = ''
Expand All @@ -60,7 +63,8 @@ def build_samples(target, build_mode):
"cpp-tests": "tests/cpp-tests",
"lua-empty-test": "tests/lua-empty-test",
"lua-tests": "tests/lua-tests",
"lua-game-controller-test": "tests/lua-game-controller-test"
"lua-game-controller-test": "tests/lua-game-controller-test",
"js-tests": "tests/js-tests"
}

cocos_root = os.path.join(os.path.dirname(os.path.realpath(__file__)), "..")
Expand All @@ -81,7 +85,7 @@ def build_samples(target, build_mode):
usage = """
This script is mainy used for building tests built-in with cocos2d-x.
Usage: %prog [options] [cpp-empty-test|cpp-tests|lua-empty-test|lua-tests|cpp|lua|all]
Usage: %prog [options] [cpp-empty-test|cpp-tests|lua-empty-test|lua-tests|js-tests|cpp|lua|all]
If you are new to cocos2d-x, I recommend you start with cpp-empty-test, lua-empty-test.
Expand All @@ -93,13 +97,15 @@ def build_samples(target, build_mode):

parser = OptionParser(usage=usage)
parser.add_option("-n", "--ndk", dest="ndk_build_param",
help='It is not used anymore, because cocos console does not support it.')
help='It is not used anymore, because cocos console does not support it.')
parser.add_option("-p", "--platform", dest="android_platform",
help='This parameter is not used any more, just keep compatible.')
help='This parameter is not used any more, just keep compatible.')
parser.add_option("-b", "--build", dest="build_mode",
help='The build mode for java project,debug[default] or release. Get more information,please refer to http://developer.android.com/tools/building/building-cmdline.html')
help='The build mode for java project,debug[default] or release. \
Get more information, \
please refer to http://developer.android.com/tools/building/building-cmdline.html')
(opts, args) = parser.parse_args()

if len(args) == 0:
parser.print_help()
sys.exit(1)
Expand Down
3 changes: 3 additions & 0 deletions tools/jenkins-scripts/do-pull-request-builder.py
Original file line number Diff line number Diff line change
Expand Up @@ -48,10 +48,13 @@ def do_build_slaves():
js_tests_build_scripts = jenkins_script_path + "win32-js-build.bat"
elif(node_name == 'windows-universal' or node_name == 'windows-universal_bak'):
slave_build_scripts = jenkins_script_path + "windows-universal.bat"
js_tests_build_scripts = jenkins_script_path + "windows-js-universal.bat"
elif(node_name == 'ios_mac' or node_name == 'ios' or node_name == 'ios_bak'):
slave_build_scripts = jenkins_script_path + "ios-build.sh"
js_tests_build_scripts = jenkins_script_path + "ios-js-build.sh"
elif(node_name == 'mac' or node_name == 'mac_bak'):
slave_build_scripts = jenkins_script_path + "mac-build.sh"
js_tests_build_scripts = jenkins_script_path + "mac-js-build.sh"
elif(node_name == 'linux_centos' or node_name == 'linux' or node_name == 'linux_bak'):
slave_build_scripts = jenkins_script_path + "linux-build.sh"
elif(node_name == 'wp8'):
Expand Down
2 changes: 1 addition & 1 deletion tools/jenkins-scripts/slave-scripts/android-build.sh
Original file line number Diff line number Diff line change
Expand Up @@ -2,4 +2,4 @@
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
COCOS2DX_ROOT="$DIR"/../../..
cd ${COCOS2DX_ROOT}
python build/android-build.py -p 10 cpp-tests lua-tests
python build/android-build.py -p 10 cpp-tests lua-tests js-tests
4 changes: 2 additions & 2 deletions tools/jenkins-scripts/slave-scripts/gen_jsb.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,13 +4,13 @@
import sys

ret = 0
genbindings_dirs = ['tolua']
genbindings_dirs = ['tolua', 'tojs']
for item in genbindings_dirs:
os.chdir("tools/" + item)
ret = os.system('python genbindings.py')
os.chdir("../..")
if(ret != 0):
ret = 1
break

sys.exit(ret)
7 changes: 7 additions & 0 deletions tools/jenkins-scripts/slave-scripts/ios-js-build.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
#put xctool.sh into your PATH
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
COCOS2DX_ROOT="$DIR"/../../..
xcodebuild -project "$COCOS2DX_ROOT"/build/cocos2d_js_tests.xcodeproj -scheme "js-tests iOS" -destination "platform=iOS Simulator,name=iPhone Retina (4-inch)" clean | xcpretty
xcodebuild -project "$COCOS2DX_ROOT"/build/cocos2d_js_tests.xcodeproj -scheme "js-tests iOS" -destination "platform=iOS Simulator,name=iPhone Retina (4-inch)" build | xcpretty
#the following commands must not be removed
xcodebuild -project "$COCOS2DX_ROOT"/build/cocos2d_js_tests.xcodeproj -scheme "js-tests iOS" -destination "platform=iOS Simulator,name=iPhone Retina (4-inch)" build
22 changes: 22 additions & 0 deletions tools/jenkins-scripts/slave-scripts/mac-js-build.sh
Original file line number Diff line number Diff line change
@@ -0,0 +1,22 @@
#put xctool.sh into your PATH

#######
# Cmake build
#######
# DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
# COCOS2DX_ROOT="$DIR"/../../..
# cd ${COCOS2DX_ROOT}
# mkdir mac-build
# cd mac-build
# cmake ..
# make -j4

#######
# xcode build
#######
DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" && pwd )"
COCOS2DX_ROOT="$DIR"/../../..
xcodebuild -project "$COCOS2DX_ROOT"/build/cocos2d_js_tests.xcodeproj -scheme "js-tests Mac" clean | xcpretty
xcodebuild -project "$COCOS2DX_ROOT"/build/cocos2d_js_tests.xcodeproj -scheme "js-tests Mac" build | xcpretty
#xcpretty has a bug, some xcodebuid fails return value would be treated as 0.
xcodebuild -project "$COCOS2DX_ROOT"/build/cocos2d_js_tests.xcodeproj -scheme "js-tests Mac" build
2 changes: 2 additions & 0 deletions tools/jenkins-scripts/slave-scripts/windows-js-universal.bat
Original file line number Diff line number Diff line change
@@ -0,0 +1,2 @@
call "%VS120COMNTOOLS%vsvars32.bat"
msbuild build\cocos2d-js-win8.1-universal.sln /t:Build /p:Platform="Win32" /p:Configuration="Release" /m

0 comments on commit c7d6983

Please sign in to comment.