about summary refs log tree commit diff
path: root/elf/tst-audit16.c
blob: dd6ce189ea6fffa3a838a88ba5837378b634e7c7 (plain) (blame)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
/* Main program with DT_AUDIT and DT_DEPAUDIT.  Three audit modules.
   Copyright (C) 2020 Free Software Foundation, Inc.
   This file is part of the GNU C Library.

   The GNU C Library is free software; you can redistribute it and/or
   modify it under the terms of the GNU Lesser General Public
   License as published by the Free Software Foundation; either
   version 2.1 of the License, or (at your option) any later version.

   The GNU C Library is distributed in the hope that it will be useful,
   but WITHOUT ANY WARRANTY; without even the implied warranty of
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   Lesser General Public License for more details.

   You should have received a copy of the GNU Lesser General Public
   License along with the GNU C Library; if not, see
   <https://www.gnu.org/licenses/>.  */

#include <stdlib.h>
#include <string.h>
#include <support/check.h>
#include <support/xstdio.h>

static int
do_test (void)
{
  /* Verify what the audit modules have written.  This test assumes
     that standard output has been redirected to a regular file.  */
  FILE *fp = xfopen ("/dev/stdout", "r");

  char *buffer = NULL;
  size_t buffer_length = 0;
  size_t line_length = xgetline (&buffer, &buffer_length, fp);
  const char *message = "info: tst-auditlogmod-1.so loaded\n";
  TEST_COMPARE_BLOB (message, strlen (message), buffer, line_length);

  line_length = xgetline (&buffer, &buffer_length, fp);
  message = "info: tst-auditlogmod-2.so loaded\n";
  TEST_COMPARE_BLOB (message, strlen (message), buffer, line_length);

  line_length = xgetline (&buffer, &buffer_length, fp);
  message = "info: tst-auditlogmod-3.so loaded\n";
  TEST_COMPARE_BLOB (message, strlen (message), buffer, line_length);

  /* No more audit module output.  */
  line_length = xgetline (&buffer, &buffer_length, fp);
  TEST_COMPARE_BLOB ("", 0, buffer, line_length);

  free (buffer);
  xfclose (fp);
  return 0;
}

#include <support/test-driver.c>