Blame gnulib-tests/test-fgetc.c

Packit 33f14e
/* Test of fgetc() function.
Packit 33f14e
   Copyright (C) 2011-2017 Free Software Foundation, Inc.
Packit 33f14e
Packit 33f14e
   This program is free software; you can redistribute it and/or modify
Packit 33f14e
   it under the terms of the GNU General Public License as published by
Packit 33f14e
   the Free Software Foundation; either version 3, or (at your option)
Packit 33f14e
   any later version.
Packit 33f14e
Packit 33f14e
   This program is distributed in the hope that it will be useful,
Packit 33f14e
   but WITHOUT ANY WARRANTY; without even the implied warranty of
Packit 33f14e
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
Packit 33f14e
   GNU General Public License for more details.
Packit 33f14e
Packit 33f14e
   You should have received a copy of the GNU General Public License
Packit 33f14e
   along with this program; if not, see <http://www.gnu.org/licenses/>.  */
Packit 33f14e
Packit 33f14e
#include <config.h>
Packit 33f14e
Packit 33f14e
#include <stdio.h>
Packit 33f14e
Packit 33f14e
#include "signature.h"
Packit 33f14e
SIGNATURE_CHECK (fgetc, int, (FILE *));
Packit 33f14e
Packit 33f14e
#include <errno.h>
Packit 33f14e
#include <fcntl.h>
Packit 33f14e
#include <unistd.h>
Packit 33f14e
Packit 33f14e
#if HAVE_MSVC_INVALID_PARAMETER_HANDLER
Packit 33f14e
# include "msvc-inval.h"
Packit 33f14e
#endif
Packit 33f14e
Packit 33f14e
#include "macros.h"
Packit 33f14e
Packit 33f14e
int
Packit 33f14e
main (int argc, char **argv)
Packit 33f14e
{
Packit 33f14e
  const char *filename = "test-fgetc.txt";
Packit 33f14e
Packit 33f14e
  /* We don't have an fgetc() function that installs an invalid parameter
Packit 33f14e
     handler so far.  So install that handler here, explicitly.  */
Packit 33f14e
#if HAVE_MSVC_INVALID_PARAMETER_HANDLER \
Packit 33f14e
    && MSVC_INVALID_PARAMETER_HANDLING == DEFAULT_HANDLING
Packit 33f14e
  gl_msvc_inval_ensure_handler ();
Packit 33f14e
#endif
Packit 33f14e
Packit 33f14e
  /* Prepare a file.  */
Packit 33f14e
  {
Packit 33f14e
    const char text[] = "hello world";
Packit 33f14e
    int fd = open (filename, O_RDWR | O_CREAT | O_TRUNC, 0600);
Packit 33f14e
    ASSERT (fd >= 0);
Packit 33f14e
    ASSERT (write (fd, text, sizeof (text)) == sizeof (text));
Packit 33f14e
    ASSERT (close (fd) == 0);
Packit 33f14e
  }
Packit 33f14e
Packit 33f14e
  /* Test that fgetc() sets errno if someone else closes the stream
Packit 33f14e
     fd behind the back of stdio.  */
Packit 33f14e
  {
Packit 33f14e
    FILE *fp = fopen (filename, "r");
Packit 33f14e
    ASSERT (fp != NULL);
Packit 33f14e
    ASSERT (close (fileno (fp)) == 0);
Packit 33f14e
    errno = 0;
Packit 33f14e
    ASSERT (fgetc (fp) == EOF);
Packit 33f14e
    ASSERT (errno == EBADF);
Packit 33f14e
    ASSERT (ferror (fp));
Packit 33f14e
    fclose (fp);
Packit 33f14e
  }
Packit 33f14e
Packit 33f14e
  /* Test that fgetc() sets errno if the stream was constructed with
Packit 33f14e
     an invalid file descriptor.  */
Packit 33f14e
  {
Packit 33f14e
    FILE *fp = fdopen (-1, "r");
Packit 33f14e
    if (fp != NULL)
Packit 33f14e
      {
Packit 33f14e
        errno = 0;
Packit 33f14e
        ASSERT (fgetc (fp) == EOF);
Packit 33f14e
        ASSERT (errno == EBADF);
Packit 33f14e
        ASSERT (ferror (fp));
Packit 33f14e
        fclose (fp);
Packit 33f14e
      }
Packit 33f14e
  }
Packit 33f14e
  {
Packit 33f14e
    FILE *fp;
Packit 33f14e
    close (99);
Packit 33f14e
    fp = fdopen (99, "r");
Packit 33f14e
    if (fp != NULL)
Packit 33f14e
      {
Packit 33f14e
        errno = 0;
Packit 33f14e
        ASSERT (fgetc (fp) == EOF);
Packit 33f14e
        ASSERT (errno == EBADF);
Packit 33f14e
        ASSERT (ferror (fp));
Packit 33f14e
        fclose (fp);
Packit 33f14e
      }
Packit 33f14e
  }
Packit 33f14e
Packit 33f14e
  /* Clean up.  */
Packit 33f14e
  unlink (filename);
Packit 33f14e
Packit 33f14e
  return 0;
Packit 33f14e
}