diff options
author | Loïc Blot <nerzhul@users.noreply.github.com> | 2017-04-21 10:22:20 +0200 |
---|---|---|
committer | GitHub <noreply@github.com> | 2017-04-21 10:22:20 +0200 |
commit | 2ad74a9e8b9da48aef62346de6cd55f304c6440d (patch) | |
tree | c82fdf3836b12d7740160d9c020a067b74961c78 | |
parent | 370354cc87937bbfb6f24aa062966af8e039cec0 (diff) | |
download | minetest-2ad74a9e8b9da48aef62346de6cd55f304c6440d.tar.gz minetest-2ad74a9e8b9da48aef62346de6cd55f304c6440d.tar.bz2 minetest-2ad74a9e8b9da48aef62346de6cd55f304c6440d.zip |
Gitlab-CI enhancements (#5629)
-rw-r--r-- | .gitlab-ci.yml | 146 | ||||
-rw-r--r-- | misc/debpkg-control | 36 |
2 files changed, 181 insertions, 1 deletions
diff --git a/.gitlab-ci.yml b/.gitlab-ci.yml index 7df4490b7..84022cd0e 100644 --- a/.gitlab-ci.yml +++ b/.gitlab-ci.yml @@ -5,6 +5,11 @@ stages: - build + - package + - deploy + +variables: + MINETEST_GAME_REPO: "https://github.com/minetest/minetest_game.git" .build_template: &build_definition stage: build @@ -12,7 +17,7 @@ stages: - mkdir cmakebuild - mkdir -p artifact/minetest/usr/ - cd cmakebuild - - cmake -DCMAKE_INSTALL_PREFIX=../artifact/minetest/usr/ -DCMAKE_BUILD_TYPE=Release -DRUN_IN_PLACE=TRUE -DENABLE_GETTEXT=TRUE -DBUILD_SERVER=TRUE .. + - cmake -DCMAKE_INSTALL_PREFIX=../artifact/minetest/usr/ -DCMAKE_BUILD_TYPE=Release -DRUN_IN_PLACE=FALSE -DENABLE_GETTEXT=TRUE -DBUILD_SERVER=TRUE .. - make -j2 - make install artifacts: @@ -21,9 +26,40 @@ stages: paths: - artifact/* +.debpkg_template: &debpkg_template + stage: package + before_script: + - apt-get update -y + - apt-get install -y git + - mkdir -p build/deb/minetest/DEBIAN/ + - cp misc/debpkg-control build/deb/minetest/DEBIAN/control + - cp -Rp artifact/minetest/usr build/deb/minetest/ + script: + - git clone $MINETEST_GAME_REPO build/deb/minetest/usr/share/minetest/games/minetest + - 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/ + artifacts: + when: on_success + expire_in: 30 day + paths: + - build/deb/*.deb + +.debpkg_install: &debpkg_install + stage: deploy + before_script: + - 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 + ## ## Debian ## + +# Jessie + build:debian-8: <<: *build_definition image: debian:8 @@ -31,6 +67,24 @@ build:debian-8: - apt-get update -y - apt-get -y install build-essential libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev +package:debian-8: + image: debian:8 + dependencies: + - build:debian-8 + variables: + LEVELDB_PKG: libleveldb1 + <<: *debpkg_template + +deploy:debian-8: + image: debian:8 + dependencies: + - package:debian-8 + variables: + LEVELDB_PKG: libleveldb1 + <<: *debpkg_install + +# Stretch + build:debian-9: <<: *build_definition image: debian:9 @@ -38,9 +92,28 @@ build:debian-9: - apt-get update -y - apt-get -y install build-essential libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev +package:debian-9: + image: debian:9 + dependencies: + - build:debian-9 + variables: + LEVELDB_PKG: libleveldb1v5 + <<: *debpkg_template + +deploy:debian-9: + image: debian:9 + dependencies: + - package:debian-9 + variables: + LEVELDB_PKG: libleveldb1v5 + <<: *debpkg_install + ## ## Ubuntu ## + +# Trusty + build:ubuntu-14.04: <<: *build_definition image: ubuntu:trusty @@ -48,6 +121,24 @@ build:ubuntu-14.04: - apt-get update -y - apt-get -y install build-essential libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev +package:ubuntu-14.04: + image: ubuntu:trusty + dependencies: + - build:ubuntu-14.04 + variables: + LEVELDB_PKG: libleveldb1 + <<: *debpkg_template + +deploy:ubuntu-14.04: + image: ubuntu:trusty + dependencies: + - package:ubuntu-14.04 + variables: + LEVELDB_PKG: libleveldb1 + <<: *debpkg_install + +# Xenial + build:ubuntu-16.04: <<: *build_definition image: ubuntu:xenial @@ -55,6 +146,24 @@ build:ubuntu-16.04: - apt-get update -y - apt-get -y install build-essential libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev +package:ubuntu-16.04: + image: ubuntu:xenial + dependencies: + - build:ubuntu-16.04 + variables: + LEVELDB_PKG: libleveldb1v5 + <<: *debpkg_template + +deploy:ubuntu-16.04: + image: ubuntu:xenial + dependencies: + - package:ubuntu-16.04 + variables: + LEVELDB_PKG: libleveldb1v5 + <<: *debpkg_install + +# Yakkety + build:ubuntu-16.10: <<: *build_definition image: ubuntu:yakkety @@ -62,6 +171,24 @@ build:ubuntu-16.10: - apt-get update -y - apt-get -y install build-essential libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev +package:ubuntu-16.10: + image: ubuntu:yakkety + dependencies: + - build:ubuntu-16.10 + variables: + LEVELDB_PKG: libleveldb1v5 + <<: *debpkg_template + +deploy:ubuntu-16.10: + image: ubuntu:yakkety + dependencies: + - package:ubuntu-16.10 + variables: + LEVELDB_PKG: libleveldb1v5 + <<: *debpkg_install + +# Zesty + build:ubuntu-17.04: <<: *build_definition image: ubuntu:zesty @@ -69,9 +196,26 @@ build:ubuntu-17.04: - apt-get update -y - apt-get -y install build-essential libirrlicht-dev cmake libbz2-dev libpng-dev libjpeg-dev libxxf86vm-dev libgl1-mesa-dev libsqlite3-dev libogg-dev libvorbis-dev libopenal-dev libcurl4-gnutls-dev libfreetype6-dev zlib1g-dev libgmp-dev libjsoncpp-dev +package:ubuntu-17.04: + image: ubuntu:zesty + dependencies: + - build:ubuntu-17.04 + variables: + LEVELDB_PKG: libleveldb1v5 + <<: *debpkg_template + +deploy:ubuntu-17.04: + image: ubuntu:zesty + dependencies: + - package:ubuntu-17.04 + variables: + LEVELDB_PKG: libleveldb1v5 + <<: *debpkg_install + ## ## Fedora ## + build:fedora-24: <<: *build_definition image: fedora:24 diff --git a/misc/debpkg-control b/misc/debpkg-control new file mode 100644 index 000000000..b228f4c79 --- /dev/null +++ b/misc/debpkg-control @@ -0,0 +1,36 @@ +Section: games +Priority: extra +Standards-Version: 3.6.2 +Package: minetest-staging +Version: 0.4.15-DATEPLACEHOLDER +Depends: libc6, libcurl3-gnutls, libfreetype6, libirrlicht1.8, LEVELDB_PLACEHOLDER, liblua5.1-0, libluajit-5.1-2, libopenal1, libstdc++6, libvorbisfile3, libx11-6, zlib1g +Maintainer: Loic Blot <loic.blot@unix-experience.fr> +Homepage: http://minetest.net/ +Vcs-Git: https://github.com/minetest/minetest.git +Vcs-Browser: https://github.com/minetest/minetest.git +Architecture: amd64 +Build-Depends: + cmake, + gettext, + libbz2-dev, + libcurl4-gnutls-dev, + libfreetype6-dev, + libglu1-mesa-dev, + libirrlicht-dev (>= 1.7.0), + libjpeg-dev, + libjsoncpp-dev, + libleveldb-dev, + libluajit-5.1-dev | liblua5.1-dev, + libogg-dev, + libopenal-dev, + libpng-dev, + libsqlite3-dev, + libvorbis-dev, + libx11-dev, + zlib1g-dev +Description: Multiplayer infinite-world block sandbox (server) + Minetest is a minecraft-inspired game written from scratch and licensed + under the LGPL (version 2.1 or later). It supports both survival and creative + modes along with multiplayer support, dynamic lighting, and an "infinite" map + generator. +Conflicts: minetestc55, minetest, minetest-server, minetest-data |