<table><tr><td style="">TallFurryMan created this revision.<br />TallFurryMan added a reviewer: mutlaqja.<br />Restricted Application added a subscriber: KDE Edu.<br />Restricted Application added a project: KDE Edu.<br />TallFurryMan requested review of this revision.
</td><a style="text-decoration: none; padding: 4px 8px; margin: 0 8px 8px; float: right; color: #464C5C; font-weight: bold; border-radius: 3px; background-color: #F7F7F9; background-image: linear-gradient(to bottom,#fff,#f1f0f1); display: inline-block; border: 1px solid rgba(71,87,120,.2);" href="https://phabricator.kde.org/D12485">View Revision</a></tr></table><br /><div><strong>REVISION SUMMARY</strong><div><p>Added D-bus error management for several requests. Updated job status when needed in case of error.</p>
<p>Aborted some jobs instead of marking them invalid, in order to give them a chance to reschedule. Other no-go situations mark the jobs invalid directly.</p>
<p>Issued a warning when one of the jobs is using FINISH_LOOP, as this will prevent other jobs from scheduling. Will rework to update priority when there are other uncompleted jobs in the list.</p>
<p>Prevented dawn verification when twilight check is disabled for a job. Besides, this allows daily testing in my basement :) Also fixed twilight enforcement on culmination-based jobs.</p>
<p>Sometimes when pausing/restarting the scheduler, the state machine misses a step regarding mount parking state. Added a safeguard to unpark the mount when trying to slew, instead of waiting indefinitely for the end of an impossible slew.</p>
<p>Updated log after checking altitude calculation to clarify situation.</p>
<p>Stopped guiding when aborting a job and completing a looping job. Aborting a job should reset guiding, as we're not able to continue on the current target. Completing a looping job that is not guiding requires realignment.</p>
<p>Also updated failure count management. Alignment now resets the mount model at the last attempt before failing, and only if the settings option is enabled. When alignment fails, job is aborted, not terminated, it could be passing clouds for instance. Successful alignment properly resets the failure count.</p>
<p>Similarily, guiding now properly resets the failure count if successful.</p>
<p>Similarily, capturing now restarts the capture stage when failing, or guiding stage if it is guiding that failed. When capture fails, job is aborted, not terminated, but it's unknown whether it is possible to recover from that failure. Successful capture properly resets the failure count.</p>
<p>SchedulerJob now manages column resizing. This required the cell to be inserted in the table prior to be configured, but UI is not refreshing yet at this step. Now timestamps should format the table properly every time they are updated.</p>
<p>SchedulerJob refactor, documentation. Moved getters to interface to clarify implementation. Added some cell updates that were missing for some fields.</p>
<p>Add current scheduler job name and stage. This change displays the name and stage of the current job in the scheduler interface, so that the end-user knows what the scheduler is doing.</p>
<p>Rework job states and refactor job reset. Keeping scores now that jobs are scheduled properly. START_ASAP jobs that are scheduled auto-switch to START_AT when given a start time, and reset to the original user setting.</p>
<p>Refactored resetting jobs to original settings inside SchedulerJob, so that all resets behave the same.</p>
<p>When the scheduler is stopped, jobs will abort and not restart. Jobs have to be reset using the evaluate button before they can restart. This is a safeguard to clean up weird states when pausing/resuming the scheduler.</p>
<p>FIXME on leaving the mount to track while the scheduler is sleeping could result in problems if the end-user stops the scheduler or the system crashes. At the very least the mount should not be requested to track.<br />
FIXME on negative scores that are weird for the end-user. Probably as soon as a negative score is obtained, no further score evaluation should be attempted, just in case a subsequent one adds enough to return positive.<br />
FIXME on altitude cutoff that has an issue with rising targets, which will get aborted. Mitigated by a previous change which reschedules aborted jobs, but incorrect nonetheless.<br />
FIXME on manual execution of startup/shutdown scripts which probably requires INDI to be connected to succeed. Warning or notification should ensue properly.</p></div></div><br /><div><strong>TEST PLAN</strong><div><p>Same as previous differential. There are still some edge cases, plus one issue with the remote solver when Ekos shutdowns INDI while the solver is still working. Apparently the solver is stopped after INDI, leading to a crash.</p></div></div><br /><div><strong>REPOSITORY</strong><div><div>R321 KStars</div></div></div><br /><div><strong>REVISION DETAIL</strong><div><a href="https://phabricator.kde.org/D12485">https://phabricator.kde.org/D12485</a></div></div><br /><div><strong>AFFECTED FILES</strong><div><div>kstars/ekos/scheduler/scheduler.cpp<br />
kstars/ekos/scheduler/scheduler.h<br />
kstars/ekos/scheduler/scheduler.ui<br />
kstars/ekos/scheduler/schedulerjob.cpp<br />
kstars/ekos/scheduler/schedulerjob.h</div></div></div><br /><div><strong>To: </strong>TallFurryMan, mutlaqja<br /><strong>Cc: </strong>KDE Edu, narvaez, apol<br /></div>