I have already set up a version control system (Subversion) which is going to be used by developers to commit and update their code (let's say that its address is https://server/svn/project
). Only authenticated users will be able to have access to project's SVN.
On the other hand, I have installed Hudson as the project's continuous integration server (address of the project is server:8080/job/project
).
I'd like to achieve the following:
- Hudson builds to be triggered automatically when there is an SVN commit.
- Mails are sent to the respective developers (the ones that committed code) when their committed code doesn't build, meaning that when user A commits code that doesn't build, only user A gets an email containing the notification.
I have set up matrix-based authorization for Hudson users, because I don't want to be open to anyone.
I have seen some suggestions for post-commit
hooks, but none of them worked until now.
Can somebody suggest what to do regarding both issues? Specific steps would be appreciated.
According to "Building a software project # Builds by changes in Subversion/CVS", Hudson needs to poll your SVN repo in order to detect changes and trigger the build.
However, that can be initiated on each commit from the SVN, like in this thread.
The official script is at the Subversion Plugin page.
But it is specified:
For this to work, your Hudson has to allow anonymous read access to the system.
If access control to your Hudson is more restrictive, you may need to specify the username and password, depending on how your authentication is configured.
Here are the required steps:
I would recommend e-mailing all developers so that they are notified that the build is unstable, not just the culprit. Not only does this provide more visibility, but it will motivate the culprit to fix the problem immediately or otherwise accept a scolding from their fellow developers. Trust me, this is effective.
This is how I got Jenkins 2.157 to start a build after a commit to an SVN repo.
1. Allow read access in Jenkins
Using Jenkins' web interface, go to
Manage Jenkins
->Configure Global Security
and checkAllow anonymous read access
:If you skip this step, you'll get the following response when trying to trigger a build using an HTTP request (described in step three):
2. Configure your build trigger
Still in Jenkins' web interface, go to your build job and define that you want to trigger a build using a script (this is going to be the SVN commit hook in the next step):
3. Create the
post-commit
hookFinally, go to your repository's
hooks
directory and add a shell script namedpost-commit
(the name is important, otherwise SVN won't execute it after a commit):Make the script executable:
chmod +x post-commit
.Here's an extended version of
post-commit
that logs data about the commit, such as the commit's author.To learn more about commit hooks, head to the docs.
To trigger a build when there is a commit in SVN you have to (1) set your hudson job to build remotely and (2) make a SVN hook...
the first part is fairly straightforward... to make the hook go to /var/lib/svn//hooks and rename post-commit.tmpl to post-commit there you can do something like
Look at this article http://blogsyntagma.blogspot.com.ar/2012/04/hook-de-subversion-para-ejecutar-un-job.html (it's in spanish)