Hi Ari,

As I've mentioned offline, I think that if an exception message is set by the user, it may be a bad idea to clobber it (CayenneRuntimeException 'getMessage()' kind of does it too, doh!). The good news is that Cayenne internally uses a constructor without a message: "ValidationException(ValidationResult)", so we can use the code below to build an informative message:

private static String createMessage(ValidationResult result) {
   // Ari's code goes here
}

public ValidationException(ValidationResult result) {
   this(createMessage(result), result);
}

Do you think this'll work?

Andrus



On Jul 9, 2007, at 1:05 PM, Aristedes Maniatis wrote:

Validation exception messages in three tier are pretty unhelpful by the time they get to the client. We've been extending them by adding this to ValidationException:


    /**
* Returns message that includes the details of the validation failures.
     */
    public String getMessage() {
        String message = super.getMessage();
        if (result.hasFailures()) {
            message = message + " validation failures: ";
            for (int i = 0; i < result.getFailures().size(); i++) {
message = message + ((ValidationFailure) result.getFailures().get(i)).toString();
                if (i < result.getFailures().size() - 1) {
                    message = message + ", ";
                }
            }
        }
        return message;
    }


Any thoughts about side effects this might have for anyone?


As an aside, what would be even more helpful is if three tier returned not a CayenneRuntimeException, but a ValidationException to the client. I don't know if that is hard to change.


Ari





-------------------------->
ish
http://www.ish.com.au
Level 1, 30 Wilson Street Newtown 2042 Australia
phone +61 2 9550 5001   fax +61 2 9550 4001
GPG fingerprint CBFB 84B4 738D 4E87 5E5C  5EFA EF6A 7D2E 3E49 102A



Reply via email to