On Fri, Dec 16, 2011 at 11:40 PM, Brad Roberts <span dir="ltr"><<a href="mailto:braddr@puremagic.com">braddr@puremagic.com</a>></span> wrote:<br><div class="gmail_quote"><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">
On 12/16/2011 1:29 PM, Brad Anderson wrote:<br>
> On Thu, Dec 15, 2011 at 6:43 PM, Brad Roberts <<a href="mailto:braddr@puremagic.com">braddr@puremagic.com</a> <mailto:<a href="mailto:braddr@puremagic.com">braddr@puremagic.com</a>>> wrote:<br>
><br>
><br>
>     Left to do:<br>
><br>
>      1) deploy changes to the tester hosts (it's on 2 already)<br>
<br>
done<br>
<br>
>      2) finish the ui<br>
<br>
very ugly but minimally functional: <a href="http://d.puremagic.com/test-results/pulls.ghtml" target="_blank">http://d.puremagic.com/test-results/pulls.ghtml</a><br>
<br>
>      3) trigger pull rebuilds when trunk is updated<br>
<br>
partly implemented, but not being done yet<br>
<br>
>      4) add back in support for related pull requests (ie, two pulls that<br>
>         separately fail but together succeed)<br>
><br>
>      5) consider adding updating the pull request on github with tester<br>
>         results.  This one needs to be very carefully done to not spam the<br>
>         report every time a build fails or succeeds.<br>
><br>
>      6) update the auto-tester grease monkey script to integrate the pull<br>
>         tester results with github's ui.<br>
><br>
>     I'll hopefully finish 1 and 2 tonight.  I can do 3 manually until it's<br>
>     automated.  I'm not sure about the ordering of 4-6.  They're nice to haves<br>
>     rather than must haves.<br>
><br>
>     All these extra builds are going to cost a lot of time.  There's about 100<br>
>     open pull requests right now.  The fastest runs are on the order of 10<br>
>     minutes.  That's 6 per hour or roughly 17 hours.  The slowest are closer<br>
>     to an hour.  So, obviously there's some growing pains to deal with.  I'll<br>
>     probably add a way for github committers to prioritize pull requests so<br>
>     they build first.<br>
><br>
>     Luckily this stuff is trivial to throw hardware at.. it's super<br>
>     parallelizeable.  Also the hardware I have for those long runs is super<br>
>     old.  I think the freebsd/32 box is p4 era box.  The win/32 is my asus eee<br>
>     atom based netbook.<br>
><br>
>     If anyone wants to volunteer build hardware, particularly for the<br>
>     non-linux platforms, please contact me via email (let's not clutter up the<br>
>     newsgroup with that chatter).<br>
><br>
>     Requirements:<br>
>      I need to be able to access it remotely.<br>
><br>
>      It needs to be have reliable connectivity (bandwidth is pretty much a<br>
>      non-issue.. it doesn't need much at all).<br>
><br>
>      It needs to be hardware you're willing to have hammered fairly hard at<br>
>      random times.<br>
><br>
>     I'll almost certainly write some code during the holiday to fire up and<br>
>     use ec2 nodes for windows and linux builds.  With the application of just<br>
>     a little money, all of those runs could be done fully parallel.. which<br>
>     would just be sweet to see.  Ok, I admit it.. I love working at amazon on<br>
>     ec2.. and I'm happy to finally have a project that could actually use it.<br>
><br>
>     Later,<br>
>     Brad<br>
><br>
><br>
>> With the application of just a little money<br>
><br>
> Out of curiosity, how much is a little?<br>
<br>
I'll need to experiment.  It's the kind of thing that the more money thrown at the problem the faster the builds could<br>
be churned through.  The limit of that would be one box per platform per pull request.  A silly (and not possible due to<br>
ec2 not supporting some platforms, such as osx) extreme though.  One c1.medium running 24x7 at the current spot price is<br>
about $29/month.  Spot is perfect because this is a totally interruptable / resumable process.  I'll need to do a little<br>
work to make it resume an in-flight test run, but it's not hard at all to do.<br>
<br>
After watching the build's slowly churn through the first round of build requests, it's clear to me that one of the<br>
areas I'll need to invest a good bit more time is in scheduling of pulls.  Right now it's pseudo-random (an artifact of<br>
how the data is stored in a hash table).<br>
<br>
Later,<br>
Brad<br>
</blockquote></div><br><div><br></div><div>That seems very reasonable.  It sounds like this autotester will help immensely with processing the pull request backlog.  More free time for Walter and everyone else who works on the project is a great thing.</div>