On Fri, Oct 31, 2014 at 1:20 PM, N.M. Maclaren <n...@cam.ac.uk> wrote: > On Oct 31 2014, Janne Blomqvist wrote: >> >> >> what would be the best way to test stuff like two binaries >> communicating via a pipe, FIFO or such with DejaGNU? The gfortran >> testsuite has by now quite extensive coverage of all the weird and >> quirky corner cases of Fortran I/O behavior, but practically all these >> tests are done using regular files. Over the years we've had some >> embarrassing bugs in handling non-seekable files like terminals, >> FIFO's, and pipes. I believe these would have been quickly caught if >> only we had testing coverage. > > > It's worse. It's much, much worse :-(
I know, being one of the main libgfortran IO maintainers for several years, I know more about the quirkyness of Fortran I/O than I ever would have wanted to.. :( My main aim here really is to just get the basics right before worrying about corner cases. For instance, I recall we have failed in a simple sequential reading of a access="sequential", form="formatted" unit connected to a pipe or such, because libgfortran incorrectly issued a lseek() at some point, which returned an error (since the fd wasn't seekable), and that error was then duly propagated upwards. But since the testsuite didn't test against this, it took an embarrassingly long time before that bug was found and fixed. > So the first question is to decide the priority of I/O variations, > including types of file and permitted operations for each connection > mode. The key characteristics (in OPEN) are ACCESS, FORM and ACTION. > In particular, there is disagreement on WG5 exactly what constitutes a > 'file' - I have been told that magnetic tape files and sockets are not > files by someone who ought to have known better. For example, does > gfortran intend to support the piping of unformatted files? Not all > compilers do. My argument in this, which I have stated many times on the mailing list and in bugzilla over the years, is that there are many kinds of special files which are special in different ways. E.g. wrt. seeking, some special files allow seeking just fine, others report an error, and others always report an offset of 0. Instead of trying to enumerate in which ways special files are special on all supported targets, which is a sisyphean task, libgfortran should just do what it's being told to, no more, and if any error occurs, propagate it upwards to the calling program. The "no more" is the problematic part, e.g. a spurious lseek(fd, 0, SEEK_CUR) would have have no effect on a regular file, but cause an error on a non-seekable file. Hence the need for a testsuite for non-regular files. >> (Something which works only on x86_64-unknown-linux-gnu and perhaps a >> few other "mainstream" targets where we can expect the presence of a >> "normal" shell environment etc., while not optimal, is certainly a lot >> better than what we have now.) > > > You can do a LOT better than THAT! It would be trivial to write > something that would work on any reasonably Unix-like system (including > anything that supports base POSIX 1996). I have done that for system > scripts and still do that for my course tests, though I no longer have > access to weird and wonderful Unices to test them. > > You are quite right that you need to assume a reasonable shell, though > you can write such tests that will work on pretty well any modern Bourne, > Korn or POSIX shell, and any version of bash. The original Bourne shell > was beyond redemption, but I believe that it is now completely dead. > That is from experience in writing portable system scripts a decade or > so back, but I am pretty sure it still holds. For what I'm thinking of, I'm sure a pretty basic POSIX sh + maybe a few utilities such as mkfifo would do just fine. My reason for wanting to limit it, is that I, and AFAIK most gfortran developers, develop and test on x86_64-unknown-linux-gnu, and with the very limited time that I can afford to gfortran these days I don't want to spend that time trying to debug-over-email why a script fails on some weird target I don't have access to. If you want to make it work on Ultrix or something like that, be my guest, patches welcome. (For a similar reason, I think it wouldn't make sense to run these tests in a cross environment, more complexity for little gain (unless it's really simple?).) -- Janne Blomqvist