2013-02-09 04:39:44 +04:00
/*-*- Mode: C; c-basic-offset: 8; indent-tabs-mode: nil -*-*/
/***
This file is part of systemd .
Copyright 2013 Thomas H . P . Andersen
systemd 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 .
systemd 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 systemd ; If not , see < http : //www.gnu.org/licenses/>.
* * */
# include <stdlib.h>
# include <string.h>
# include "strbuf.h"
# include "strv.h"
# include "util.h"
static ssize_t add_string ( struct strbuf * sb , const char * s ) {
return strbuf_add_string ( sb , s , strlen ( s ) ) ;
}
static void test_strbuf ( void ) {
struct strbuf * sb ;
2013-02-11 00:56:03 +04:00
_cleanup_strv_free_ char * * l ;
2013-02-09 04:39:44 +04:00
ssize_t a , b , c , d , e , f , g ;
sb = strbuf_new ( ) ;
a = add_string ( sb , " waldo " ) ;
b = add_string ( sb , " foo " ) ;
c = add_string ( sb , " bar " ) ;
d = add_string ( sb , " waldo " ) ; /* duplicate */
e = add_string ( sb , " aldo " ) ; /* duplicate */
f = add_string ( sb , " do " ) ; /* duplicate */
g = add_string ( sb , " waldorf " ) ; /* not a duplicate: matches from tail */
/* check the content of the buffer directly */
l = strv_parse_nulstr ( sb - > buf , sb - > len ) ;
2014-10-05 01:51:45 +04:00
assert_se ( streq ( l [ 0 ] , " " ) ) ; /* root*/
assert_se ( streq ( l [ 1 ] , " waldo " ) ) ;
assert_se ( streq ( l [ 2 ] , " foo " ) ) ;
assert_se ( streq ( l [ 3 ] , " bar " ) ) ;
assert_se ( streq ( l [ 4 ] , " waldorf " ) ) ;
2013-02-09 04:39:44 +04:00
2014-10-05 01:51:45 +04:00
assert_se ( sb - > nodes_count = = 5 ) ; /* root + 4 non-duplicates */
assert_se ( sb - > dedup_count = = 3 ) ;
assert_se ( sb - > in_count = = 7 ) ;
2013-02-09 04:39:44 +04:00
2014-10-05 01:51:45 +04:00
assert_se ( sb - > in_len = = 29 ) ; /* length of all strings added */
assert_se ( sb - > dedup_len = = 11 ) ; /* length of all strings duplicated */
assert_se ( sb - > len = = 23 ) ; /* buffer length: in - dedup + \0 for each node */
2013-02-09 04:39:44 +04:00
/* check the returned offsets and the respective content in the buffer */
2014-10-05 01:51:45 +04:00
assert_se ( a = = 1 ) ;
assert_se ( b = = 7 ) ;
assert_se ( c = = 11 ) ;
assert_se ( d = = 1 ) ;
assert_se ( e = = 2 ) ;
assert_se ( f = = 4 ) ;
assert_se ( g = = 15 ) ;
assert_se ( streq ( sb - > buf + a , " waldo " ) ) ;
assert_se ( streq ( sb - > buf + b , " foo " ) ) ;
assert_se ( streq ( sb - > buf + c , " bar " ) ) ;
assert_se ( streq ( sb - > buf + d , " waldo " ) ) ;
assert_se ( streq ( sb - > buf + e , " aldo " ) ) ;
assert_se ( streq ( sb - > buf + f , " do " ) ) ;
assert_se ( streq ( sb - > buf + g , " waldorf " ) ) ;
2013-02-09 04:39:44 +04:00
strbuf_complete ( sb ) ;
2014-10-05 01:51:45 +04:00
assert_se ( sb - > root = = NULL ) ;
2013-02-09 04:39:44 +04:00
strbuf_cleanup ( sb ) ;
}
2013-12-04 01:27:45 +04:00
int main ( int argc , const char * argv [ ] ) {
2013-02-09 04:39:44 +04:00
test_strbuf ( ) ;
return 0 ;
}