The Perl Toolchain Summit needs more sponsors. If your company depends on Perl, please support this very important event.
##############################################################################
#  Copyright (c) 2004, The Regents of the University of California.
#  Produced at the Lawrence Livermore National Laboratory.
#  Written by Tim Harsch <harsch1@llnl.gov>
#  UCRL-CODE-155918
#  All rights reserved.
#
#  This file is part of Schedule::DRMAAc. For details, see CPAN
#  Please also read LICENSE.txt which is found in this source distribution.
#
#  This program is free software; you can redistribute it and/or modify it
#  under the terms of the GNU General Public License (as published by the
#  Free Software Foundation) version 2, dated June 1991.
#  This program is distributed in the hope that it will be useful, but
#  WITHOUT ANY WARRANTY; without even the IMPLIED WARRANTY
#  OF MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
#  See the terms and conditions of the GNU General Public License for more
#  details.
#  You should have received a copy of the GNU General Public License
#  along with this program; if not, write to the Free Software Foundation,
#  Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
#
##############################################################################
#  $Id: 07_complex_job.t,v 1.2 2004/04/30 17:10:04 harsch Exp $
##############################################################################

use Schedule::DRMAAc qw/ :all /;

use strict;

sub mydiag( $ $ ; $ );


my $vec_args = [ 1 ];
my $remote_cmd = "/bin/sleep";

use constant JOB_CHUNK => 1;
use constant TESTS => 15 + 8 * &JOB_CHUNK;
use Test::More tests => TESTS;


my( $error, $diagnosis );
my @vals = drmaa_strerror( 0 );
ok( @vals == 1, "drmaa_strerror returned " . scalar(@vals) . " of 1 args" );

@vals = ( $error, $diagnosis ) = drmaa_init( undef );
ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_init error?" )
	or mydiag( $error, $diagnosis );

my $jt;
@vals = ( $error, $jt, $diagnosis ) = drmaa_allocate_job_template();
ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_allocate_job_template error?" )
	or mydiag( $error, $diagnosis );

@vals = ( $error, $diagnosis ) = drmaa_set_attribute( $jt, $DRMAA_REMOTE_COMMAND, $remote_cmd );
ok( @vals == 2, "drmaa_set_attribute returned " . scalar(@vals) . " of 2 args" );
ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_set_attribute error?" )
	or mydiag( $error, $diagnosis );

@vals = ( $error, $diagnosis ) = drmaa_set_vector_attribute( $jt, $DRMAA_V_ARGV, $vec_args );
ok( @vals == 2, "drmaa_set_vector_attribute returned " . scalar(@vals) . " of 2 args" );
ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_set_vector_attribute error?" )
	or mydiag( $error, $diagnosis );

( $error, $diagnosis ) = drmaa_set_attribute( $jt, $DRMAA_JOIN_FILES, "y" );
ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_set_attribute error?" )
	or mydiag( $error, $diagnosis );

( $error, $diagnosis ) = drmaa_set_attribute( $jt, $DRMAA_OUTPUT_PATH,
								":" . $DRMAA_PLACEHOLDER_HD . "/DRMAA_complex_job." . $DRMAA_PLACEHOLDER_INCR . ".out" );
ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_set_attribute error?" )
	or mydiag( $error, $diagnosis );

my $jobids;
@vals = ( $error, $jobids, $diagnosis ) = drmaa_run_bulk_jobs( $jt, 1, &JOB_CHUNK, 1 );
ok( @vals == 3, "drmaa_run_bulk_jobs returned " . scalar(@vals) . " of 3 args" );
ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_run_bulk_jobs error?" )
	or mydiag( $error, $diagnosis );

# collect job ids, and place a user hold on all jobs
my @all_jobids;
for (my $j=0; $j<JOB_CHUNK; $j++) {
	my( $error, $jobid ) = @vals = drmaa_get_next_job_id( $jobids );
	print "job #$jobid submitted\n";
	ok( @vals == 2, "drmaa_get_next_job_id returned " . scalar(@vals) . " of 2 args" );
	ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_get_next_job_id error?" )
		or mydiag( $error, $diagnosis );
	@vals = ( $error, $diagnosis ) = drmaa_control( $jobid, $DRMAA_CONTROL_HOLD );
	ok( @vals == 2, "drmaa_control returned " . scalar(@vals) . " of 2 args" );
	ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_control error?" )
		or mydiag( $error, $diagnosis );

	push @all_jobids, $jobid;
} # end for

@vals = drmaa_release_job_ids( $jobids );
ok( @vals == 0, "drmaa_control returned " . scalar(@vals) . " of 0 args" );

# query for user hold, and release hold so synchronize will finish
foreach my $jobid ( @all_jobids ) {
	my( $error, $remoteps, $diagnosis ) = @vals = drmaa_job_ps( $jobid );
	ok( @vals == 3, "drmaa_job_ps returned " . scalar(@vals) . " of 3 args" );
	ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_job_ps error?" )
		or mydiag( $error, $diagnosis );
	ok( $remoteps == $DRMAA_PS_USER_ON_HOLD, "job $jobid on hold?" );
	( $error, $diagnosis ) = drmaa_control( $jobid, $DRMAA_CONTROL_RELEASE );
	ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_control error?" )
		or mydiag( $error, $diagnosis );
} # end foreach

@vals = ( $error, $diagnosis ) = drmaa_synchronize( \@all_jobids, $DRMAA_TIMEOUT_WAIT_FOREVER, 0 );
ok( @vals == 2, "drmaa_synchronize returned " . scalar(@vals) . " of 2 args" );

@vals = ( $error, $diagnosis ) = drmaa_delete_job_template( $jt );
ok( @vals == 2, "drmaa_delete_job_template returned " . scalar(@vals) . " of 2 args" );

( $error, $diagnosis ) = drmaa_exit();
ok( $error == $DRMAA_ERRNO_SUCCESS, "drmaa_exit error?" );

sub mydiag( $ $ ; $ ) {
	my $msg = "error: " . drmaa_strerror( $_[0] ) . "\n" . "diagnosis: " . $_[1];
	$msg .= $_[2] if defined $_[2];
	diag( $msg );
} # end sub

1; # Ancient Druid Custom