Make SchemaValidator catch errors such as very invalid schema using only part of the primary key for join columns
This commit is contained in:
parent
3dc30dee11
commit
a82bffbfc9
1 changed files with 16 additions and 0 deletions
|
@ -152,6 +152,17 @@ class SchemaValidator
|
||||||
"has to be a primary key column.";
|
"has to be a primary key column.";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (count($targetClass->identifier) != count($assoc['joinTable']['inverseJoinColumns'])) {
|
||||||
|
$ce[] = "The inverse join columns of the many-to-many table '" . $assoc['joinTable']['name'] . "' " .
|
||||||
|
"have to match to ALL identifier columns of the target entity '". $targetClass->name . "'";
|
||||||
|
}
|
||||||
|
|
||||||
|
if (count($class->identifier) != count($assoc['joinTable']['joinColumns'])) {
|
||||||
|
$ce[] = "The join columns of the many-to-many table '" . $assoc['joinTable']['name'] . "' " .
|
||||||
|
"have to match to ALL identifier columns of the source entity '". $class->name . "'";
|
||||||
|
}
|
||||||
|
|
||||||
} else if ($assoc['type'] & ClassMetadataInfo::TO_ONE) {
|
} else if ($assoc['type'] & ClassMetadataInfo::TO_ONE) {
|
||||||
foreach ($assoc['joinColumns'] AS $joinColumn) {
|
foreach ($assoc['joinColumns'] AS $joinColumn) {
|
||||||
$targetClass = $cmf->getMetadataFor($assoc['targetEntity']);
|
$targetClass = $cmf->getMetadataFor($assoc['targetEntity']);
|
||||||
|
@ -167,6 +178,11 @@ class SchemaValidator
|
||||||
"has to be a primary key column.";
|
"has to be a primary key column.";
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
if (count($class->identifier) != count($assoc['joinColumns'])) {
|
||||||
|
$ce[] = "The join columns of the association '" . $assoc['fieldName'] . "' " .
|
||||||
|
"have to match to ALL identifier columns of the source entity '". $class->name . "'";
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
Loading…
Add table
Reference in a new issue