Disclaimer: I am relatively unfamiliar with the flash build processes, so some/all of this may be misinformed nonsense. Please feel free to suggest alternative approaches.
We’re currently developing a flex web app and our build situation is far from ideal. At present we’re (as in individual developers) just building using FlashBuilder and deploying manually. The programmers are currently screaming bloody murder for two reasons, though:
- The lack of CI is like going back to the stone age
- We don’t much care for FlashBuilder
(Note: We’re only using FlashBuilder because it was the easiest way to set up a flex project in conjunction with Away3d and get it building / rendering correctly — it’s a stopgap solution).
As a predominately .NET development shop, we’re used to doing continuous integration as well as continuous deployment. Ideally, we’d like to get something comparable to this for our flash projects without tying ourselves to a particular IDE.
Requirements:
The build process must be:
- .. runnable via the commandline
- .. runnable on both developer and CI build machines (and certainly not requiring an IDE!)
- .. preferably as IDE-independent as possible (pragmatism will kick in though; if this causes a lot of friction we’ll just pick one).
- .. able to run on Windows (we develop using Windows)
We don’t mind a touch of duplication or a few manual steps (e.g. tarting up the build scripts if we add a new project via an IDE, or generating one configuration from another if tools exist), but the less duplication / maintenance required the better.
I’ve read quite a few articles / blog posts and watched some short screencasts, but most of them are very thin on the ground on how the build system sits alongside IDEs. Most articles/screencasts have the same formula: How to create a “Hello World” build using a single file & text editors (no IDE).
I’ve not seen the topic of multiple libraries/projects etc. being broached, either.
After reading around the issue for a while, I’m considering investigating the following options:
Does anyone have any experience of the above solutions (or others I’m unaware of) and, if so, what do you make of them? Any help / pointers appreciated.
I recently started building with Gradle and the GradleFx plugin and I immediately fell in love with its power and ease of use.
Gradle is ANT + Maven + Ivy evolved and is primarily used from the command-line. You can:
And best of all: it’s very easy to learn. I had no knowledge of Maven before I started with Gradle and could get a multi-project build with some customizations working quite quickly.
Edit (comparison to Buildr AS3 and Maven)
I can compare this only to one of the projects you mentioned: Buildr AS3. It seems to start from a philosophy that is similar to Gradle’s. But I’ve tried to use it about half a year ago and couldn’t even get a simple ‘Hello World’ app to work. I e-mailed the developer for help: no response.
Compared to GradleFx: I had a small forum discussion with the developer (on a rather philosophical topic, since I didn’t really need any help because it just worked right away). He answered within minutes.
As for Maven: (for what it’s worth) I’ve only glanced at some configurations and they seem overly complicated when I compare them to a Gradle script.
There is one thing Maven does that you can’t do with GradleFx (yet). It can pull the right Flex SDK from a Maven repo and build against that. With GradleFx you have to have your SDK’s available locally.