Skip to content

Commit

Permalink
add unittest to test that the problems page does not show page, state…
Browse files Browse the repository at this point in the history
…ment, sample data before contest start.
  • Loading branch information
as6325400 committed Nov 1, 2024
1 parent 2d6f4ff commit 857338e
Showing 1 changed file with 42 additions and 0 deletions.
42 changes: 42 additions & 0 deletions webapp/tests/Unit/Controller/Team/ProblemControllerTest.php
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,9 @@

namespace App\Tests\Unit\Controller\Team;

use App\DataFixtures\Test\DemoAboutToStartContestFixture;
use App\Entity\Contest;
use App\Entity\ContestProblem;
use App\Entity\Problem;
use App\Entity\Testcase;
use App\Tests\Unit\BaseTestCase;
Expand Down Expand Up @@ -183,4 +186,43 @@ public function testInteractiveSamples(): void
$response = $this->client->getResponse();
self::assertEquals(404, $response->getStatusCode());
}

/**
* Test that the problems page does not show page, statement, sample data before contest start.
*/
public function testAccessProblemBeforeContestStarts(): void
{
$this->loadFixtures([DemoAboutToStartContestFixture::class]);

/** @var EntityManagerInterface $em */
$em = self::getContainer()->get(EntityManagerInterface::class);
$problems = $em->createQueryBuilder()
->select('p.probid')
->from(ContestProblem::class, 'cp')
->join('cp.problem', 'p')
->join('cp.contest', 'c')
->where('c.shortname = :shortname')
->setParameter('shortname', 'demo')
->getQuery()
->getResult();
$probids = array_column($problems, 'probid');

$this->client->request('GET', '/public/problems');
static::assertSelectorTextContains('.nav-item .nav-link.disabled', 'Problems');
static::assertSelectorTextContains('.alert.alert-secondary', 'No problem texts available at this point.');

foreach ($probids as $id) {
$endpoints = [
"/team/problems/{$id}",
"/team/problems/{$id}/statement",
"/team/problems/{$id}/samples.zip"
];

foreach ($endpoints as $endpoint) {
$this->client->request('GET', $endpoint);
$statusCode = $this->client->getResponse()->getStatusCode();
static::assertSame(404, $statusCode, "Expected status code 404, got {$statusCode} for {$endpoint}");
}
}
}
}

0 comments on commit 857338e

Please sign in to comment.