I’m testing the existence of a file in a remote share (on a Windows server). The underlying function used for testing is WinAPI’s GetFileAttributes, and what happens is that function can take an inordinate amount of time (dozens of seconds) in various situations, like when the target server being offline, when there are rights or DNS issues, etc.
However, in my particular case, it’s always a LAN access, so if the file can’t be accessed in less than 1 second, then it typically won’t be accessible by waiting dozens of seconds more…
Is there an alternative to GetFileAttributes that wouldn’t stall? (apart from calling it in a thread and killing the thread after a timeout, which seems to bring its own bag of issues)
The problem isn’t GetFileAttributes really. It typically uses just one call to the underlying file system driver. It’s that IO which is stalling.
Still, the solution is probably easy. Call CancelSynchronousIo() after one second (this obviously requires a second thread as your first is stuck inside GetFileAttributes).