Web notifications small fixes. Issue #156.

This commit is contained in:
Dmitry Khomutov 2018-04-09 20:07:04 +07:00
commit 56fc76d4e5
No known key found for this signature in database
GPG key ID: EC19426474B37AAC
7 changed files with 36 additions and 69 deletions

View file

@ -365,17 +365,9 @@ class BuildController extends WebController
public function ajaxQueue()
{
$sPending = 'pending';
$sRunning = 'running';
$pending = $this->buildStore->getByStatus(Build::STATUS_PENDING);
$running = $this->buildStore->getByStatus(Build::STATUS_RUNNING);
$rtn = [
$sPending => $this->formatBuilds($pending),
$sRunning => $this->formatBuilds($running),
'pending' => $this->formatBuilds($this->buildStore->getByStatus(Build::STATUS_PENDING)),
'running' => $this->formatBuilds($this->buildStore->getByStatus(Build::STATUS_RUNNING)),
];
$response = new JsonResponse();

View file

@ -3,16 +3,9 @@
namespace PHPCensor\Controller;
use PHPCensor\Model\Build;
use PHPCensor\Store\BuildStore;
use PHPCensor\WebController;
use PHPCensor\Store\Factory;
//use PHPCensor\View;
//use PHPCensor\Model\Project;
//use PHPCensor\Http\Response;
//use PHPCensor\Store\BuildStore;
//use PHPCensor\Store\ProjectStore;
//use PHPCensor\Store\ProjectGroupStore;
//use PHPCensor\Service\BuildService;
//use b8\Http\Response\JsonResponse;
use PHPCensor\Http\Response\JsonResponse;
use PHPCensor\Service\WebNotificationService;
@ -26,16 +19,6 @@ class WebNotificationsController extends WebController
*/
protected $buildStore;
/**
* @var ProjectStore
*/
protected $projectStore;
/**
* @var ProjectGroupStore
*/
protected $groupStore;
/**
* Initialise the controller, set up stores and services.
*/
@ -43,18 +26,17 @@ class WebNotificationsController extends WebController
{
parent::init();
$this->buildStore = Factory::getStore('Build');
$this->projectStore = Factory::getStore('Project');
$this->groupStore = Factory::getStore('ProjectGroup');
$this->buildStore = Factory::getStore('Build');
}
/**
* Provides JSON format for web notification UI of all last
* builds that have success and failed status.
* This is similar to WidgetAllProjectsController::update()
* but instead, this only returns JSON.
* Provides JSON format for web notification UI of all last builds that have success and failed status.
* This is similar to WidgetAllProjectsController::update() but instead, this only returns JSON.
*
* @param int $projectId
*
* @return \PHPCensor\Http\Response\JsonResponse
*
* @see \PHPCensor\Controller\WidgetAllProjectsController
*/
public function widgetsAllProjectsUpdate($projectId)
@ -65,9 +47,6 @@ class WebNotificationsController extends WebController
$oSuccess = WebNotificationService::formatBuild($success);
$oFailed = WebNotificationService::formatBuild($failed);
//@keys count and items Follow the for-loop structure
//found in
//\PHPCensor\Service\WebNotificationService::formatBuilds()
$aSuccess = [
'count' => count($oSuccess),
'items' => [$projectId => ['build' => $oSuccess]]
@ -90,24 +69,25 @@ class WebNotificationsController extends WebController
/**
* Provides JSON format for web notification UI of all last
* builds that have pending and running status.
* This is similar to WidgetAllProjectsController::update()
* but instead, this only returns JSON.
* @return \PHPCensor\Http\Response\JsonResponse
* Provides JSON format for web notification UI of all last builds that have pending and running status.
* This is similar to WidgetAllProjectsController::update() but instead, this only returns JSON.
*
* @return JsonResponse
*
* @throws \PHPCensor\Exception\HttpException
*/
public function buildsUpdated()
{
$pending = $this->buildStore->getByStatus(Build::STATUS_PENDING);
$running = $this->buildStore->getByStatus(Build::STATUS_RUNNING);
$rtn = [
$result = [
'pending' => WebNotificationService::formatBuilds($pending),
'running' => WebNotificationService::formatBuilds($running)
];
$response = new JsonResponse();
$response->setContent($rtn);
$response->setContent($result);
return $response;
}

View file

@ -11,8 +11,6 @@ use PHPCensor\Http\Response;
use PHPCensor\Store\BuildStore;
use PHPCensor\Store\ProjectStore;
use PHPCensor\Store\ProjectGroupStore;
use PHPCensor\Service\BuildService;
use b8\Http\Response\JsonResponse;
/**
* Widget All Projects Controller
@ -106,6 +104,8 @@ class WidgetAllProjectsController extends WebController
* Get a summary of the project groups we have, and what projects they have in them.
*
* @return array
*
* @throws \Exception
*/
protected function getGroupInfo()
{
@ -129,6 +129,8 @@ class WidgetAllProjectsController extends WebController
* @param integer $projectId
*
* @return Response
*
* @throws \PHPCensor\Exception\HttpException
*/
public function update($projectId)
{

View file

@ -52,6 +52,8 @@ class WidgetBuildErrorsController extends WebController
/**
* @return Response
*
* @throws \PHPCensor\Exception\HttpException
*/
public function update()
{
@ -65,6 +67,8 @@ class WidgetBuildErrorsController extends WebController
* @param View $view
*
* @return string
*
* @throws \PHPCensor\Exception\HttpException
*/
protected function renderAllProjectsLatestBuilds($view)
{