]>
git.proxmox.com Git - systemd.git/blob - src/journal/test-catalog.c
1 /*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
4 This file is part of systemd.
6 Copyright 2012 Lennart Poettering
7 Copyright 2013 Zbigniew Jędrzejewski-Szmek
9 systemd is free software; you can redistribute it and/or modify it
10 under the terms of the GNU Lesser General Public License as published by
11 the Free Software Foundation; either version 2.1 of the License, or
12 (at your option) any later version.
14 systemd is distributed in the hope that it will be useful, but
15 WITHOUT ANY WARRANTY; without even the implied warranty of
16 MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
17 Lesser General Public License for more details.
19 You should have received a copy of the GNU Lesser General Public License
20 along with systemd; If not, see <http://www.gnu.org/licenses/>.
32 #include "sd-messages.h"
35 static const char *catalog_dirs
[] = {
40 static const char *no_catalog_dirs
[] = {
41 "/bin/hopefully/with/no/catalog",
45 static void test_import(Hashmap
*h
, struct strbuf
*sb
,
46 const char* contents
, ssize_t size
, int code
) {
48 char name
[] = "/tmp/test-catalog.XXXXXX";
49 _cleanup_close_
int fd
;
51 fd
= mkostemp_safe(name
, O_RDWR
|O_CLOEXEC
);
53 assert_se(write(fd
, contents
, size
) == size
);
55 r
= catalog_import_file(h
, sb
, name
);
61 static void test_catalog_importing(void) {
65 assert_se(h
= hashmap_new(&catalog_hash_ops
));
66 assert_se(sb
= strbuf_new());
69 test_import(h
, sb
, BUF
, sizeof(BUF
), -EINVAL
);
71 assert(hashmap_isempty(h
));
72 log_debug("----------------------------------------");
75 "-- 0027229ca0644181a76c4e92458afaff dededededededededededededededede\n" \
76 "Subject: message\n" \
79 test_import(h
, sb
, BUF
, sizeof(BUF
), -EINVAL
);
82 log_debug("----------------------------------------");
85 "-- 0027229ca0644181a76c4e92458afaff dededededededededededededededed\n" \
86 "Subject: message\n" \
89 test_import(h
, sb
, BUF
, sizeof(BUF
), 0);
92 assert(hashmap_size(h
) == 1);
94 log_debug("----------------------------------------");
101 static const char* database
= NULL
;
103 static void test_catalog_update(void) {
104 static char name
[] = "/tmp/test-catalog.XXXXXX";
107 r
= mkostemp_safe(name
, O_RDWR
|O_CLOEXEC
);
112 /* Test what happens if there are no files. */
113 r
= catalog_update(database
, NULL
, NULL
);
116 /* Test what happens if there are no files in the directory. */
117 r
= catalog_update(database
, NULL
, no_catalog_dirs
);
120 /* Make sure that we at least have some files loaded or the
121 catalog_list below will fail. */
122 r
= catalog_update(database
, NULL
, catalog_dirs
);
126 static void test_catalog_file_lang(void) {
127 _cleanup_free_
char *lang
= NULL
, *lang2
= NULL
, *lang3
= NULL
, *lang4
= NULL
;
129 assert_se(catalog_file_lang("systemd.de_DE.catalog", &lang
) == 1);
130 assert_se(streq(lang
, "de_DE"));
132 assert_se(catalog_file_lang("systemd..catalog", &lang2
) == 0);
133 assert_se(lang2
== NULL
);
135 assert_se(catalog_file_lang("systemd.fr.catalog", &lang2
) == 1);
136 assert_se(streq(lang2
, "fr"));
138 assert_se(catalog_file_lang("systemd.fr.catalog.gz", &lang3
) == 0);
139 assert_se(lang3
== NULL
);
141 assert_se(catalog_file_lang("systemd.01234567890123456789012345678901.catalog", &lang3
) == 0);
142 assert_se(lang3
== NULL
);
144 assert_se(catalog_file_lang("systemd.0123456789012345678901234567890.catalog", &lang3
) == 1);
145 assert_se(streq(lang3
, "0123456789012345678901234567890"));
147 assert_se(catalog_file_lang("/x/y/systemd.catalog", &lang4
) == 0);
148 assert_se(lang4
== NULL
);
150 assert_se(catalog_file_lang("/x/y/systemd.ru_RU.catalog", &lang4
) == 1);
151 assert_se(streq(lang4
, "ru_RU"));
154 int main(int argc
, char *argv
[]) {
155 _cleanup_free_
char *text
= NULL
;
158 setlocale(LC_ALL
, "de_DE.UTF-8");
160 log_parse_environment();
163 test_catalog_file_lang();
165 test_catalog_importing();
167 test_catalog_update();
169 r
= catalog_list(stdout
, database
, true);
172 r
= catalog_list(stdout
, database
, false);
175 assert_se(catalog_get(database
, SD_MESSAGE_COREDUMP
, &text
) >= 0);
176 printf(">>>%s<<<\n", text
);