256 lines
8.4 KiB
PHP
256 lines
8.4 KiB
PHP
<?php
|
|
|
|
/**
|
|
* This program is free software; you can redistribute it and/or
|
|
* modify it under the terms of the GNU General Public License
|
|
* as published by the Free Software Foundation; under version 2
|
|
* of the License (non-upgradable).
|
|
*
|
|
* This program is distributed in the hope that it will be useful,
|
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
* GNU General Public License for more details.
|
|
*
|
|
* You should have received a copy of the GNU General Public License
|
|
* along with this program; if not, write to the Free Software
|
|
* Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
|
|
*
|
|
* Copyright (c) 2017 (original work) Open Assessment Technologies SA (under the project TAO-PRODUCT);
|
|
*
|
|
*/
|
|
|
|
namespace oat\taoTaskQueue\test\model\Task;
|
|
|
|
use InvalidArgumentException;
|
|
use oat\taoTaskQueue\model\Task\AbstractTask;
|
|
use oat\taoTaskQueue\model\Task\TaskInterface;
|
|
use oat\generis\test\TestCase;
|
|
|
|
/**
|
|
* @deprecated
|
|
*/
|
|
class AbstractTaskTest extends TestCase
|
|
{
|
|
/**
|
|
* @var AbstractTask
|
|
*/
|
|
private $abstractTaskMock;
|
|
private $fakeId = 'ADFA23234sdfsdf';
|
|
private $fakeOwner = 'FakeOwner';
|
|
|
|
public function setUp(): void
|
|
{
|
|
$this->abstractTaskMock = $this->getMockBuilder(AbstractTask::class)
|
|
->setConstructorArgs([$this->fakeId, $this->fakeOwner])
|
|
->getMockForAbstractClass();
|
|
}
|
|
|
|
public function tearDown(): void
|
|
{
|
|
$this->abstractTaskMock = null;
|
|
}
|
|
|
|
public function testSetMetadataShouldReturnTheTask()
|
|
{
|
|
$rs = $this->abstractTaskMock->setMetadata('foo', 'bar');
|
|
$this->assertInstanceOf(TaskInterface::class, $rs);
|
|
}
|
|
|
|
public function testGetMetadataWhenKeyDoesNotExistThenReturnNull()
|
|
{
|
|
$this->assertNull($this->abstractTaskMock->getMetadata('not_existing_key'));
|
|
}
|
|
|
|
public function testGetMetadataWhenKeyDoesNotExistAndDefaultIsSuppliedThenReturnDefault()
|
|
{
|
|
$default = 'default_value';
|
|
$this->assertEquals($default, $this->abstractTaskMock->getMetadata('not_existing_key', $default));
|
|
}
|
|
|
|
public function testSetGetMetadataWhenKeyIsAString()
|
|
{
|
|
$key = 'key1';
|
|
$value = 'value1';
|
|
$this->abstractTaskMock->setMetadata($key, $value);
|
|
|
|
$this->assertEquals($value, $this->abstractTaskMock->getMetadata($key));
|
|
}
|
|
|
|
public function testSetGetMetadataWhenKeyIsAnArray()
|
|
{
|
|
$key = ['foo' => 'bar'];
|
|
$this->abstractTaskMock->setMetadata($key);
|
|
|
|
$this->assertEquals('bar', $this->abstractTaskMock->getMetadata('foo'));
|
|
}
|
|
|
|
public function testSetMetadataWhenKeyIsInvalidThenThrowException()
|
|
{
|
|
$this->expectException(InvalidArgumentException::class);
|
|
$this->abstractTaskMock->setMetadata(new \stdClass());
|
|
}
|
|
|
|
public function testGetMetadataWhenKeyIsInvalidThenThrowException()
|
|
{
|
|
$this->expectException(InvalidArgumentException::class);
|
|
$this->abstractTaskMock->getMetadata(new \stdClass());
|
|
}
|
|
|
|
public function testSetParameterShouldReturnTheTask()
|
|
{
|
|
$rs = $this->abstractTaskMock->setMetadata('foo', 'bar');
|
|
$this->assertInstanceOf(TaskInterface::class, $rs);
|
|
}
|
|
|
|
public function testGetParameterWhenKeyDoesNotExistThenReturnNull()
|
|
{
|
|
$this->assertNull($this->abstractTaskMock->getParameter('not_existing_key'));
|
|
}
|
|
|
|
public function testGetParameterWhenKeyDoesNotExistAndDefaultIsSuppliedThenReturnDefault()
|
|
{
|
|
$default = 'default_value';
|
|
$this->assertEquals($default, $this->abstractTaskMock->getParameter('not_existing_key', $default));
|
|
}
|
|
|
|
public function testSetGetParameterWhenKeyIsAString()
|
|
{
|
|
$key = 'key1';
|
|
$value = 'value1';
|
|
$this->abstractTaskMock->setParameter($key, $value);
|
|
|
|
$this->assertEquals($value, $this->abstractTaskMock->getParameter($key));
|
|
}
|
|
|
|
public function testSetGetParameterWhenKeyIsAnArray()
|
|
{
|
|
$key = ['foo' => 'bar'];
|
|
$this->abstractTaskMock->setParameter($key);
|
|
|
|
$this->assertEquals('bar', $this->abstractTaskMock->getParameter('foo'));
|
|
}
|
|
|
|
public function testSetParameterWhenKeyIsInvalidThenThrowException()
|
|
{
|
|
$this->expectException(InvalidArgumentException::class);
|
|
$this->abstractTaskMock->setParameter(new \stdClass());
|
|
}
|
|
|
|
public function testGetParameterWhenKeyIsInvalidThenThrowException()
|
|
{
|
|
$this->expectException(InvalidArgumentException::class);
|
|
$this->abstractTaskMock->getParameter(new \stdClass());
|
|
}
|
|
|
|
public function testGetParametersShouldGiveBackTheWholeParameterContainer()
|
|
{
|
|
$this->abstractTaskMock->setParameter('key1', 'value1');
|
|
$this->abstractTaskMock->setParameter('key2', 'value2');
|
|
$this->abstractTaskMock->setParameter(['key3' => 'value3', 'key4' => 'value4']);
|
|
|
|
$this->assertEquals([
|
|
'key1' => 'value1',
|
|
'key2' => 'value2',
|
|
'key3' => 'value3',
|
|
'key4' => 'value4'
|
|
], $this->abstractTaskMock->getParameters());
|
|
}
|
|
|
|
public function testIdShouldBeGeneratedInConstructor()
|
|
{
|
|
$this->assertEquals($this->fakeId, $this->abstractTaskMock->getId());
|
|
}
|
|
|
|
public function testIdShouldNotBeOverWrittenBySetMetadata()
|
|
{
|
|
$this->abstractTaskMock->setMetadata('id', 4444);
|
|
$this->assertEquals($this->fakeId, $this->abstractTaskMock->getId());
|
|
}
|
|
|
|
public function testCreatedAtShouldBeGeneratedInConstructor()
|
|
{
|
|
$this->assertInstanceOf(\DateTime::class, $this->abstractTaskMock->getCreatedAt());
|
|
}
|
|
|
|
public function testSetCreatedAtShouldReturnTheTask()
|
|
{
|
|
$rs = $this->abstractTaskMock->setCreatedAt(new \DateTime());
|
|
$this->assertInstanceOf(TaskInterface::class, $rs);
|
|
}
|
|
|
|
public function testSetGetCreatedAtWhenCreatedAtSetFromOutside()
|
|
{
|
|
$date = new \DateTime('yesterday 12:15:00');
|
|
$this->abstractTaskMock->setCreatedAt($date);
|
|
$this->assertEquals($date, $this->abstractTaskMock->getCreatedAt());
|
|
}
|
|
|
|
public function testToStringWorks()
|
|
{
|
|
$this->assertEquals('TASK ' . get_class($this->abstractTaskMock) . ' [' . $this->fakeId . ']', (string) $this->abstractTaskMock);
|
|
}
|
|
|
|
public function testOwnerShouldBeGeneratedInConstructor()
|
|
{
|
|
$this->assertEquals($this->fakeOwner, $this->abstractTaskMock->getOwner());
|
|
}
|
|
|
|
public function testSetOwnerShouldReturnTheTask()
|
|
{
|
|
$rs = $this->abstractTaskMock->setOwner('owner');
|
|
$this->assertInstanceOf(TaskInterface::class, $rs);
|
|
}
|
|
|
|
public function testSetGetOwnerWhenOwnerSetFromOutside()
|
|
{
|
|
$owner = 'example_owner';
|
|
$this->abstractTaskMock->setOwner($owner);
|
|
$this->assertEquals($owner, $this->abstractTaskMock->getOwner());
|
|
}
|
|
|
|
public function testJsonSerializingAbstractTask()
|
|
{
|
|
$this->abstractTaskMock->setMetadata('key1', 'value1');
|
|
$this->abstractTaskMock->setMetadata('key2', 'value2');
|
|
$this->abstractTaskMock->setMetadata(['key3' => 'value3', 'key4' => 'value4']);
|
|
|
|
$this->abstractTaskMock->setParameter('key1', 'value1');
|
|
$this->abstractTaskMock->setParameter('key2', 'value2');
|
|
$this->abstractTaskMock->setParameter(['key3' => 'value3', 'key4' => 'value4']);
|
|
|
|
$date = new \DateTime('-2days 12:15:00');
|
|
$this->abstractTaskMock->setCreatedAt($date);
|
|
|
|
$jsonArray = [
|
|
'taskFqcn' => get_class($this->abstractTaskMock),
|
|
'metadata' => [
|
|
'__id__' => $this->fakeId,
|
|
'__created_at__' => $date->format('c'),
|
|
'__owner__' => $this->fakeOwner,
|
|
'key1' => 'value1',
|
|
'key2' => 'value2',
|
|
'key3' => 'value3',
|
|
'key4' => 'value4'
|
|
],
|
|
'parameters' => [
|
|
'key1' => 'value1',
|
|
'key2' => 'value2',
|
|
'key3' => 'value3',
|
|
'key4' => 'value4'
|
|
]
|
|
];
|
|
|
|
$this->assertEquals(json_encode($jsonArray), json_encode($this->abstractTaskMock));
|
|
}
|
|
|
|
public function testGetCreatedAtWhenJsonEncodeIsLoadedThenItShouldStillGiveADateTimeObject()
|
|
{
|
|
$date = new \DateTime('yesterday 12:15:00');
|
|
$this->abstractTaskMock->setCreatedAt($date);
|
|
|
|
$json = json_encode($this->abstractTaskMock);
|
|
|
|
$this->assertInstanceOf(\DateTime::class, $this->abstractTaskMock->getCreatedAt());
|
|
}
|
|
}
|