Skip to content

Commit

Permalink
Bugfix/inf 248 not send ags with outcome processing set to none (#2435)
Browse files Browse the repository at this point in the history
* bugfix: move event to proper delivery finish

* bugfix: code review fixes

* fix: code check
  • Loading branch information
Karol-Stelmaczonek authored Jan 8, 2024
1 parent 362b82c commit d87be4b
Show file tree
Hide file tree
Showing 5 changed files with 40 additions and 85 deletions.
5 changes: 2 additions & 3 deletions helpers/class.TestSession.php
Original file line number Diff line number Diff line change
Expand Up @@ -819,12 +819,11 @@ private function triggerResultTestVariablesTransmissionEvent(
$this->getSessionId(),
$variables,
$this->getSessionId(),
$testUri,
$this->isManualScored()
$testUri
));
}

private function isManualScored(): bool
public function isManualScored(): bool
{
/** @var AssessmentItemRef $itemRef */
foreach ($this->getRoute()->getAssessmentItemRefs() as $itemRef) {
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -23,19 +23,20 @@
namespace oat\taoQtiTest\models\event;

use oat\oatbox\event\Event;
use oat\taoDelivery\model\execution\DeliveryExecution;

class TestVariablesRecorded implements Event
class DeliveryExecutionFinish implements Event
{
private string $deliveryExecutionId;
private DeliveryExecution $deliveryExecution;
private array $variables;
private bool $isManualScored;

public function __construct(
string $deliveryExecutionId,
DeliveryExecution $deliveryExecution,
array $variables,
bool $isManualScored
) {
$this->deliveryExecutionId = $deliveryExecutionId;
$this->deliveryExecution = $deliveryExecution;
$this->variables = $variables;
$this->isManualScored = $isManualScored;
}
Expand All @@ -45,9 +46,9 @@ public function getName(): string
return self::class;
}

public function getDeliveryExecutionId(): string
public function getDeliveryExecution(): DeliveryExecution
{
return $this->deliveryExecutionId;
return $this->deliveryExecution;
}

public function getVariables(): array
Expand Down
11 changes: 1 addition & 10 deletions models/classes/event/ResultTestVariablesTransmissionEvent.php
Original file line number Diff line number Diff line change
Expand Up @@ -34,21 +34,17 @@ class ResultTestVariablesTransmissionEvent implements Event
private $transmissionId;
/** @var string */
private $testUri;
/** @var bool */
private bool $isManualScored;

public function __construct(
string $deliveryExecutionId,
array $variables,
string $transmissionId,
string $testUri = '',
bool $isManualScored = null,
string $testUri = ''
) {
$this->deliveryExecutionId = $deliveryExecutionId;
$this->variables = $variables;
$this->transmissionId = $transmissionId;
$this->testUri = $testUri;
$this->isManualScored = $isManualScored;
}

public function getName(): string
Expand All @@ -75,9 +71,4 @@ public function getTestUri(): string
{
return $this->testUri;
}

public function isManualScored(): bool
{
return $this->isManualScored;
}
}
Original file line number Diff line number Diff line change
Expand Up @@ -22,19 +22,13 @@

namespace oat\taoQtiTest\models\classes\eventHandler\ResultTransmissionEventHandler;

use common_exception_Error;
use oat\oatbox\event\EventManager;
use oat\oatbox\service\ServiceManager;
use oat\oatbox\service\ServiceNotFoundException;
use oat\tao\model\service\InjectionAwareService;
use oat\taoDelivery\model\execution\DeliveryServerService;
use oat\taoQtiTest\models\classes\event\ResultTestVariablesTransmissionEvent;
use oat\taoQtiTest\models\event\ResultItemVariablesTransmissionEvent;
use oat\taoQtiTest\models\event\TestVariablesRecorded;
use taoQtiCommon_helpers_ResultTransmitter;
use oat\oatbox\service\exception\InvalidServiceManagerException;
use oat\taoResultServer\models\classes\implementation\ResultServerService;
use taoResultServer_models_classes_ReadableResultStorage as ReadableResultStorage;

class ResultTransmissionEventHandler extends InjectionAwareService implements
Api\ResultTransmissionEventHandlerInterface
Expand All @@ -55,6 +49,7 @@ public function transmitResultItemVariable(ResultItemVariablesTransmissionEvent
/**
* @param ResultTestVariablesTransmissionEvent $event
* @throws InvalidServiceManagerException
* @throws ServiceNotFoundException
* @throws \taoQtiCommon_helpers_ResultTransmissionException
*/
public function transmitResultTestVariable(ResultTestVariablesTransmissionEvent $event): void
Expand All @@ -64,14 +59,14 @@ public function transmitResultTestVariable(ResultTestVariablesTransmissionEvent
$event->getTransmissionId(),
$event->getTestUri()
);

if (!$this->containsScoreTotal($event)) {
return;
}

$this->triggerTestVariablesRecorded($event);
}

/**
* @param $deliveryExecutionIdigcicd
* @return taoQtiCommon_helpers_ResultTransmitter
* @throws InvalidServiceManagerException
* @throws \oat\oatbox\service\ServiceNotFoundException
*/
private function buildTransmitter($deliveryExecutionId): taoQtiCommon_helpers_ResultTransmitter
{
/** @var DeliveryServerService $deliveryServerService */
Expand All @@ -80,58 +75,4 @@ private function buildTransmitter($deliveryExecutionId): taoQtiCommon_helpers_Re

return new taoQtiCommon_helpers_ResultTransmitter($resultStore);
}

public function getEventManager()
{
return $this->getServiceLocator()->get(EventManager::SERVICE_ID);
}

public function getServiceLocator()
{
return ServiceManager::getServiceManager();
}

/**
* @return ReadableResultStorage
* @throws ServiceNotFoundException
* @throws common_exception_Error
*/
private function getResultsStorage(): ReadableResultStorage
{
$resultServerService = $this->getServiceLocator()->get(ResultServerService::SERVICE_ID);
$storage = $resultServerService->getResultStorage();

if (!$storage instanceof ReadableResultStorage) {
throw new common_exception_Error('Configured result storage is not writable.');
}

return $storage;
}

private function containsScoreTotal(ResultTestVariablesTransmissionEvent $event): bool
{
$scoreTotal = array_filter(
$event->getVariables(),
function ($item) {
return $item->getIdentifier() === 'SCORE_TOTAL';
}
);

return !empty($scoreTotal);
}

/**
* @param ResultTestVariablesTransmissionEvent $event
* @return void
* @throws InvalidServiceManagerException
*/
private function triggerTestVariablesRecorded(ResultTestVariablesTransmissionEvent $event): void
{
$outcomeVariables = $this->getResultsStorage()->getDeliveryVariables($event->getDeliveryExecutionId());
$this->getEventManager()->trigger(new TestVariablesRecorded(
$event->getDeliveryExecutionId(),
$outcomeVariables,
$event->isManualScored()
));
}
}
23 changes: 23 additions & 0 deletions models/classes/runner/QtiRunnerService.php
Original file line number Diff line number Diff line change
Expand Up @@ -46,6 +46,7 @@
use oat\taoDelivery\model\execution\DeliveryServerService;
use oat\taoDelivery\model\execution\ServiceProxy as TaoDeliveryServiceProxy;
use oat\taoDelivery\model\RuntimeService;
use oat\taoOutcomeRds\model\RdsResultStorage;
use oat\taoQtiItem\model\portableElement\exception\PortableElementNotFoundException;
use oat\taoQtiItem\model\portableElement\exception\PortableModelMissing;
use oat\taoQtiItem\model\portableElement\PortableElementService;
Expand All @@ -57,6 +58,7 @@
use oat\taoQtiTest\models\event\TestExitEvent;
use oat\taoQtiTest\models\event\TestInitEvent;
use oat\taoQtiTest\models\event\TestTimeoutEvent;
use oat\taoQtiTest\models\event\DeliveryExecutionFinish;
use oat\taoQtiTest\models\ExtendedStateService;
use oat\taoQtiTest\models\files\QtiFlysystemFileManager;
use oat\taoQtiTest\models\render\UpdateItemContentReferencesService;
Expand All @@ -68,6 +70,7 @@
use oat\taoQtiTest\models\runner\session\TestSession;
use oat\taoQtiTest\models\runner\toolsStates\ToolsStateStorage;
use oat\taoQtiTest\models\TestSessionService;
use oat\taoResultServer\models\classes\implementation\ResultServerService;
use qtism\common\datatypes\QtiInteger;
use qtism\common\datatypes\QtiString as QtismString;
use qtism\common\enums\BaseType;
Expand Down Expand Up @@ -1185,10 +1188,30 @@ public function finish(RunnerServiceContext $context, $finalState = DeliveryExec
}

$this->getServiceManager()->get(ExtendedStateService::SERVICE_ID)->clearEvents($executionUri);
/** @var TestSession $session */
$session = $context->getTestSession();
$this->triggerDeliveryExecutionFinish($deliveryExecution, $session->isManualScored());

return $result;
}

private function getResultsStorage(): RdsResultStorage
{
return $this->getServiceLocator()->get(ResultServerService::SERVICE_ID)->getResultStorage();
}

private function triggerDeliveryExecutionFinish(DeliveryExecution $deliveryExecution, bool $isManualScored): void
{
$outcomeVariables = $this->getResultsStorage()->getDeliveryVariables($deliveryExecution->getIdentifier());
$this->getServiceManager()->get(EventManager::SERVICE_ID)->trigger(
new DeliveryExecutionFinish(
$deliveryExecution,
$outcomeVariables,
$isManualScored
)
);
}

/**
* Sets the test to paused state
* @param RunnerServiceContext $context
Expand Down

0 comments on commit d87be4b

Please sign in to comment.