Merge pull request #1010 from turtleli/travisci_appveyor

Travis CI and Appveyor continuous integration
This commit is contained in:
Gregory Hainaut 2015-12-03 09:08:53 +01:00
commit 31e80c1321
3 changed files with 137 additions and 0 deletions

23
.travis.yml Normal file
View File

@ -0,0 +1,23 @@
language: cpp
sudo: required
dist: trusty
matrix:
include:
# Version 5 seems to be whatever is latest - for now it's 5.2
- env: VERSION=5
compiler: gcc
os: linux
- env: VERSION=4.9
compiler: gcc
os: linux
- env: VERSION=3.7
compiler: clang
os: linux
before_install:
- ./travis.sh before_install
script:
- ./travis.sh script

35
appveyor.yml Normal file
View File

@ -0,0 +1,35 @@
# Static build version - changing the version dynamically means you can't
# just click from github to see how things are progressing until the build has
# finished, which could be a bit annoying.
version: 1.{build}-{branch}
environment:
matrix:
- platform: Win32
target: ReleaseAll
visualstudio_string: vs2015
- platform: Win32
VisualStudioVersion: 12.0
target: ReleaseAll
visualstudio_string: vs2013
init:
# Use CRLF line endings on Windows so users can just use Notepad.
- git config --global core.autocrlf true
build_script:
- msbuild buildbot.xml /m /t:%target% /logger:"C:\Program Files\AppVeyor\BuildAgent\Appveyor.MSBuildLogger.dll"
after_build:
- ps: $env:gitrev = git describe --tags
- ps: $env:my_version = "$env:gitrev-$env:appveyor_repo_branch-$env:appveyor_build_number"
- type NUL > bin\portable.ini
- set folder_name=pcsx2-%my_version%-%visualstudio_string%-%platform%-%target%
- rename bin %folder_name%
- 7z a -mx9 %folder_name%.7z %folder_name%
test: off
artifacts:
- path: $(folder_name).7z
name: $(visualstudio_string)-$(target)

79
travis.sh Executable file
View File

@ -0,0 +1,79 @@
#!/bin/sh
set -ex
linux_before_install() {
# Build worker is 64-bit only by default it seems.
sudo dpkg --add-architecture i386
# Compilers
if [ "${CXX}" = "clang++" ]; then
sudo apt-key adv --fetch-keys http://llvm.org/apt/llvm-snapshot.gpg.key
sudo add-apt-repository -y "deb http://llvm.org/apt/trusty/ llvm-toolchain-trusty-${VERSION} main"
# g++-4.8-multilib is necessary for compiler dependencies. Well, I think
# the specific dependency is probably lib32gcc-4.8-dev.
COMPILER_PACKAGE="clang-${VERSION} g++-4.8-multilib"
fi
if [ "${CXX}" = "g++" ]; then
sudo add-apt-repository -y ppa:ubuntu-toolchain-r/test
COMPILER_PACKAGE="g++-${VERSION}-multilib"
fi
sudo apt-get -qq update
# The 64-bit versions of the first 7 dependencies are part of the initial
# build image. libgtk2.0-dev:i386 and libsdl2-dev:i386 require the 32-bit
# versions of the dependencies, and the 2 versions conflict. So those
# dependencies must be explicitly installed.
sudo apt-get -qq -y install \
gir1.2-freedesktop:i386 \
gir1.2-gdkpixbuf-2.0:i386 \
gir1.2-glib-2.0:i386 \
libcairo2-dev:i386 \
libgdk-pixbuf2.0-dev:i386 \
libgirepository-1.0-1:i386 \
libglib2.0-dev:i386 \
libaio-dev:i386 \
libasound2-dev:i386 \
libgl1-mesa-dev:i386 \
libgtk2.0-dev:i386 \
liblzma-dev:i386 \
libpng12-dev:i386 \
libsdl2-dev:i386 \
libsoundtouch-dev:i386 \
libwxgtk3.0-dev:i386 \
libxext-dev:i386 \
portaudio19-dev:i386 \
zlib1g-dev:i386 \
${COMPILER_PACKAGE}
# libpng++-dev is noarch but doesn't install nicely.
apt-get download libpng++-dev
sudo dpkg --force-all -i $(ls | grep 'libpng++-dev')
}
linux_script() {
mkdir build
cd build
export CC=${CC}-${VERSION} CXX=${CXX}-${VERSION}
cmake \
-DCMAKE_TOOLCHAIN_FILE=cmake/linux-compiler-i386-multilib.cmake \
-DCMAKE_BUILD_TYPE=Release \
-DBUILD_REPLAY_LOADERS=TRUE \
-DCMAKE_BUILD_PO=FALSE \
..
# Documentation says 1.5 cores, so 2 or 3 threads should work ok.
make -j3 install
}
# Just in case I do manual testing and accidentally insert "rm -rf /"
case "${1}" in
before_install|script)
${TRAVIS_OS_NAME}_${1}
;;
*)
echo "Unknown command" && false
;;
esac