. */ namespace SP\Tests\Services\Eventlog; use DI\DependencyException; use DI\NotFoundException; use SP\Core\Context\ContextException; use SP\Core\Exceptions\ConstraintException; use SP\Core\Exceptions\QueryException; use SP\Core\Exceptions\SPException; use SP\DataModel\EventlogData; use SP\DataModel\ItemSearchData; use SP\Services\EventLog\EventlogService; use SP\Tests\DatabaseTestCase; use stdClass; use function SP\Tests\setupContext; /** * Class EventlogServiceTest * * @package SP\Tests\Services\Eventlog */ class EventlogServiceTest extends DatabaseTestCase { /** * @var EventlogService */ private static $service; /** * @throws NotFoundException * @throws ContextException * @throws DependencyException */ public static function setUpBeforeClass(): void { $dic = setupContext(); self::$loadFixtures = true; // Inicializar el servicio self::$service = $dic->get(EventlogService::class); } /** * @throws ConstraintException * @throws QueryException * @throws SPException */ public function testClear() { self::$service->clear(); $this->assertEquals(0, self::getRowCount('EventLog')); } /** * @throws ConstraintException * @throws QueryException */ public function testSearch() { $itemSearchData = new ItemSearchData(); $itemSearchData->setLimitCount(10); $itemSearchData->setSeachString('login.auth.database'); $result = self::$service->search($itemSearchData); $data = $result->getDataAsArray(); $this->assertEquals(4, $result->getNumRows()); $this->assertCount(4, $data); $this->assertInstanceOf(stdClass::class, $data[0]); $this->assertEquals('login.auth.database', $data[0]->action); $itemSearchData->setSeachString('login.auth.'); $result = self::$service->search($itemSearchData); $data = $result->getDataAsArray(); $this->assertEquals(4, $result->getNumRows()); $this->assertCount(4, $data); $this->assertInstanceOf(stdClass::class, $data[0]); $itemSearchData->setSeachString('Tiempo inactivo : 0 min.'); $result = self::$service->search($itemSearchData); $data = $result->getDataAsArray(); $this->assertEquals(1, $result->getNumRows()); $this->assertCount(1, $data); $this->assertInstanceOf(stdClass::class, $data[0]); $itemSearchData->setSeachString('prueba'); $result = self::$service->search($itemSearchData); $this->assertCount(0, $result->getDataAsArray()); $this->assertEquals(0, $result->getNumRows()); } /** * @throws ConstraintException * @throws QueryException */ public function testCreate() { $eventlogData = new EventlogData(); $eventlogData->setAction('test'); $eventlogData->setLevel('INFO'); $eventlogData->setUserId(1); $eventlogData->setLogin('Admin'); $eventlogData->setIpAddress('127.0.0.1'); $eventlogData->setDescription('Prueba'); $countBefore = self::getRowCount('EventLog'); self::$service->create($eventlogData); $countAfter = self::getRowCount('EventLog'); $this->assertEquals($countBefore + 1, $countAfter); $this->expectException(ConstraintException::class); self::$service->create(new EventlogData()); } }