]> git.lizzy.rs Git - minetest.git/commitdiff
Implement GItlab CI daily builds for windows platform (32 & 64) (#5923)
authorLoïc Blot <nerzhul@users.noreply.github.com>
Thu, 8 Jun 2017 14:30:30 +0000 (16:30 +0200)
committerGitHub <noreply@github.com>
Thu, 8 Jun 2017 14:30:30 +0000 (16:30 +0200)
* Implement win32 & win64 builds in Gitlab CI + pkg improvements

* windows buildbot: split build & deploy steps
* move deb artifacts to root folder to have a nicer artifact
* add windows build + packaging on xenial

.gitlab-ci.yml
util/buildbot/buildwin32.sh
util/buildbot/buildwin64.sh

index ad1b9a8c34f223f709ddc8747535d34c1e1cd987..d48dd5fcd5fbf6172218975af9ab46461d945037 100644 (file)
@@ -22,7 +22,7 @@ variables:
     - make install
   artifacts:
     when: on_success
-    expire_in: 1h
+    expire_in: 2h
     paths:
       - artifact/*
 
@@ -39,12 +39,12 @@ variables:
     - rm -Rf build/deb/minetest/usr/share/minetest/games/minetest/.git
     - sed -i 's/DATEPLACEHOLDER/'$(date +%y.%m.%d)'/g' build/deb/minetest/DEBIAN/control
     - sed -i 's/LEVELDB_PLACEHOLDER/'$LEVELDB_PKG'/g' build/deb/minetest/DEBIAN/control
-    - cd build/deb/ && dpkg-deb -b minetest/
+    - cd build/deb/ && dpkg-deb -b minetest/ && mv minetest.deb ../../
   artifacts:
     when: on_success
-    expire_in: 30 day
+    expire_in: 90 day
     paths:
-      - build/deb/*.deb
+      - ./*.deb
 
 .debpkg_install: &debpkg_install
   stage: deploy
@@ -52,7 +52,7 @@ variables:
     - apt-get update -y
     - apt-get install -y libc6 libcurl3-gnutls libfreetype6 libirrlicht1.8 $LEVELDB_PKG liblua5.1-0 libluajit-5.1-2 libopenal1 libstdc++6 libvorbisfile3 libx11-6 zlib1g
   script:
-    - dpkg -i build/deb/*.deb
+    - dpkg -i ./*.deb
 
 ##
 ## Debian
@@ -231,3 +231,80 @@ build:fedora-24:
   image: fedora:24
   before_script:
     - dnf -y install make automake gcc gcc-c++ kernel-devel cmake libcurl* openal* libvorbis* libXxf86vm-devel libogg-devel freetype-devel mesa-libGL-devel zlib-devel jsoncpp-devel irrlicht-devel bzip2-libs gmp-devel sqlite-devel luajit-devel leveldb-devel ncurses-devel doxygen spatialindex-devel bzip2-devel
+
+
+##
+## Mingw for Windows
+##
+
+.generic_win_template: &generic_win_template
+  image: ubuntu:xenial
+  before_script:
+    - apt-get update -y
+    - apt-get install -y p7zip-full wget unzip git cmake gettext
+    - wget http://minetest.kitsunemimi.pw/mingw-w64-${WIN_ARCH}_7.1.1_ubuntu14.04.7z -O mingw.7z > /dev/null
+    - sed -e "s|%PREFIX%|${WIN_ARCH}-w64-mingw32|" -e "s|%ROOTPATH%|/usr/${WIN_ARCH}-w64-mingw32|" < util/travis/toolchain_mingw.cmake.in > ${TOOLCHAIN_OUTPUT}
+    - 7z x -y -o/usr mingw.7z > /dev/null
+
+.build_win_template: &build_win_template
+  <<: *generic_win_template
+  stage: build
+  artifacts:
+    when: on_success
+    expire_in: 2h
+    paths:
+      - build/*
+
+.package_win_template: &package_win_template
+  <<: *generic_win_template
+  stage: package
+  script:
+    - cd build/minetest/_build
+    - make package
+    - cd ../../../
+    - mkdir minetest-win-${WIN_ARCH}
+    - unzip build/minetest/_build/minetest-*-win*.zip -d minetest-win-${WIN_ARCH}
+    - cp /usr/${WIN_ARCH}-w64-mingw32/bin/libgcc*.dll minetest-win-${WIN_ARCH}/minetest-*-win*/bin
+    - cp /usr/${WIN_ARCH}-w64-mingw32/bin/libstdc++*.dll minetest-win-${WIN_ARCH}/minetest-*-win*/bin
+    - cp /usr/${WIN_ARCH}-w64-mingw32/bin/libwinpthread*.dll minetest-win-${WIN_ARCH}/minetest-*-win*/bin
+  artifacts:
+    when: on_success
+    expire_in: 90 day
+    paths:
+      - minetest-win-*/*
+
+build:win32:
+  <<: *build_win_template
+  script:
+    - ./util/buildbot/buildwin32.sh build
+  variables:
+    NO_PACKAGE: "1"
+    WIN_ARCH: "i686"
+    TOOLCHAIN_OUTPUT: "util/buildbot/toolchain_mingw.cmake"
+
+package:win32:
+  <<: *package_win_template
+  dependencies:
+    - build:win32
+  variables:
+    NO_PACKAGE: "1"
+    WIN_ARCH: "i686"
+    TOOLCHAIN_OUTPUT: "util/buildbot/toolchain_mingw.cmake"
+
+build:win64:
+  <<: *build_win_template
+  script:
+    - ./util/buildbot/buildwin64.sh build
+  variables:
+    NO_PACKAGE: "1"
+    WIN_ARCH: "x86_64"
+    TOOLCHAIN_OUTPUT: "util/buildbot/toolchain_mingw64.cmake"
+
+package:win64:
+  <<: *package_win_template
+  dependencies:
+    - build:win64
+  variables:
+    NO_PACKAGE: "1"
+    WIN_ARCH: "x86_64"
+    TOOLCHAIN_OUTPUT: "util/buildbot/toolchain_mingw64.cmake"
index 26f43b235a38d0369bd2f4ac522e62e797fe7371..5ab446593fac560db3e793ff7f9e24c2567ebf32 100755 (executable)
@@ -149,6 +149,8 @@ cmake .. \
        -DLEVELDB_LIBRARY=$libdir/leveldb/lib/libleveldb.dll.a \
        -DLEVELDB_DLL=$libdir/leveldb/bin/libleveldb.dll
 
-make package -j2
+make -j2
+
+[ "x$NO_PACKAGE" = "x" ] && make package
 
 # EOF
index 31d9aad7a895bb86ebb981bebf4612f518867edd..e2fc45b0a1e348d8f925f9bdf9233315d100c39c 100755 (executable)
@@ -150,6 +150,8 @@ cmake .. \
        -DLEVELDB_LIBRARY=$libdir/leveldb/lib/libleveldb.dll.a \
        -DLEVELDB_DLL=$libdir/leveldb/bin/libleveldb.dll
 
-make package -j2
+make -j2
+
+[ "x$NO_PACKAGE" = "x" ] && make package
 
 # EOF