mirror of
https://github.com/justinrainbow/json-schema.git
synced 2025-05-02 04:18:09 +02:00
* Add URI translation for retrieval & add local copies of spec schema * Add use line for InvalidArgumentException & adjust scope (#372) Fixes issue #371 * add quiet option (#382) * add quiet option * use verbose instead of quiet * add quiet option * always output dump-schema * always output dump-schema-url * fix typo and ws * [BUGFIX] Add provided schema under a dummy / internal URI (fixes #376) (#378) * Add provided schema under a dummy / internal URI (fixes #376) In order to resolve internal $ref references within a user-provided schema, SchemaStorage needs to know about the schema. As user-supplied schemas do not have an associated URI, use a dummy / internal one instead. * Remove dangling use * Change URI to class constant on SchemaStorage * Add option to disable validation of "format" constraint (#383) * Add more unit tests (#366) * Add test coverage for coercion API * Complete test coverage for SchemaStorage * Add test coverage for ObjectIterator * Add exception test for JsonPointer * MabeEnum\Enum appears to use singletons - add testing const * Don't check this line for coverage mbstring is on all test platforms, so this line will never be reached. * Add test for TypeConstraint::validateTypeNameWording() * Add test for exception on TypeConstraint::validateType() * PHPunit doesn't like an explanation with its @codeCoverageIgnore... * Add various tests for UriRetriever * Add tests for FileGetContents * Add tests for JsonSchema\Uri\Retrievers\Curl * Add missing bad-syntax test file * Restrict ignore to the exception line only * Fix exception scope * Allow the schema to be an associative array (#389) * Allow the schema to be an associative array Implements #388. * Use json_decode(json_encode()) for array -> object cast * Skip exception check on PHP versions < 5.5.0 * Skip test on HHVM, as it's happy to encode resources * Enable FILTER_FLAG_EMAIL_UNICODE for email format if present (#398) * Don't throw exceptions until after checking anyOf / oneOf (#394) Fixes #393 * Fix infinite recursion on some schemas when setting defaults (#359) (#365) * Don't try to fetch files that don't exist Throws an exception when the ref can't be resolved to a useful file URI, rather than waiting for something further down the line to fail after the fact. * Refactor defaults code to use LooseTypeCheck where appropriate * Test for not treating non-containers like arrays * Update comments * Rename variable for clarity * Add CHECK_MODE_ONLY_REQUIRED_DEFAULTS If CHECK_MODE_ONLY_REQUIRED_DEFAULTS is set, then only apply defaults if they are marked as required. * Workaround for $this scope issue on PHP-5.3 * Fix infinite recursion via $ref when applying defaults * Add missing second test for array case * Add test for setting a default value for null * Also fix infinite recursion via $ref for array defaults * Move nested closure into separate method * $parentSchema will always be set when $name is, so don't check it * Handle nulls properly - fixes issue #377 * Add option to also validate the schema (#357) * Remove stale files from #357 (obviated by #362) (#400) * Stop #386 sneaking in alongside another PR backport
171 lines
5.2 KiB
PHP
171 lines
5.2 KiB
PHP
<?php
|
|
|
|
/*
|
|
* This file is part of the JsonSchema package.
|
|
*
|
|
* For the full copyright and license information, please view the LICENSE
|
|
* file that was distributed with this source code.
|
|
*/
|
|
|
|
namespace JsonSchema\Tests\Constraints;
|
|
|
|
class DisallowTest extends BaseTestCase
|
|
{
|
|
// schemas in these tests look like draft-03, but the 'disallow' patterns provided are in
|
|
// violation of the spec - 'disallow' as defined in draft-03 accepts the same values as the
|
|
// 'type' option, and cannot take arbitrary patterns. The implementation in this library is
|
|
// probably deliberate, but noting that it's invalid, schema validation has been disabled
|
|
// for these tests. The 'disallow' option was removed permanently in draft-04.
|
|
protected $schemaSpec = 'http://json-schema.org/draft-03/schema#';
|
|
protected $validateSchema = false;
|
|
|
|
public function getInvalidTests()
|
|
{
|
|
return array(
|
|
array(
|
|
'{
|
|
"value":"The xpto is weird"
|
|
}',
|
|
'{
|
|
"type":"object",
|
|
"properties":{
|
|
"value":{
|
|
"type":"any",
|
|
"disallow":{"type":"string","pattern":"xpto"}
|
|
}
|
|
}
|
|
}'
|
|
),
|
|
array(
|
|
'{
|
|
"value":null
|
|
}',
|
|
'{
|
|
"type":"object",
|
|
"properties":{
|
|
"value":{
|
|
"type":"any",
|
|
"disallow":{"type":"null"}
|
|
}
|
|
}
|
|
}'
|
|
),
|
|
array(
|
|
'{"value": 1}',
|
|
'{
|
|
"type": "object",
|
|
"properties": {
|
|
"value": {"type": "any", "disallow": "integer"}
|
|
}
|
|
}'
|
|
),
|
|
array(
|
|
'{"value": true}',
|
|
'{
|
|
"type": "object",
|
|
"properties": {
|
|
"value": {"type": "any", "disallow": ["integer", "boolean"]}
|
|
}
|
|
}'
|
|
),
|
|
array(
|
|
'{"value": "foo"}',
|
|
'{
|
|
"type": "object",
|
|
"properties": {
|
|
"value": {
|
|
"type": "any",
|
|
"disallow":
|
|
["string", {
|
|
"type": "object",
|
|
"properties": {
|
|
"foo": {"type": "string"}
|
|
}
|
|
}]
|
|
}
|
|
}
|
|
}'
|
|
),
|
|
array(
|
|
'{"value": {"foo": "bar"}}',
|
|
'{
|
|
"type": "object",
|
|
"properties": {
|
|
"value": {
|
|
"type": "any",
|
|
"disallow":
|
|
["string", {
|
|
"type": "object",
|
|
"properties": {
|
|
"foo": {"type": "string"}
|
|
}
|
|
}]
|
|
}
|
|
}
|
|
}'
|
|
)
|
|
);
|
|
}
|
|
|
|
public function getValidTests()
|
|
{
|
|
return array(
|
|
array(
|
|
'{
|
|
"value":"The xpto is weird"
|
|
}',
|
|
'{
|
|
"type":"object",
|
|
"properties":{
|
|
"value":{
|
|
"type":"any",
|
|
"disallow":{"type":"string","pattern":"^xpto"}
|
|
}
|
|
}
|
|
}'
|
|
),
|
|
array(
|
|
'{
|
|
"value":1
|
|
}',
|
|
'{
|
|
"type":"object",
|
|
"properties":{
|
|
"value":{
|
|
"type":"any",
|
|
"disallow":{"type":"null"}
|
|
}
|
|
}
|
|
}'
|
|
),
|
|
array(
|
|
'{"value": {"foo": 1}}',
|
|
'{
|
|
"type": "object",
|
|
"properties": {
|
|
"value": {
|
|
"type": "any",
|
|
"disallow":
|
|
["string", {
|
|
"type": "object",
|
|
"properties": {
|
|
"foo": {"type": "string"}
|
|
}
|
|
}]
|
|
}
|
|
}
|
|
}'
|
|
),
|
|
array(
|
|
'{"value": true}',
|
|
'{
|
|
"type": "object",
|
|
"properties": {
|
|
"value": {"type": "any", "disallow": "string"}
|
|
}
|
|
}'
|
|
)
|
|
);
|
|
}
|
|
}
|