Code Coverage
 
Lines
Functions and Methods
Classes and Traits
Total
71.43% covered (warning)
71.43%
5 / 7
50.00% covered (danger)
50.00%
1 / 2
CRAP
0.00% covered (danger)
0.00%
0 / 1
QtiBoolean
71.43% covered (warning)
71.43%
5 / 7
50.00% covered (danger)
50.00%
1 / 2
5.58
0.00% covered (danger)
0.00%
0 / 1
 validate
100.00% covered (success)
100.00%
1 / 1
100.00% covered (success)
100.00%
1 / 1
1
 fix
66.67% covered (warning)
66.67%
4 / 6
0.00% covered (danger)
0.00%
0 / 1
4.59
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) 2013 (original work) Open Assessment Technologies SA (under the project TAO-PRODUCT);
19 *
20 *
21 */
22
23namespace oat\taoQtiItem\model\qti\datatype;
24
25use oat\taoQtiItem\model\qti\datatype\Boolean;
26use oat\taoQtiItem\model\qti\datatype\Datatype;
27
28/**
29 * The basic boolean datatype
30 *
31 * @access public
32 * @author Sam, <sam@taotesting.com>
33 * @package taoQTI
34
35 */
36class QtiBoolean extends Datatype
37{
38    public static function validate($value)
39    {
40        return is_bool($value);
41    }
42
43    public static function fix($value)
44    {
45        $returnValue = null;
46
47        if (strcasecmp($value, 'false') == 0) {
48            $returnValue = false;
49        } elseif (!is_array($value) && !is_object($value)) {
50            $returnValue = (bool)$value;//try casting to boolean type
51        }
52
53        return $returnValue;
54    }
55}