- user web: don't show "database error" if result refers

to deleted app version

svn path=/trunk/boinc/; revision=20251
This commit is contained in:
David Anderson 2010-01-23 00:36:12 +00:00
parent 974ea0469c
commit 6b3ea3d339
4 changed files with 35 additions and 16 deletions

View File

@ -637,3 +637,14 @@ David 22 Jan 2010
sched/ sched/
db_purge.cpp db_purge.cpp
transitioner.cpp transitioner.cpp
David 22 Jan 2010
- user web: don't show "database error" if result refers
to deleted app version
client/
app_start.cpp
html/inc/
result.inc
sched/
transitioner.cpp

View File

@ -167,8 +167,10 @@ int ACTIVE_TASK::get_shmem_seg_name() {
// ftok() only works if there's a file at the given location // ftok() only works if there's a file at the given location
// //
FILE* f = boinc_fopen(init_data_path, "w"); if (!boinc_file_exists(init_data_path)) {
if (f) fclose(f); FILE* f = boinc_fopen(init_data_path, "w");
if (f) fclose(f);
}
shmem_seg_name = ftok(init_data_path, 1); shmem_seg_name = ftok(init_data_path, 1);
if (shmem_seg_name == -1) return ERR_SHMEM_NAME; if (shmem_seg_name == -1) return ERR_SHMEM_NAME;
#endif #endif

View File

@ -28,6 +28,9 @@ function app_version_string($id) {
$app = $apps[$av->appid]; $app = $apps[$av->appid];
} else { } else {
$av = BoincAppVersion::lookup("id=$id"); $av = BoincAppVersion::lookup("id=$id");
if (!$av) {
return "Not in DB";
}
$app_versions[$id] = $av; $app_versions[$id] = $av;
$app = BoincApp::lookup_id($av->appid); $app = BoincApp::lookup_id($av->appid);
$apps[$av->appid] = $app; $apps[$av->appid] = $app;

View File

@ -434,8 +434,8 @@ int handle_wu(
// //
all_over_and_validated = true; all_over_and_validated = true;
bool all_over_and_ready_to_assimilate = true; bool all_over_and_ready_to_assimilate = true;
// used for the defer assmilation // used for the defer assimilation
int most_recently_returned = 0; double most_recently_returned = 0;
for (i=0; i<items.size(); i++) { for (i=0; i<items.size(); i++) {
TRANSITIONER_ITEM& res_item = items[i]; TRANSITIONER_ITEM& res_item = items[i];
if (!res_item.res_id) continue; if (!res_item.res_id) continue;
@ -449,7 +449,7 @@ int handle_wu(
all_over_and_ready_to_assimilate = false; all_over_and_ready_to_assimilate = false;
} }
} else if (res_item.res_outcome == RESULT_OUTCOME_NO_REPLY) { } else if (res_item.res_outcome == RESULT_OUTCOME_NO_REPLY) {
if ((res_item.res_report_deadline + config.grace_period_hours*60*60) > now) { if ((res_item.res_report_deadline + config.grace_period_hours*3600) > now) {
all_over_and_validated = false; all_over_and_validated = false;
} }
} }
@ -459,7 +459,7 @@ int handle_wu(
} }
} }
// If we are defering assimilation until all results are over // If we are deferring assimilation until all results are over
// and validated then when that happens we need to make sure // and validated then when that happens we need to make sure
// that it gets advanced to assimilate ready // that it gets advanced to assimilate ready
// the items.size is a kludge // the items.size is a kludge
@ -478,7 +478,7 @@ int handle_wu(
// if WU is assimilated, trigger file deletion // if WU is assimilated, trigger file deletion
// //
if (wu_item.assimilate_state == ASSIMILATE_DONE if (wu_item.assimilate_state == ASSIMILATE_DONE
&& ((most_recently_returned + config.delete_delay_hours*60*60) < now) && ((most_recently_returned + config.delete_delay_hours*3600) < now)
) { ) {
// can delete input files if all results OVER // can delete input files if all results OVER
// //
@ -531,10 +531,10 @@ int handle_wu(
} }
} else if (wu_item.assimilate_state == ASSIMILATE_DONE) { } else if (wu_item.assimilate_state == ASSIMILATE_DONE) {
log_messages.printf(MSG_DEBUG, log_messages.printf(MSG_DEBUG,
"[WU#%d %s] not checking for items to be ready for delete because the deferred delete time has not expired. That will occur in %d seconds\n", "[WU#%d %s] not checking for results ready for delete because deferred delete time has not expired. That will occur in %d seconds\n",
wu_item.id, wu_item.id,
wu_item.name, wu_item.name,
most_recently_returned + config.delete_delay_hours*60*60-(int)now most_recently_returned + config.delete_delay_hours*3600-now
); );
} }
@ -573,8 +573,8 @@ int handle_wu(
if (res_item.res_outcome == RESULT_OUTCOME_NO_REPLY) { if (res_item.res_outcome == RESULT_OUTCOME_NO_REPLY) {
// Transition again after the grace period has expired // Transition again after the grace period has expired
// //
if ((res_item.res_report_deadline + config.grace_period_hours*60*60) > now) { x = res_item.res_report_deadline + config.grace_period_hours*3600;
x = res_item.res_report_deadline + config.grace_period_hours*60*60; if (x > now) {
if (x > max_grace_or_delay_time) { if (x > max_grace_or_delay_time) {
max_grace_or_delay_time = x; max_grace_or_delay_time = x;
} }
@ -583,10 +583,10 @@ int handle_wu(
|| res_item.res_outcome == RESULT_OUTCOME_CLIENT_ERROR || res_item.res_outcome == RESULT_OUTCOME_CLIENT_ERROR
|| res_item.res_outcome == RESULT_OUTCOME_VALIDATE_ERROR || res_item.res_outcome == RESULT_OUTCOME_VALIDATE_ERROR
) { ) {
// Transition again after deferred delete period has experied // Transition again after deferred delete period has expired
// //
if ((res_item.res_received_time + config.delete_delay_hours*60*60) > now) { x = res_item.res_received_time + config.delete_delay_hours*3600;
x = res_item.res_received_time + config.delete_delay_hours*60*60; if (x > now) {
if (x > max_grace_or_delay_time && res_item.res_received_time > 0) { if (x > max_grace_or_delay_time && res_item.res_received_time > 0) {
max_grace_or_delay_time = x; max_grace_or_delay_time = x;
} }
@ -598,10 +598,13 @@ int handle_wu(
// If either of the grace period or delete delay is less than // If either of the grace period or delete delay is less than
// the next transition time then use that value // the next transition time then use that value
// //
if (max_grace_or_delay_time < wu_item.transition_time && max_grace_or_delay_time > now && ninprogress == 0) { if (max_grace_or_delay_time < wu_item.transition_time
&& max_grace_or_delay_time > now
&& ninprogress == 0
) {
wu_item.transition_time = max_grace_or_delay_time; wu_item.transition_time = max_grace_or_delay_time;
log_messages.printf(MSG_NORMAL, log_messages.printf(MSG_NORMAL,
"[WU#%d %s] Delaying transition due to grace period or delete day. New transition time = %d sec\n", "[WU#%d %s] Delaying transition due to grace period or delete delay. New transition time: %d\n",
wu_item.id, wu_item.name, wu_item.transition_time wu_item.id, wu_item.name, wu_item.transition_time
); );
} }