diff --git a/Makefile.am b/Makefile.am index ffccd44a..7c27737d 100644 --- a/Makefile.am +++ b/Makefile.am @@ -139,7 +139,7 @@ update-manpage: $(top_srcdir)/doc/rofi-manpage.markdown ## # Rofi test program ## -check_PROGRAMS=history_test textbox_test helper_test helper_expand +check_PROGRAMS=history_test textbox_test helper_test helper_expand helper_config_cmdline_parser history_test_CFLAGS=\ $(AM_CFLAGS)\ @@ -251,10 +251,26 @@ helper_expand_CFLAGS=${helper_test_CFLAGS} helper_expand_LDADD=${helper_test_LDADD} +helper_config_cmdline_parser_CFLAGS=${helper_test_CFLAGS} + +helper_config_cmdline_parser_LDADD=${helper_test_LDADD} +helper_config_cmdline_parser_SOURCES=\ + config/config.c\ + include/rofi.h\ + include/mode.h\ + include/mode-private.h\ + source/helper.c\ + include/helper.h\ + include/xrmoptions.h\ + source/xrmoptions.c\ + source/x11-helper.c\ + test/helper-config-cmdline-parser.c + TESTS=\ history_test\ helper_test\ - helper_expand + helper_expand\ + helper_config_cmdline_parser .PHONY: test-x test-x: $(bin_PROGRAMS) textbox_test diff --git a/test/helper-config-cmdline-parser.c b/test/helper-config-cmdline-parser.c new file mode 100644 index 00000000..861b43bf --- /dev/null +++ b/test/helper-config-cmdline-parser.c @@ -0,0 +1,63 @@ +#include +#include +#include +#include +#include +#include +#include +#include "xcb-internal.h" +#include "rofi.h" +#include "settings.h" + +static int test = 0; +struct xcb_stuff *xcb; + +#define TASSERT( a ) { \ + assert ( a ); \ + printf ( "Test %i passed (%s)\n", ++test, # a ); \ +} +#define TASSERTE( a, b ) { \ + if ( ( a ) == ( b ) ) { \ + printf ( "Test %i passed (%s == %s) (%u == %u)\n", ++test, # a, # b, a, b ); \ + }else { \ + printf ( "Test %i failed (%s == %s) (%u != %u)\n", ++test, # a, # b, a, b ); \ + abort ( ); \ + } \ +} + +int rofi_view_error_dialog ( const char *msg, G_GNUC_UNUSED int markup ) +{ + fputs ( msg, stderr ); + return TRUE; +} + +int show_error_message ( const char *msg, int markup ) +{ + rofi_view_error_dialog ( msg, markup ); + return 0; +} + +int main ( int argc, char ** argv ) +{ + + if ( setlocale ( LC_ALL, "" ) == NULL ) { + fprintf ( stderr, "Failed to set locale.\n" ); + return EXIT_FAILURE; + } + char **list = NULL; + int llength = 0; + char * test_str = + "{host} {terminal} -e bash -c \"{ssh-client} {host}; echo '{terminal} {host}'\""; + helper_parse_setup ( test_str, &list, &llength, "{host}", "chuck", + "{terminal}", "x-terminal-emulator", NULL ); + + TASSERT ( llength == 6 ); + TASSERT ( strcmp ( list[0], "chuck" ) == 0 ); + TASSERT ( strcmp ( list[1], "x-terminal-emulator" ) == 0 ); + TASSERT ( strcmp ( list[2], "-e" ) == 0 ); + TASSERT ( strcmp ( list[3], "bash" ) == 0 ); + TASSERT ( strcmp ( list[4], "-c" ) == 0 ); + TASSERT ( strcmp ( list[5], "ssh chuck; echo 'x-terminal-emulator chuck'" ) == 0 ); + g_strfreev ( list ); + +} diff --git a/test/helper-test.c b/test/helper-test.c index 00de4d19..425cef06 100644 --- a/test/helper-test.c +++ b/test/helper-test.c @@ -49,21 +49,6 @@ int main ( int argc, char ** argv ) fprintf ( stderr, "Failed to set locale.\n" ); return EXIT_FAILURE; } - char **list = NULL; - int llength = 0; - char * test_str = - "{host} {terminal} -e bash -c \"{ssh-client} {host}; echo '{terminal} {host}'\""; - helper_parse_setup ( test_str, &list, &llength, "{host}", "chuck", - "{terminal}", "x-terminal-emulator", NULL ); - - TASSERT ( llength == 6 ); - TASSERT ( strcmp ( list[0], "chuck" ) == 0 ); - TASSERT ( strcmp ( list[1], "x-terminal-emulator" ) == 0 ); - TASSERT ( strcmp ( list[2], "-e" ) == 0 ); - TASSERT ( strcmp ( list[3], "bash" ) == 0 ); - TASSERT ( strcmp ( list[4], "-c" ) == 0 ); - TASSERT ( strcmp ( list[5], "ssh chuck; echo 'x-terminal-emulator chuck'" ) == 0 ); - g_strfreev ( list ); /** * Collating.