Skip to content

Better cleanup of example session during check

3 messages · Thomas Lin Pedersen, Duncan Murdoch

#
I have a couple of packages (?fiery? and ?reqres') that uses a mock of a rook request for their examples. The mock is an R6 object containing a rawConnection, along with a finalizer that closes this connection when the object is removed. So far so good. I?ve recently been getting CRAN errors due to the rawConnection not being closed in examples
Error: connections left open:
	content (rawConnection)

and the only way to remove this is by removing the objects and calling gc() as part of the example code. While it is possible to hide all that inside a \dontshow{} block, it appears to me that it would be better if cleanEx() did a cleaning of the environment along with a single gc call prior to performing any checks on the end state. Is this something you would consider?

best
Thomas Lin Pedersen
#
On 12/11/2018 8:09 AM, Thomas Lin Pedersen wrote:
Wouldn't it be possible for you to add a way to explicitly request the 
connection be closed?  Then the finalizer would only need to close it if 
you forgot.
This message was fine, but sometimes posting in HTML makes your message 
unreadable.  This list wants plain text.

Duncan Murdoch
#
On 12/11/2018 8:32 AM, Duncan Murdoch wrote:
After some private messages, it appears that having the example code 
explicitly remove the object is enough to satisfy the check.  Presumably 
this is because a garbage collection is happening before the error is 
issued, and it triggers the finalizer.

Duncan Murdoch