Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
28.57% covered (danger)
28.57%
2 / 7
25.00% covered (danger)
25.00%
1 / 4
CRAP
0.00% covered (danger)
0.00%
0 / 1
AbstractTestTakerEvent
28.57% covered (danger)
28.57%
2 / 7
25.00% covered (danger)
25.00%
1 / 4
9.83
0.00% covered (danger)
0.00%
0 / 1
 __construct
100.00% covered (success)
100.00%
2 / 2
100.00% covered (success)
100.00%
1 / 1
1
 getName
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
 jsonSerialize
0.00% covered (danger)
0.00%
0 / 3
0.00% covered (danger)
0.00%
0 / 1
2
 getProperties
0.00% covered (danger)
0.00%
0 / 1
0.00% covered (danger)
0.00%
0 / 1
2
1<?php
2
3/**
4 * This program is free software; you can redistribute it and/or
5 * modify it under the terms of the GNU General Public License
6 * as published by the Free Software Foundation; under version 2
7 * of the License (non-upgradable).
8 *
9 * This program is distributed in the hope that it will be useful,
10 * but WITHOUT ANY WARRANTY; without even the implied warranty of
11 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
12 * GNU General Public License for more details.
13 *
14 * You should have received a copy of the GNU General Public License
15 * along with this program; if not, write to the Free Software
16 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA  02110-1301, USA.
17 *
18 * Copyright (c) 2016  (original work) Open Assessment Technologies SA;
19 *
20 * @author Ivan klimchuk <klimchuk@1pt.com>
21 */
22
23namespace oat\taoTestTaker\models\events;
24
25use JsonSerializable;
26use oat\oatbox\event\Event;
27
28abstract class AbstractTestTakerEvent implements Event, JsonSerializable
29{
30    /** @var string */
31    protected $testTakerUri;
32
33    /** @var array */
34    protected $properties;
35
36    /**
37     * AbstractTestTakerEvent constructor.
38     * @param $testTakerUri
39     * @param array $properties
40     */
41    public function __construct($testTakerUri, array $properties = [])
42    {
43        $this->testTakerUri = $testTakerUri;
44
45        $this->properties = $properties;
46    }
47
48    /**
49     * @return string
50     */
51    public function getName()
52    {
53        return get_class($this);
54    }
55
56    /**
57     * Specify data which should be serialized to JSON
58     * @link http://php.net/manual/en/jsonserializable.jsonserialize.php
59     * @return mixed data which can be serialized by <b>json_encode</b>,
60     * which is a value of any type other than a resource.
61     * @since 5.4.0
62     */
63    public function jsonSerialize()
64    {
65        return [
66            'testTakerUri' => $this->testTakerUri,
67        ];
68    }
69
70    /**
71     * @return array
72     */
73    public function getProperties()
74    {
75        return $this->properties;
76    }
77}