From cb8087771b23605a62608a1a672b61b1859ac1e9 Mon Sep 17 00:00:00 2001 From: /dev/urandom Date: Tue, 13 Sep 2016 00:33:00 +0200 Subject: [PATCH] Add Jenkinsfile. --- Jenkinsfile | 90 +++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 90 insertions(+) create mode 100644 Jenkinsfile diff --git a/Jenkinsfile b/Jenkinsfile new file mode 100644 index 00000000..ba9fb30e --- /dev/null +++ b/Jenkinsfile @@ -0,0 +1,90 @@ +#!groovy + +/* +This is our new pipeline script to do all of the building in, of and around IW4x. + +Here's what it is supposed to do: + +- Make sure Modern Warfare 2 is installed (CI should provide the folder like a custom tool) +- Check out code from iw4x-data +- Build the IW4x client library (this code repository) +- Use iw4x.exe from the iw4x-data repository in order to build the zone files in iw4x-data +- Package the IW4x client with the newly built data files + +At this point it is done building everything, however afterwards we want the build server to +also push the newly built files to an update repository, depending on the branch we're on. + +- For "develop", release to the "iw4x-dev" branch on the repository server. +- For "master", release to the "iw4x" branch on the repository server. + +I'm looking into how the logic of pipelining works in detail before deciding on whether to +throw in the IW4x Updater and the IW4x Node binaries in as well or not. +*/ + +/* +Note that this is just a rewrite of the jobs as they are currently set up on the production +Jenkins server. This will allow every developer to tinker around with how the build process +is set up. For those who want to play around with this, here's a bit of information: + +- This is a Groovy script. Essentially Java but with less bullshit (like brackets and verbose writing). +- This gets directly translated into a Jenkins pipeline. +- If you have no idea how to handle scripts, get your hands off this file. +- If you do not use Jenkins, get your hands off this file. +- If you fuck this script up, I will kill you. +*/ + +@Field def configurations = [ + "Debug", + "DebugStatic", + "Release", + "ReleaseStatic" +] + +// Run a function for each platform and project to be built +def perConfiguration(suffix, f) { + def executions = [:] + for (int a = 0; a < configurations.size(); a++) { + def configuration = configurations[a] + executions["$configuration$suffix"] = { + f(goos, goarch, targetProject) + } + } + parallel executions +} + +// This will build the IW4x client. +// We need a Windows Server with Visual Studio 2015, Premake5 and Git on it. +def doBuild(premakeFlags, configuration) { + node("windows") { + checkout scm + + premakeHome = "${pwd()}\\src\\tools" + + withEnv(["PATH+=${premakeHome}"]) { + def outputDir = pwd() + dir("src") { + bat "premake5 vs2015 $premakeFlags" + bat "\"${tool 'MSBuild'}\" src\\build\\iw4x.sln \"/p:OutDir=$outputDir\\\" \"/p:Configuration=$configuration\"" + } + } + + archiveArtifacts artifacts: "*", fingerprint: true + stash name: "iw4x $configuration", includes: "*" + } +} + +// For each available configuration generate a normal build and a unit test build. +stage "Build" +def executions = [:] +for (int i = 0; i < configurations.size(); i++) +{ + configuration = configurations[i] + executions["$configuration"] = { + doBuild premakeFlags: "", configuration: configuration + } + executions["$configuration Unit-Testing"] = { + doBuild premakeFlags: "--force-unit-tests", configuration: configuration + } +} +parallel executions +