summaryrefslogtreecommitdiff
path: root/tests/gtest_dlt_json_filter.cpp
blob: 8cdd98a3eb3cd4a7da0158003310fc3fe3761417 (plain)
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
#include <stdio.h>
#include <gtest/gtest.h>
#include <limits.h>
#include <syslog.h>

extern "C"
{
    #include "dlt-control-common.h"
    #include "dlt-daemon.h"
}

/* Begin Method: dlt_common::dlt_message_print_ascii with json filter*/
TEST(t_dlt_message_print_ascii_with_json_filter, normal)
{
    DltFile file;
    DltFilter filter;
    static char text[DLT_DAEMON_TEXTSIZE];

    /* Get PWD so file can be used*/
    char pwd[100];
    char openfile[114];

    /* ignore returned value from getcwd */
    if (getcwd(pwd, 100) == NULL) {}

    char openfilter[117];
    sprintf(openfile, "%s/testfile_extended.dlt", pwd);
    sprintf(openfilter, "%s/testfilter.json", pwd);
    /*---------------------------------------*/

    /* Normal Use-Case, expect 0 */
    EXPECT_LE(DLT_RETURN_OK, dlt_file_init(&file, 0));
    EXPECT_LE(DLT_RETURN_OK, dlt_filter_init(&filter, 0));
    EXPECT_LE(DLT_RETURN_OK, dlt_json_filter_load(&filter, openfilter, 0));
    EXPECT_LE(DLT_RETURN_OK, dlt_file_set_filter(&file, &filter, 0));
    EXPECT_LE(DLT_RETURN_OK, dlt_file_open(&file, openfile, 0));

    char tmp[DLT_ID_SIZE+1];
    strncpy(tmp, filter.apid[0], DLT_ID_SIZE);
    tmp[DLT_ID_SIZE] = {};
    EXPECT_STREQ("LOG",tmp);
    EXPECT_EQ(3,filter.log_level[0]);
    EXPECT_EQ(0,filter.payload_min[0]);
    EXPECT_EQ(INT32_MAX,filter.payload_max[0]);


    strncpy(tmp, filter.apid[1], DLT_ID_SIZE);
    EXPECT_STREQ("app",tmp);
    strncpy(tmp, filter.ctid[1], DLT_ID_SIZE);
    EXPECT_STREQ("",tmp);

    EXPECT_EQ(0,filter.log_level[2]);
    EXPECT_EQ(20,filter.payload_min[2]);
    EXPECT_EQ(50,filter.payload_max[2]);

    while (dlt_file_read(&file, 0) >= 0) {}

    for (int i = 0; i < file.counter; i++) {
        EXPECT_LE(DLT_RETURN_OK, dlt_file_message(&file, i, 0));
        EXPECT_LE(DLT_RETURN_OK, dlt_message_print_ascii(&file.msg, text, DLT_DAEMON_TEXTSIZE, 0));
    }

    for (int i = 0; i < file.counter; i++) {
        EXPECT_LE(DLT_RETURN_OK, dlt_file_message(&file, i, 0));
        EXPECT_LE(DLT_RETURN_OK, dlt_message_print_ascii(&file.msg, text, DLT_DAEMON_TEXTSIZE, 1));
    }

    EXPECT_LE(DLT_RETURN_OK, dlt_file_free(&file, 0));
}
TEST(t_dlt_message_print_ascii_with_json_filter, abnormal)
{
    /* equal with t_dlt_message_print_ascii */
}
TEST(t_dlt_message_print_ascii_with_json_filter, nullpointer)
{
    /* equal with t_dlt_message_print_ascii */
}
/* End Method: dlt_common::dlt_message_print_ascii with json filter*/