1 | <?php |
||
2 | /** |
||
3 | * This file is part of the MediaWiki extension Lingo. |
||
4 | * |
||
5 | * @copyright 2011 - 2016, Stephan Gambke |
||
6 | * @license GPL-2.0-or-later |
||
7 | * |
||
8 | * The Lingo extension is free software: you can redistribute it and/or modify |
||
9 | * it under the terms of the GNU General Public License as published by the Free |
||
10 | * Software Foundation; either version 2 of the License, or (at your option) any |
||
11 | * later version. |
||
12 | * |
||
13 | * The Lingo extension is distributed in the hope that it will be useful, but |
||
14 | * WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or |
||
15 | * FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more |
||
16 | * details. |
||
17 | * |
||
18 | * You should have received a copy of the GNU General Public License along |
||
19 | * with this program. If not, see <http://www.gnu.org/licenses/>. |
||
20 | * |
||
21 | * @author Stephan Gambke |
||
22 | * @since 2.0 |
||
23 | * @file |
||
24 | * @ingroup Lingo |
||
25 | */ |
||
26 | |||
27 | namespace Lingo\Tests\Unit; |
||
28 | |||
29 | /** |
||
30 | * @group extensions-lingo |
||
31 | * @group extensions-lingo-unit |
||
32 | * @group mediawiki-databaseless |
||
33 | * |
||
34 | * @ingroup Lingo |
||
35 | * @ingroup Test |
||
36 | */ |
||
37 | class LingoI18NTest extends \PHPUnit\Framework\TestCase { |
||
0 ignored issues
–
show
|
|||
38 | |||
39 | public function testJsonSchemaValidatorExists() { |
||
40 | $this->assertTrue( class_exists( '\JsonSchema\Validator' ) ); |
||
41 | $this->assertTrue( method_exists( '\JsonSchema\Validator', 'check' ) ); |
||
42 | } |
||
43 | |||
44 | public function testMagicWordsLoaded() { |
||
45 | // load magic words |
||
46 | require __DIR__ . '/../../../src/Lingo.i18n.magic.php'; |
||
47 | |||
48 | // assert $magicWords was created |
||
49 | $defined_vars = get_defined_vars(); |
||
50 | $this->assertArrayHasKey( 'magicWords', $defined_vars ); |
||
51 | |||
52 | // validate structure |
||
53 | |||
54 | $data = json_decode( json_encode( $defined_vars[ 'magicWords' ] ) ); |
||
55 | |||
56 | $validator = new \JsonSchema\Validator(); |
||
57 | $validator->check( $data, (object)[ '$ref' => |
||
58 | 'file://' . realpath( __DIR__ . '/../Fixture/magicWordsSchema.json' ) ] ); |
||
59 | |||
60 | // format error message |
||
61 | $errors = implode( '', array_map( |
||
62 | function ( $error ) { |
||
63 | return "* [{$error[ 'property' ]}] {$error[ 'message' ]}\n"; |
||
0 ignored issues
–
show
As per coding-style, please use concatenation or
sprintf for the variable $error instead of interpolation.
It is generally a best practice as it is often more readable to use concatenation instead of interpolation for variables inside strings. // Instead of
$x = "foo $bar $baz";
// Better use either
$x = "foo " . $bar . " " . $baz;
$x = sprintf("foo %s %s", $bar, $baz);
Loading history...
|
|||
64 | }, |
||
65 | $validator->getErrors() |
||
66 | ) ); |
||
67 | |||
68 | // assert structure is valid |
||
69 | $this->assertTrue( $validator->isValid(), "JSON does not validate. Violations:\n" . $errors ); |
||
70 | } |
||
71 | } |
||
72 |
The issue could also be caused by a filter entry in the build configuration. If the path has been excluded in your configuration, e.g.
excluded_paths: ["lib/*"]
, you can move it to the dependency path list as follows:For further information see https://scrutinizer-ci.com/docs/tools/php/php-scrutinizer/#list-dependency-paths