2010-11-10 22:54:56 +00:00
|
|
|
#! /usr/bin/env php
|
|
|
|
|
|
|
|
<?php
|
2024-11-13 01:49:52 +00:00
|
|
|
// query a job or batch for an app that uses sample assimilator
|
2010-11-10 22:54:56 +00:00
|
|
|
//
|
2024-11-13 01:49:52 +00:00
|
|
|
// usage: bin/query_job jobname|batchid
|
2010-11-10 22:54:56 +00:00
|
|
|
|
|
|
|
chdir("html/ops");
|
|
|
|
require_once("../inc/boinc_db.inc");
|
2024-11-13 01:49:52 +00:00
|
|
|
require_once("../inc/submit_db.inc");
|
2023-11-19 21:31:52 +00:00
|
|
|
require_once("../inc/common_defs.inc");
|
|
|
|
require_once("../inc/result.inc");
|
2010-11-10 22:54:56 +00:00
|
|
|
chdir("../..");
|
|
|
|
|
2024-11-13 01:49:52 +00:00
|
|
|
function show_wu($wu, $dir) {
|
2010-11-10 22:54:56 +00:00
|
|
|
if ($wu->error_mask) {
|
2023-12-22 21:30:41 +00:00
|
|
|
echo sprintf("Job failed: %s\n",
|
2023-11-19 21:31:52 +00:00
|
|
|
wu_error_mask_str($wu->error_mask)
|
|
|
|
);
|
|
|
|
return;
|
2010-11-10 22:54:56 +00:00
|
|
|
}
|
2023-11-19 21:31:52 +00:00
|
|
|
switch ($wu->assimilate_state) {
|
|
|
|
case ASSIMILATE_INIT:
|
|
|
|
echo "Job is in progress.\n";
|
|
|
|
break;
|
|
|
|
case ASSIMILATE_READY:
|
2023-12-22 21:30:41 +00:00
|
|
|
echo "Job is waiting for assimilation.\n";
|
2023-11-19 21:31:52 +00:00
|
|
|
break;
|
|
|
|
case ASSIMILATE_DONE:
|
2010-11-10 22:54:56 +00:00
|
|
|
$result = BoincResult::lookup_id($wu->canonical_resultid);
|
|
|
|
$host = BoincHost::lookup_id($result->hostid);
|
|
|
|
$user = BoincUser::lookup_id($result->userid);
|
|
|
|
echo "Job completed\n"
|
|
|
|
." Host $host->id ($host->os_name, $host->p_vendor)\n"
|
|
|
|
." User $user->id ($user->name)\n"
|
|
|
|
;
|
2024-11-24 07:35:40 +00:00
|
|
|
$xmlin = simplexml_load_string(
|
|
|
|
sprintf("<foo>%s</foo>", $result->xml_doc_in)
|
|
|
|
);
|
2023-12-22 21:30:41 +00:00
|
|
|
$xmlout = simplexml_load_string(
|
|
|
|
sprintf("<foo>%s</foo>", $result->xml_doc_out)
|
|
|
|
);
|
|
|
|
$ofs = $xmlout->file_info;
|
2024-11-24 07:35:40 +00:00
|
|
|
$ifs = $xmlin->result->file_ref;
|
2023-12-22 21:30:41 +00:00
|
|
|
$nofs = $ofs->count();
|
|
|
|
for ($i=0; $i<$nofs; $i++) {
|
2024-11-24 07:35:40 +00:00
|
|
|
$path = sprintf("$dir/%s__file_%s", $wu->name, $ifs[$i]->open_name);
|
2023-12-22 21:30:41 +00:00
|
|
|
if (!is_file($path)) {
|
2024-11-13 01:49:52 +00:00
|
|
|
die("output file $i is missing: $path\n");
|
2023-12-22 21:30:41 +00:00
|
|
|
}
|
|
|
|
echo "Output file $i ($path):\n";
|
2024-11-13 01:49:52 +00:00
|
|
|
$x = file_get_contents($path);
|
|
|
|
if (strlen($x) > 256) {
|
|
|
|
$x = substr($x, 0, 256);
|
|
|
|
$x .= '...';
|
|
|
|
}
|
|
|
|
echo "$x\n";
|
2010-11-10 22:54:56 +00:00
|
|
|
}
|
|
|
|
break;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
2023-11-19 21:31:52 +00:00
|
|
|
if ($argc != 2) {
|
2024-11-13 01:49:52 +00:00
|
|
|
die("usage: demo_query jobname|batchid\n");
|
|
|
|
}
|
|
|
|
$x = $argv[1];
|
|
|
|
if (is_numeric($x)) {
|
|
|
|
$id = (int)$x;
|
|
|
|
$batch = BoincBatch::lookup_id($id);
|
|
|
|
if (!$batch) {
|
|
|
|
die("no such batch\n");
|
|
|
|
}
|
|
|
|
$wus = BoincWorkunit::enum("batch=$id");
|
|
|
|
foreach ($wus as $wu) {
|
|
|
|
echo "-------------------\nWorkunit $wu->id:\n";
|
|
|
|
show_wu($wu, "results/$id");
|
|
|
|
}
|
|
|
|
} else {
|
|
|
|
$wu = BoincWorkunit::lookup("name='$x'");
|
|
|
|
if (!$wu) {
|
|
|
|
die("no such job: $wu_name\n");
|
|
|
|
}
|
|
|
|
show_wu($wu, "results/$wu->batch");
|
2023-11-19 21:31:52 +00:00
|
|
|
}
|
2010-11-10 22:54:56 +00:00
|
|
|
?>
|