views:

652

answers:

2

Hi,

I am triggering an ant script (via cruise control), and would like to be able to dump the std out and std err for a particular ant target to a plain text file.

Yes, I am aware that cruise control already does maintain an XML log file containing this information (among many other things), but for portability reasons, I need this to happen from the ant script itself.

Is this possible, and if so, how to do it?

Many thanks!

+1  A: 

recorder task may be able to do what you want:

<record name="log.txt" action="start"/>
...
<record name="log.txt" action="stop"/>

Beyond that, certain tasks (exec, java, etc) offer this functionality by themselves (usually by means of output and error arguments)

ChssPly76
Both of you are correct, but I'm giving you the tick cos you were first.
bguiz
+2  A: 

Try this:

<java classname="some.package.Class"
    fork="yes"
    output="stdouterr.txt">
    ...
</java>

stdouterr.txt will contain both stdout and stderr

<java classname="some.package.Class"
    fork="yes"
    output="stdout.txt"
    error="stderr.txt">
    ...
</java>

stdout.txt and stderr.txt will contain stdout and stderr respectively

From my experience, the record task tends to fail when the ant script is run on cruise control, due to file access permissions (if someone can tell me how to fix that I'll be a happy man).

HTH

bojangle
Thanks, this works!
bguiz
You just need to make sure that the user CC runs as has write permissions to the file - it most certainly does work. The advantage "record" has is that it will capture output of **any** task, not just the ones that support that internally.
ChssPly76