File: logtest.c

package info (click to toggle)
tinyssh 20230101-1
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 2,244 kB
  • sloc: ansic: 12,106; sh: 1,168; python: 479; makefile: 42
file content (121 lines) | stat: -rw-r--r-- 2,591 bytes parent folder | download | duplicates (4)
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
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
/*
20140319
Jan Mojzis
Public domain.
*/

#include <sys/types.h>
#include <sys/wait.h>
#include <unistd.h>
#include <stdio.h>
#include "fail.h"
#include "byte.h"
#include "log.h"

static int readall(int fd, unsigned char *x, long long xlen) {

    long long r;
    long long len = 0;

    while (xlen > 0) {
        r = read(fd, x, xlen);
        if (r == 0) break;
        if (r <= 0) return -1;
        x += r;
        len += r;
        xlen -= r;
    }
    return len;
}

static unsigned char buf[1024];

#define LINE_EXP "?????????\n????????????????????? !\"#$%&'()*+,-./0123456789:;<=>?@ABCDEFGHIJKLMNOPQRSTUVWXYZ[\\]^_`abcdefghijklmnopqrstuvwxyz{|}~?????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????????"
static void run(void (*op)(void)) {

    pid_t pid;
    int status, fromchild[2];
    long long r, i, j;

    if (pipe(fromchild) == -1) fail("pipe() failure");
    pid = fork();
    if (pid == -1) fail("fork() failure");
    if (pid == 0) {
        close(fromchild[0]);
        if (dup2(fromchild[1], 2) == -1) _exit(111);
        op();
        _exit(0);
    }
    close(fromchild[1]);
    r = readall(fromchild[0], buf, sizeof buf);
    if (r == -1) fail("read() failure");

    j = 0;
    for (i = 0; i < r; ++i) {
        if (buf[i] == ' ') ++j;
        if (j == 3) break;
    }
    r -= i + 1;
    byte_copy(buf, r, buf + i + 1);

    for (r = r - 1; r > 0; --r) {
        if (buf[r] == ' ') { 
            buf[r] = 0;
            break;
        }
    }

    while (waitpid(pid, &status, 0) != pid) {};
    if (!WIFEXITED(status)) fail("process killed");
    if (WEXITSTATUS(status)) fail("process exited with status != 0");

    if (r < sizeof(LINE_EXP) - 1) fail("failure");
    if (!byte_isequal(buf, sizeof(LINE_EXP) - 1, LINE_EXP)) fail("failure");
}

static char line[256];

static void feed(void) {
    unsigned long long i;
    for (i = 0; i < 256; ++i) line[i] = (unsigned char)(i + 1);
}

static void test_fatal(void) {
    log_init(0, "x", 1, 0);
    log_d1("hidden");
    log_i1("hidden");
    log_w1("hidden");
    log_f1(line);
}

static void test_warning(void) {
    log_init(1, "x", 1, 0);
    log_d1("hidden");
    log_i1("hidden");
    log_w1(line);
}

static void test_info(void) {
    log_init(1, "x", 1, 0);
    log_d1("hidden");
    log_i1(line);
}

static void test_debug(void) {
    log_init(2, "x", 1, 0);
    log_d1(line);
}


int main(void) {

    return 0;
    feed();

    run(test_fatal);
    run(test_warning);
    run(test_info);
    run(test_debug);

    _exit(0);
}