LCOV - code coverage report
Current view: top level - journal - test-journal-send.c (source / functions) Hit Total Coverage
Test: systemd_full.info Lines: 28 28 100.0 %
Date: 2019-08-23 13:36:53 Functions: 1 1 100.0 %
Legend: Lines: hit not hit | Branches: + taken - not taken # not executed Branches: 16 32 50.0 %

           Branch data     Line data    Source code
       1                 :            : /* SPDX-License-Identifier: LGPL-2.1+ */
       2                 :            : 
       3                 :            : #include <errno.h>
       4                 :            : #include <stdlib.h>
       5                 :            : #include <unistd.h>
       6                 :            : 
       7                 :            : #include "sd-journal.h"
       8                 :            : 
       9                 :            : #include "macro.h"
      10                 :            : 
      11                 :          4 : int main(int argc, char *argv[]) {
      12                 :            :         char huge[4096*1024];
      13                 :            : 
      14                 :            :         /* utf-8 and non-utf-8, message-less and message-ful iovecs */
      15                 :          4 :         struct iovec graph1[] = {
      16                 :            :                 {(char*) "GRAPH=graph", STRLEN("GRAPH=graph")}
      17                 :            :         };
      18                 :          4 :         struct iovec graph2[] = {
      19                 :            :                 {(char*) "GRAPH=graph\n", STRLEN("GRAPH=graph\n")}
      20                 :            :         };
      21                 :          4 :         struct iovec message1[] = {
      22                 :            :                 {(char*) "MESSAGE=graph", STRLEN("MESSAGE=graph")}
      23                 :            :         };
      24                 :          4 :         struct iovec message2[] = {
      25                 :            :                 {(char*) "MESSAGE=graph\n", STRLEN("MESSAGE=graph\n")}
      26                 :            :         };
      27                 :            : 
      28         [ -  + ]:          4 :         assert_se(sd_journal_print(LOG_INFO, "piepapo") == 0);
      29                 :            : 
      30         [ -  + ]:          4 :         assert_se(sd_journal_send("MESSAGE=foobar",
      31                 :            :                                   "VALUE=%i", 7,
      32                 :            :                                   NULL) == 0);
      33                 :            : 
      34                 :          4 :         errno = ENOENT;
      35         [ -  + ]:          4 :         assert_se(sd_journal_perror("Foobar") == 0);
      36                 :            : 
      37         [ -  + ]:          4 :         assert_se(sd_journal_perror("") == 0);
      38                 :            : 
      39                 :          4 :         memset(huge, 'x', sizeof(huge));
      40                 :          4 :         memcpy(huge, "HUGE=", 5);
      41                 :          4 :         char_array_0(huge);
      42                 :            : 
      43         [ -  + ]:          4 :         assert_se(sd_journal_send("MESSAGE=Huge field attached",
      44                 :            :                                   huge,
      45                 :            :                                   NULL) == 0);
      46                 :            : 
      47         [ -  + ]:          4 :         assert_se(sd_journal_send("MESSAGE=uiui",
      48                 :            :                                   "VALUE=A",
      49                 :            :                                   "VALUE=B",
      50                 :            :                                   "VALUE=C",
      51                 :            :                                   "SINGLETON=1",
      52                 :            :                                   "OTHERVALUE=X",
      53                 :            :                                   "OTHERVALUE=Y",
      54                 :            :                                   "WITH_BINARY=this is a binary value \a",
      55                 :            :                                   NULL) == 0);
      56                 :            : 
      57                 :          4 :         syslog(LOG_NOTICE, "Hello World!");
      58                 :            : 
      59         [ -  + ]:          4 :         assert_se(sd_journal_print(LOG_NOTICE, "Hello World") == 0);
      60                 :            : 
      61         [ -  + ]:          4 :         assert_se(sd_journal_send("MESSAGE=Hello World!",
      62                 :            :                                   "MESSAGE_ID=52fb62f99e2c49d89cfbf9d6de5e3555",
      63                 :            :                                   "PRIORITY=5",
      64                 :            :                                   "HOME=%s", getenv("HOME"),
      65                 :            :                                   "TERM=%s", getenv("TERM"),
      66                 :            :                                   "PAGE_SIZE=%li", sysconf(_SC_PAGESIZE),
      67                 :            :                                   "N_CPUS=%li", sysconf(_SC_NPROCESSORS_ONLN),
      68                 :            :                                   NULL) == 0);
      69                 :            : 
      70         [ -  + ]:          4 :         assert_se(sd_journal_sendv(graph1, 1) == 0);
      71         [ -  + ]:          4 :         assert_se(sd_journal_sendv(graph2, 1) == 0);
      72         [ -  + ]:          4 :         assert_se(sd_journal_sendv(message1, 1) == 0);
      73         [ -  + ]:          4 :         assert_se(sd_journal_sendv(message2, 1) == 0);
      74                 :            : 
      75                 :            :         /* test without location fields */
      76                 :            : #undef sd_journal_sendv
      77         [ -  + ]:          4 :         assert_se(sd_journal_sendv(graph1, 1) == 0);
      78         [ -  + ]:          4 :         assert_se(sd_journal_sendv(graph2, 1) == 0);
      79         [ -  + ]:          4 :         assert_se(sd_journal_sendv(message1, 1) == 0);
      80         [ -  + ]:          4 :         assert_se(sd_journal_sendv(message2, 1) == 0);
      81                 :            : 
      82                 :          4 :         sleep(1);
      83                 :            : 
      84                 :          4 :         return 0;
      85                 :            : }

Generated by: LCOV version 1.14