[Bioperl-l] Nightly build archives now available

Chris Fields cjfields at uiuc.edu
Fri Mar 7 13:00:52 EST 2008


On Mar 7, 2008, at 11:34 AM, Sendu Bala wrote:

> Chris Fields wrote:
>> 1)  I am running a 'svn co' on anon. svn for the various distros to  
>> a temp directory.
>
> Is it important that you do a fresh co every night? Why not do a co  
> once   and then do a 'svn update' every night? This is the crux of  
> the problems: if you choose to simply update, then you only have to  
> get 'perl Build.PL' to work once.

Unless you update Build.PL (which will happen as the distributions  
grow).  Then you need to rerun 'perl Build.PL'.  It seems safer to run  
that each time with a 'pass-through' flag for automated builds.

>> If I attempt to change into the distribution directory and run  
>> 'perl Build.PL' from the bash script, I immediately run into  
>> permissions issues and several odd things:
>> Checking prerequisites...
>> - ERROR: Bio::Root::Version is not installed
>> (I think you ran Build.PL directly, so will use CPAN to install  
>> prerequisites on demand)
>> CPAN: Storable loaded ok
>> Going to read /root/.cpan/Metadata
>>  Database was generated on Tue, 05 Feb 2008 11:30:54 GMT
>> Warning: You are not allowed to write into directory "/root/.cpan/ 
>> sources/authors".
> [snip]
>
> I'm assuming this is on portal? The CPAN setup for users is a little  
> broken. You need to create /home/yourusername/.cpan/CPAN/MyConfig.pm
>
> $CPAN::Config->{cpan_home} = "/home/yourusername/.cpan/"
>
> Then you can run and configure cpan correctly and install  
> Bundle::CPAN. Some of the zlib stuff failed to install for me, but  
> that doesn't seem to matter.
>
> Of course, I guess it makes sense for root to just install all of  
> Bioperl's prereqs anyway, so that testing can be automated in the  
> future.
>
> Anyway, once you have cpan happy 'perl Build.PL' will run fine.  
> Answer 'n' to everything and then your cron job just has to call './ 
> Build dist'.

I agree about setting up the prereqs.  I could also (as mentioned  
before) set this up as root.  However, if we go this route we need to  
have 'perl Build.PL' included in the process in order to ensure a  
clean build process each time and to prevent the script from breaking  
whenever someone decides to change Build.PL.

>> 2) I suspect, even if I worked around permissions and set up the  
>> job as root or admin and worked out why it can't find  
>> 'Bio::Root::Version' (?!?), this would still be a terrific pain in  
>> the *** to deal with as the Build.PL process is expecting answers  
>> for each and every prompt, and the process differs for each  
>> distribution.
>
> You won't be running Build.PL in the cron job.

See above.  I don't want to set up something automated which can't be  
maintained in the long term.

>> passing flags to 'perl Build.PL' would be a nice way to work around  
>> that.  For that I haven't heard a response, so I assume that  
>> functionality isn't there (or am I assuming incorrectly?).
>
> It isn't AFAIK, but my point is that it doesn't need to be (for this  
> particular use-case at least).

See above.  There are very good reasons to allow this (and the  
functionality has been requested before, particularly from the GMOD  
crowd).  If I can pass in a single flag (for instance, --defaults,  
which just uses the default arg for each prompt) then it would make  
it /much/ easier.

>> So, from where I stand, even if using Build.PL is the /proper/ way  
>> to do it, it doesn't work as expected using an automated process  
>> (i.e. cron).  Make sense?
>
> Only if you can't run 'svn update' instead of 'svn co' each night.

I think a single co with updates is feasible (I can do that with the  
current setup; just run the initial co, copy the directory over to a  
temp copy, then go about my business).

I'll leave the nightly build setup as is for now and work on getting  
Build.PL working (something we need anyway for Devel::Cover and  
Pod::Coverage work).

chris



More information about the Bioperl-l mailing list