]
Erwin Bolwidt commented on JBPM-2762:
-------------------------------------
I have a fair bit of knowledge about xml namespaces and schemas (blast from the past.. not
done much with it recently) so I'll have a go at JBPM-2166. It'll take some time
to come up with something useful though.
XML Schema Validation errors in jpdl files don't get reported
when deploying them
---------------------------------------------------------------------------------
Key: JBPM-2762
URL:
https://jira.jboss.org/jira/browse/JBPM-2762
Project: jBPM
Issue Type: Bug
Security Level: Public(Everyone can see)
Components: Runtime Engine
Affects Versions: jBPM 4.3, jBPM 4.2
Reporter: Erwin Bolwidt
Priority: Minor
When I deploy an invalid JPDL file (take a valid file, add <abc/> at some random
location, voila) through the RepositoryService, the deployment succeeds. I can see that
the validation error is reported internally, but an exception is not thrown.
It is also not possible for the caller to determine that there was a validation error,
unless the caller is willing to cast NewDeployment to DeploymentImpl and invoke the
methods from the ProblemList superclass.
The thing is, DeployerManager (line 49, jbpm 4.3) checks that there haven't been any
errors using ProblemList#hasErrors(). And ProblemList#hasErrors() returns true if there is
at least one problem with severity ProblemImpl.TYPE_ERROR. However, validation errors are
reported with severity ProblemImpl.TYPE_XML_VALIDATION_ERROR.
Of course I don't know the reasons why the developer of this code choose this
implementation, but to me it seems that this was an oversight and the hasErrors() should
have checked for TYPE_XML_VALIDATION_ERROR as well.
I haven't had a chance yet to see how a process definition with an invalid jpdl file
functions in practice, but it doesn't seem right that you can deploy an incorrect
process definition.
And if it was right, for some reason, then I think the caller should have a chance to
find out, so in that case the interface NewDeployment could be extended with methods to
retrieve any problems during deployment.
--
This message is automatically generated by JIRA.
-
If you think it was sent incorrectly contact one of the administrators: