Passed
Push — master ( 8ba091...d47090 )
by Johnny
06:24
created

SingleTest::minScore()   A

Complexity

Conditions 1
Paths 1

Size

Total Lines 3
Code Lines 1

Duplication

Lines 0
Ratio 0 %

Importance

Changes 1
Bugs 0 Features 0
Metric Value
cc 1
eloc 1
c 1
b 0
f 0
nc 1
nop 0
dl 0
loc 3
rs 10
1
<?php
2
3
require __DIR__.'/../vendor/autoload.php';
4
5
use Redbox\Testsuite\Test;
0 ignored issues
show
Bug introduced by
This use statement conflicts with another class in this namespace, Test. Consider defining an alias.

Let?s assume that you have a directory layout like this:

.
|-- OtherDir
|   |-- Bar.php
|   `-- Foo.php
`-- SomeDir
    `-- Foo.php

and let?s assume the following content of Bar.php:

// Bar.php
namespace OtherDir;

use SomeDir\Foo; // This now conflicts the class OtherDir\Foo

If both files OtherDir/Foo.php and SomeDir/Foo.php are loaded in the same runtime, you will see a PHP error such as the following:

PHP Fatal error:  Cannot use SomeDir\Foo as Foo because the name is already in use in OtherDir/Foo.php

However, as OtherDir/Foo.php does not necessarily have to be loaded and the error is only triggered if it is loaded before OtherDir/Bar.php, this problem might go unnoticed for a while. In order to prevent this error from surfacing, you must import the namespace with a different alias:

// Bar.php
namespace OtherDir;

use SomeDir\Foo as SomeDirFoo; // There is no conflict anymore.
Loading history...
6
use Redbox\Testsuite\TestSuite;
7
8
/**
9
 * JUST A SPEC DEMO FOR MY SELF
10
 */
11
class SingleTest extends Test
12
{
13
    
14
    /**
15
     * Required function for tests indicating
16
     * the minimal score for this test.
17
     *
18
     * @return int
19
     */
20
    public function minScore(): int
21
    {
22
        return 0;
23
    }
24
    
25
    /**
26
     * Required function for tests indicating
27
     * the maximum score for this test.
28
     *
29
     * @return int
30
     */
31
    public function maxScore(): int
32
    {
33
        return 4;
34
    }
35
    
36
    /**
37
     * Demo function for answering demo questions.
38
     *
39
     * @param bool $correct For demo only if the answer is true mark correct.
40
     *
41
     * @return void
42
     */
43
    protected function checkAnswer(bool $correct)
44
    {
45
        if ($correct) {
46
            $this->score->increment(1);
0 ignored issues
show
Bug introduced by
The method increment() does not exist on null. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

46
            $this->score->/** @scrutinizer ignore-call */ 
47
                          increment(1);

This check looks for calls to methods that do not seem to exist on a given type. It looks for the method on the type itself as well as in inherited classes or implemented interfaces.

This is most likely a typographical error or the method has been renamed.

Loading history...
47
        }
48
    }
49
    
50
    /**
51
     * Run the test.
52
     *
53
     * @return void
54
     */
55
    public function run()
56
    {
57
        $this->checkAnswer(true);
58
        $this->checkAnswer(true);
59
        $this->checkAnswer(false);
60
    }
61
}
62
63
$test = new SingleTest();
64
65
/**
66
 * Create a test suite
67
 */
68
$suite = new TestSuite();
69
$suite->attach($test);
70
71
/**
72
 * Score should be
73
 *
74
 * Test score: 2
75
 *   - Answer 1 correct: true
76
 *   - Answer 2 correct: true
77
 *   - Answer 3 correct: false
78
 * ===================+
79
 * Total suite score 2
80
 */
81
$suite->run();
82
83
echo "Total suite score: ".$suite->getScore()."\n";
84
echo "Percentage complete: ".$test->score->percentage()."%\n";
0 ignored issues
show
Bug introduced by
The method percentage() does not exist on null. ( Ignorable by Annotation )

If this is a false-positive, you can also ignore this issue in your code via the ignore-call  annotation

84
echo "Percentage complete: ".$test->score->/** @scrutinizer ignore-call */ percentage()."%\n";

This check looks for calls to methods that do not seem to exist on a given type. It looks for the method on the type itself as well as in inherited classes or implemented interfaces.

This is most likely a typographical error or the method has been renamed.

Loading history...
85