layout | title | subtitle | minutes |
---|---|---|---|
page |
First Steps in LHCb |
Using git to develop LHCb software |
60 |
- Learn how to clone specific LHCb packages to a local development directory
- Learn how to make changes and upload them to be reviewed by others
Before starting, you should have a basic understanding of how to use
git
, similar to what has been taught during the starterkit.
In this lesson, we'll show you a complete workflow for developing the LHCb software
using the git
version control system.
At LHCb, we use Gitlab to manage our git repositories.
Among other features, Gitlab allows you to browse the source code for each project,
and to review new changes (called merge requests) in a convenient web interface.
You can find the CERN Gitlab instance at https://gitlab.cern.ch.
In principle, there are multiple ways of interacting with the LHCb software repositories:
- A vanilla git workflow using only the standard git commands.
This requires you to
clone
and compile an entire LHCb project at a time. - An LHCb-specific workflow using a set of
lb-*
subcommands. This allows you to check out individual packages inside a project, and streamlines the modification of a few packages at a time. This is closer to the previously usedgetpack
command.
Here, we want to focus on the second workflow.
Before jumping in by creating a project in Gitlab, you should make sure that your local git configuration and your settings on Gitlab are sufficiently set up:
Your name and email address should be set up in your local git
configuration.
To ensure that this is the case, run
$ git config --global user.name "Your Name"
$ git config --global user.email "Your Name <[email protected]>"
and put in your information.
Next, connect to https://gitlab.cern.ch and log in with your CERN credentials.
Visit https://gitlab.cern.ch/profile/keys and add an SSH key.
Run this LHCb-specific configuration command:
git config --global lb-use.protocol ssh
This makes sure the LHCb commands use the ssh protocol instead of https.
In the Gitlab web interface, create a new project by clicking on the "New project" button. Give your project the name "LHCbSK".
We will now set up a local LHCb development area that is connected to the git repository you just created. In order to create a new dev environment, run
$ lb-dev --list LHCb
to see which versions of the LHCb project are available. Pick the newest one and run
$ lb-dev --name LHCbSK LHCb/<version>
where you need to insert the version you picked earlier.
This will automatically run git init
to create a new git repository with some initial files (Makefile
, CMakeLists.txt
, etc.).
In order to connect your repository with the remote one, run
cd LHCbSK
git remote add origin ssh://[email protected]:7999/<username>/LHCbSK.git
where you need to substitute your username. Run
git push -u origin master
once to define master
as the remote branch that we should push to by default.
For the purpose of this tutorial, we've set up an SKTest
project containing
the package TheTestPackage
.
In order to define SKTest
as your currently active project, run
git lb-use SKTest
This will also fetch the SKTest
git repository from Gitlab.
You can then run
git lb-checkout SKTest/master TheTestPackage
to check out the files inside the SKTest
project that belong to the
TheTestPackage
package.
This performs git checkout
under the hood and commits the files into the
local (synthetic) branch.
You can now run
make
to build the project, make some changes, run make
again, etc.
You can also use
make test
to run the tests. Once you're happy with the changes, run
git add <your-changed-files>
where you have to specify all files with changes that you want to store, and
git commit
to store them in a new commit. This will open up a text editor that will allow you to type in a commit message.
As new commits are only stored in your local repository, there's no cost to committing often. You should try to make a new commit every time you've made modifications that can be considered a single unit of changes.
Once you want to upload your commits for review, run
git lb-push SKTest <username>-new-feature
to create a new <username>-new-feature
branch on the main Gitlab repository
and upload your commits to it.
This will calculate the changes between your local dev repository and the
remote project repository, and create corresponding commits for the remote
project.
You can now create a merge request by going to
https://gitlab.cern.ch/LHCb-SVN-mirrors/SKTest/merge_requests/new,
selecting the <username>-new-feature
branch as the source and master
as the target.
Add a title for your merge request and explain what you've done in the main text.
- Working with a partner, try to create a merge conflict by making changes to the same file. If you don't have someone else to work with, you can simulate this by creating a second development area.
- Now, try to resolve the merge conflict. This is a bit complicated because of the way the local repository is set up. Take a look at https://twiki.cern.ch/twiki/bin/view/LHCb/Git4LHCb#Replacement_for_svn_update_in_lo for pointers.