61 lines
4.3 KiB
Markdown
61 lines
4.3 KiB
Markdown
|
\page automating-with-jenkins Automating Your Bot with Jenkins
|
||
|
|
||
|
\note This page does NOT go into explaining how to install Jenkins, nor how to initially setup Jenkins. This is a tutorial for the CMake version with Linux (more specifically Ubuntu 22.04 LTS). If you don't know how to use CMake or you don't use CMake for your bot (and would like to) then please visit \ref buildcmake. If you wish to automate this tutorial from GitHub pushes then you can simply download the GitHub plugin for Jenkins, set that up and this tutorial will still work as this tutorial will only build what it can see!
|
||
|
|
||
|
## Getting started
|
||
|
|
||
|
First of all, you'll want to create your project. For this, we'll use a "Freestyle project" as we're just going to be calling some bash commands to tell CMake to build. We'll be calling this "DiscordBot" but you can name it whatever you want. I would advise against non-ASCII characters.
|
||
|
|
||
|
\image html jenkinsproject.png
|
||
|
|
||
|
From here, just hit `Ok` and now you've created your Jenkins project, Well done! From here you can add a description, change the security policy (if your Jenkins is public), really whatever your heart desires.
|
||
|
|
||
|
## Automating the Building Process
|
||
|
|
||
|
Scrolling down, you'll find `Build Steps`. You can also click `Build Steps` on the left. Here, you'll want to hit `Add build step` and hit `Execute shell`.
|
||
|
|
||
|
\image html buildstepjenkins.png
|
||
|
|
||
|
Inside of this, you'll want to enter this script below.
|
||
|
|
||
|
~~~~~~~~~~bash
|
||
|
# Check if the "build" directory doesn't exist (if you've not setup CMake or deleted its content).
|
||
|
if [ ! -d "build/" ]
|
||
|
then # As it doesn't, create the build directory.
|
||
|
cmake -B build
|
||
|
fi
|
||
|
|
||
|
# Commence build.
|
||
|
cmake --build build/
|
||
|
~~~~~~~~~~
|
||
|
|
||
|
\note This script does not make use of multiple threads. If you know how to do this and you would like to use threads, then feel free to. However, I would be careful not to use all your threads as Jenkins may dislike this.
|
||
|
|
||
|
This script will build your project for you and also set up CMake if you've deleted the build directory, allowing you to easily refresh CMake. You can change this to a build parameter if you want, meaning you can hit `Build with Parameters` and state what you'd like to do. This would require the script to be changed so only do that if you know what you're doing!
|
||
|
|
||
|
\image html shelljenkins.png
|
||
|
|
||
|
Now you can hit save!
|
||
|
|
||
|
## Seeing the Builds Work
|
||
|
|
||
|
Making sure you have your project files in the workspace directory (you can see this by pressing `Workspace` on the left, the files will automatically be pulled from GitHub if you're using the GitHub plugin), you should be able to hit `Build Now` and see a new build in the History appear. If everything went well, you should have a green tick!
|
||
|
|
||
|
\note Building can take a while if you haven't set up your build directory before (doing `cmake ..`), especially on less-powerful machines, so don't be alarmed!
|
||
|
|
||
|
\image html buildhistoryjenkins.png
|
||
|
|
||
|
## Running the Build
|
||
|
|
||
|
Running the builds is the same as any other time, but we'll still cover it! However, we won't cover running it in background and whatnot, that part is completely down to you.
|
||
|
|
||
|
First, you need to get into the `jenkins` user. If you're like me and don't have the Jenkins user password, you can login with your normal login (that has sudo perms) and do `sudo su - jenkins`. Once logged in, you'll be in `/var/lib/jenkins/`. From here, you'll want to do `cd workspace/DiscordBot/` (make sure to replace "DiscordBot" with your bot's name. Remember, you can tab-complete this) and then `cd build`. Now, you can simply do `./DiscordBot`!
|
||
|
|
||
|
\warning If you are going to be running the bot at the same time as builds, I would heavily advise that you copy the bot (if it's not statically linked, then copy the entire build directory) to a different location. This is so you can pick and choose when the bot gets updated (and even means you can run experimental builds as opposed to stable builds) but also means you avoid any risk of the bot crashing during build (as Jenkins will be overwriting your executable and libraries).
|
||
|
|
||
|
Once you're happy with everything, then you're good to go! Enjoy your automated builds!
|
||
|
|
||
|
## Possible Permission Issues
|
||
|
|
||
|
Sometimes, doing `./DiscordBot` can end up with an error, saying you don't have permission to execute. If that's the case, simply do `chmod +x DiscordBot` and now you can re-run `./DiscordBot`.
|