views:

488

answers:

3

I have two Hudson jobs:

  1. Upload
  2. Launch-instance

I want to make Launch-instance dependent on the other one, so that triggering Launch-instance automatically causes Upload to be run first. Can I achieve this using Hudson's built-in features or with a plugin?

Note that I do not want Upload to always trigger Launch-instance, which is what the "Build after other projects are built" option on Launch-instance would do. What I want is more analogous to how depends attribute works for an Ant target.

A: 

You can use the downstream or upstream dependencies. You should use "Build Triggers" -> Build after other projects are built and/or post-build actions in the configure part of the project.

khmarbaise
You have to add "Build-Trigger"-> Build after in the "Update" project and enter "Launch-instance" there.
khmarbaise
Sorry, you didn't seem to read the whole question... It says I do **not** want *Upload* to always trigger *Launch-instance* (but when *Launch-instance* is run, *Upload* should be run first).
Jonik
+3  A: 

What about building Upload by calling its build URL with wget as the first build step? Then adding the beef build steps of Launch-instance.

Or for a fancier approach, perhaps use the Remote access API.

miki
+1 for leading me to the right path! Simply accessing build URL won't work in our case as anonymous builds are disabled. But I found key advice from the link Alejandro Pérez García posted in the *comments* of that "Remote access API" page. :-) I put details in separate answer: http://stackoverflow.com/questions/2674468/making-hudson-job-depend-on-another-job/2675178#2675178
Jonik
I guess it's fairest to accept this answer. (Just remember to check out *Build Triggers -> Trigger builds remotely* in job configuration when security is enabled; details in my answer.)
Jonik
+1  A: 

Aha, found it! Here I'm building on miki's answer which showed the way but didn't fully solve this for me.

As it says in the Spanish-language article about launching Hudson builds which was linked to from the comments of Hudson's Remote access API page that miki linked to:

En la sección "Build Triggers" [...] marcamos la opción "Trigger builds remotely (e.g., from scripts)". Al marcar esta opción vemos como aparece el cuadro de texto "Authentication Token". Aquí pondremos el nombre del token de autenticación.

alt text

(It seems the benefits of knowing Spanish are starting to materialise... :-)

So, turns out Hudson provides a handy built-in option for triggering builds remotely. In Build Triggers section (of Upload job in my case) you can enable remote builds and set an auth token (see screenshot above). Then you can launch a build by accessing a certain URL containing that token. In my case, the first build step of Launch-instance looks like:

wget http://[hudson-url]/job/Upload/build?token=TEST
sleep 10

This works even if anonymous builds are disabled and simply trying to access the build URL would yield "403 Forbidden".

Jonik