On 21/02/2018 4:28 PM, Jonathan Greenberg wrote:
Folks:
Consider the following two use cases:
goodfunction <- function()
{
stop("Something went wrong..."
}
# vs.
badfunction <- function()
{
notgood()
}
Is there a way for me to test if the functions make use of a stop()
statement WITHOUT modifying the stop() output (assume I can't mod the
function containing the stop() statement itself)? For "goodfunction" the
answer is TRUE, for "badfunction" the answer is FALSE. Both return an
error, but only one does it "safely".
I thought the answer might lie in a tryCatch statement but I'm having a
hard time figuring out how to do this test.
I think tryCatch() is what you want. To see the difference between
those two errors, run
tryCatch(goodfunction(), error = function(e) browser())
and similarly with badfunction(). When you land in the browser, you'll see
Browse[1]> str(e)
List of 2
$ message: chr "Something went wrong..."
$ call : language goodfunction()
- attr(*, "class")= chr [1:3] "simpleError" "error" "condition"
and
Browse[1]> str(e)
List of 2
$ message: chr "could not find function \"notgood\""
$ call : language notgood()
- attr(*, "class")= chr [1:3] "simpleError" "error" "condition"
so you could write a test based on the message, or based on the call to
see where the stop() happened.
Duncan Murdoch
______________________________________________
R-help@r-project.org mailing list -- To UNSUBSCRIBE and more, see
https://stat.ethz.ch/mailman/listinfo/r-help
PLEASE do read the posting guide http://www.R-project.org/posting-guide.html
and provide commented, minimal, self-contained, reproducible code.