Added Test class to track benchmark groups

This commit is contained in:
2022-11-25 19:39:51 -05:00
parent 9a65b5f27a
commit ca62be49b6
12 changed files with 245 additions and 4 deletions

View File

@ -7,6 +7,7 @@ use Psr\Http\Message\ServerRequestInterface as Request;
use Slim\Routing\RouteContext;
use Slim\Views\Twig;
use BitGoblin\Colossus\Models\Result;
use BitGoblin\Colossus\Models\Test;
class ResultController extends Controller {
@ -20,14 +21,19 @@ class ResultController extends Controller {
}
public function getAdd(Request $request, Response $response): Response {
$tests = Test::all();
$view = Twig::fromRequest($request);
return $view->render($response, 'result/add.twig');
return $view->render($response, 'result/add.twig', [
'tests' => $tests,
]);
}
public function postAdd(Request $request, Response $response): Response {
$params = (array)$request->getParsedBody();
$result = new Result;
$result->test_id = $params['result_test'];
$result->component = $params['result_component'];
$result->benchmark = $params['result_benchmark'];
$result->type = $params['result_type'];

View File

@ -0,0 +1,53 @@
<?php
namespace BitGoblin\Colossus\Controllers;
use Psr\Http\Message\ResponseInterface as Response;
use Psr\Http\Message\ServerRequestInterface as Request;
use Slim\Routing\RouteContext;
use Slim\Views\Twig;
use BitGoblin\Colossus\Models\Test;
class TestController extends Controller {
public function getList(Request $request, Response $response): Response {
$tests = Test::all();
$view = Twig::fromRequest($request);
return $view->render($response, 'test/list.twig', [
'tests' => $tests,
]);
}
public function getView(Request $request, Response $response, array $args): Response {
$test = Test::where('id', $args['test_id'])->first();
$view = Twig::fromRequest($request);
return $view->render($response, 'test/view.twig', [
'test' => $test,
]);
}
public function getAdd(Request $request, Response $response): Response {
$view = Twig::fromRequest($request);
return $view->render($response, 'test/add.twig');
}
public function postAdd(Request $request, Response $response): Response {
$params = (array)$request->getParsedBody();
$test = new Test;
$test->name = $params['test_name'];
$test->description = $params['test_description'];
$test->save();
// redirect the user back to the home page
$routeContext = RouteContext::fromRequest($request);
$routeParser = $routeContext->getRouteParser();
return $response
->withHeader('Location', $routeParser->urlFor('test.list'))
->withStatus(302);
}
}

View File

@ -7,6 +7,7 @@ use Illuminate\Database\Eloquent\Model;
class Result extends Model {
protected $fillable = [
'test_id',
'component',
'benchmark',
'type',
@ -15,4 +16,8 @@ class Result extends Model {
'maximum',
];
public function test() {
return $this->belongsTo(Test::class);
}
}

18
src/Models/Test.php Normal file
View File

@ -0,0 +1,18 @@
<?php
namespace BitGoblin\Colossus\Models;
use Illuminate\Database\Eloquent\Model;
class Test extends Model {
protected $fillable = [
'name',
'description',
];
public function results() {
return $this->hasMany(Result::class);
}
}

View File

@ -2,6 +2,11 @@
$app->get('/', '\\BitGoblin\\Colossus\\Controllers\\HomeController:getIndex')->setName('dashboard');
$app->get('/test', '\\BitGoblin\\Colossus\\Controllers\\TestController:getList')->setName('test.list');
$app->get('/test/add', '\\BitGoblin\\Colossus\\Controllers\\TestController:getAdd')->setName('test.add');
$app->post('/test/add', '\\BitGoblin\\Colossus\\Controllers\\TestController:postAdd');
$app->get('/test/{test_id}', '\\BitGoblin\\Colossus\\Controllers\\TestController:getView')->setName('test.view');
$app->get('/result', '\\BitGoblin\\Colossus\\Controllers\\ResultController:getList')->setName('result.list');
$app->get('/result/add', '\\BitGoblin\\Colossus\\Controllers\\ResultController:getAdd')->setName('result.add');
$app->post('/result/add', '\\BitGoblin\\Colossus\\Controllers\\ResultController:postAdd');