1
1
mirror of https://github.com/profanity-im/profanity.git synced 2025-01-03 14:57:42 -05:00
profanity/tests/functionaltests/proftest.c

297 lines
6.9 KiB
C
Raw Normal View History

2015-05-16 20:11:03 -04:00
#include <sys/stat.h>
#include <glib.h>
2015-07-16 18:53:26 -04:00
#include "glib/gstdio.h"
2015-05-16 20:11:03 -04:00
#include <setjmp.h>
#include <stdarg.h>
#include <stddef.h>
#include <stdlib.h>
#include <cmocka.h>
#include <stdio.h>
#include <unistd.h>
2015-05-17 18:10:30 -04:00
#include <errno.h>
2015-05-26 18:22:05 -04:00
#include <string.h>
2015-05-16 20:11:03 -04:00
2015-05-23 19:56:13 -04:00
#include <stabber.h>
#include <tcl.h>
2015-05-26 18:22:05 -04:00
#include <expect.h>
#include <expect_tcl.h>
2015-05-28 14:01:49 -04:00
#include "proftest.h"
2015-05-16 20:11:03 -04:00
2015-05-23 19:56:13 -04:00
char *config_orig;
char *data_orig;
2015-05-26 20:06:17 -04:00
int fd = 0;
2015-05-16 20:11:03 -04:00
gboolean
_create_dir(char *name)
{
struct stat sb;
if (stat(name, &sb) != 0) {
if (errno != ENOENT || mkdir(name, S_IRWXU) != 0) {
return FALSE;
}
} else {
if ((sb.st_mode & S_IFDIR) != S_IFDIR) {
return FALSE;
}
}
return TRUE;
}
gboolean
_mkdir_recursive(const char *dir)
{
int i;
gboolean result = TRUE;
for (i = 1; i <= strlen(dir); i++) {
if (dir[i] == '/' || dir[i] == '\0') {
gchar *next_dir = g_strndup(dir, i);
2015-05-26 18:22:05 -04:00
result = _create_dir(next_dir);
2015-05-16 20:11:03 -04:00
g_free(next_dir);
if (!result) {
break;
}
}
}
return result;
}
void
_create_config_dir(void)
{
GString *profanity_dir = g_string_new(XDG_CONFIG_HOME);
g_string_append(profanity_dir, "/profanity");
if (!_mkdir_recursive(profanity_dir->str)) {
assert_true(FALSE);
}
g_string_free(profanity_dir, TRUE);
}
void
_create_data_dir(void)
{
GString *profanity_dir = g_string_new(XDG_DATA_HOME);
g_string_append(profanity_dir, "/profanity");
if (!_mkdir_recursive(profanity_dir->str)) {
assert_true(FALSE);
}
g_string_free(profanity_dir, TRUE);
}
void
_create_chatlogs_dir(void)
{
GString *chatlogs_dir = g_string_new(XDG_DATA_HOME);
g_string_append(chatlogs_dir, "/profanity/chatlogs");
if (!_mkdir_recursive(chatlogs_dir->str)) {
assert_true(FALSE);
}
g_string_free(chatlogs_dir, TRUE);
}
void
_create_logs_dir(void)
{
GString *logs_dir = g_string_new(XDG_DATA_HOME);
g_string_append(logs_dir, "/profanity/logs");
if (!_mkdir_recursive(logs_dir->str)) {
assert_true(FALSE);
}
g_string_free(logs_dir, TRUE);
}
void
_cleanup_dirs(void)
{
2015-06-13 14:41:11 -04:00
int res = system("rm -rf ./tests/functionaltests/files");
2015-05-17 18:10:30 -04:00
if (res == -1) {
assert_true(FALSE);
}
2015-05-16 20:11:03 -04:00
}
2015-05-28 13:50:55 -04:00
void
prof_start(void)
{
/* initialise expect and tcl */
Tcl_Interp *interp = Tcl_CreateInterp();
Tcl_Init(interp);
Expect_Init(interp);
2015-07-16 18:53:26 -04:00
FILE *logp = fopen("./expout.log", "a");
g_chmod("./expout.log", S_IRUSR | S_IWUSR);
exp_debugfile = logp;
// helper script sets terminal columns, avoids assertions failing
// based on the test runner terminal size
fd = exp_spawnl("sh",
"sh",
"-c",
"./tests/functionaltests/start_profanity.sh",
NULL);
2015-07-16 18:53:26 -04:00
2015-05-28 13:50:55 -04:00
FILE *fp = fdopen(fd, "r+");
assert_true(fp != NULL);
2015-05-28 13:50:55 -04:00
setbuf(fp, (char *)0);
}
2015-05-16 20:11:03 -04:00
void
init_prof_test(void **state)
{
if (stbbr_start(STBBR_LOGDEBUG ,5230, 0) != 0) {
assert_true(FALSE);
return;
}
2015-05-23 19:56:13 -04:00
config_orig = getenv("XDG_CONFIG_HOME");
data_orig = getenv("XDG_DATA_HOME");
2015-05-16 20:11:03 -04:00
setenv("XDG_CONFIG_HOME", XDG_CONFIG_HOME, 1);
setenv("XDG_DATA_HOME", XDG_DATA_HOME, 1);
2015-05-23 23:13:28 -04:00
_cleanup_dirs();
2015-05-16 20:11:03 -04:00
_create_config_dir();
_create_data_dir();
_create_chatlogs_dir();
_create_logs_dir();
2015-05-26 20:06:17 -04:00
prof_start();
assert_true(prof_output_exact("Profanity"));
// set UI options to make expect assertions faster and more reliable
prof_input("/inpblock timeout 5");
assert_true(prof_output_exact("Input blocking set to 5 milliseconds"));
prof_input("/inpblock dynamic off");
assert_true(prof_output_exact("Dynamic input blocking disabled"));
2015-11-28 19:16:00 -05:00
prof_input("/notify chat off");
assert_true(prof_output_exact("Chat notifications disabled"));
prof_input("/wrap off");
assert_true(prof_output_exact("Word wrap disabled"));
prof_input("/roster hide");
assert_true(prof_output_exact("Roster disabled"));
2015-09-30 17:42:42 -04:00
prof_input("/time console off");
prof_input("/time console off");
assert_true(prof_output_exact("Console time display disabled."));
prof_input("/time chat off");
assert_true(prof_output_exact("Chat time display disabled."));
prof_input("/time muc off");
assert_true(prof_output_exact("MUC time display disabled."));
prof_input("/time mucconfig off");
assert_true(prof_output_exact("MUC config time display disabled."));
prof_input("/time private off");
assert_true(prof_output_exact("Private chat time display disabled."));
prof_input("/time xml off");
assert_true(prof_output_exact("XML Console time display disabled."));
2015-05-16 20:11:03 -04:00
}
void
close_prof_test(void **state)
{
prof_input("/quit");
waitpid(exp_pid, NULL, 0);
2015-05-16 20:11:03 -04:00
_cleanup_dirs();
2015-05-23 19:56:13 -04:00
if (config_orig) {
setenv("XDG_CONFIG_HOME", config_orig, 1);
}
if (data_orig) {
setenv("XDG_DATA_HOME", data_orig, 1);
}
2015-05-23 19:56:13 -04:00
stbbr_stop();
2015-05-16 20:11:03 -04:00
}
2015-05-26 20:06:17 -04:00
void
prof_input(char *input)
{
2015-07-16 18:53:26 -04:00
int i = 0;
for (i = 0; i < strlen(input); i++) {
write(fd, &input[i], 1);
}
prof_output_exact(input);
char *newline = "\r";
write(fd, newline, 1);
// GString *inp_str = g_string_new(input);
// g_string_append(inp_str, "\r");
// write(fd, inp_str->str, inp_str->len);
// g_string_free(inp_str, TRUE);
2015-05-26 20:06:17 -04:00
}
int
prof_output_exact(char *text)
2015-05-26 20:06:17 -04:00
{
return (1 == exp_expectl(fd, exp_exact, text, 1, exp_end));
}
2015-05-28 15:02:16 -04:00
int
prof_output_regex(char *text)
{
return (1 == exp_expectl(fd, exp_regexp, text, 1, exp_end));
}
int
prof_output_glob(char *text)
{
return (1 == exp_expectl(fd, exp_glob, text, 1, exp_end));
}
2015-05-28 15:02:16 -04:00
void
prof_connect_with_roster(char *roster)
2015-05-28 15:02:16 -04:00
{
GString *roster_str = g_string_new(
"<iq type=\"result\" to=\"stabber@localhost/profanity\">"
"<query xmlns=\"jabber:iq:roster\" ver=\"362\">"
);
g_string_append(roster_str, roster);
g_string_append(roster_str,
"</query>"
"</iq>"
);
stbbr_for_query("jabber:iq:roster", roster_str->str);
g_string_free(roster_str, TRUE);
2015-06-13 14:41:11 -04:00
stbbr_for_id("prof_presence_1",
"<presence id=\"prof_presence_1\" lang=\"en\" to=\"stabber@localhost/profanity\" from=\"stabber@localhost/profanity\">"
"<priority>0</priority>"
"<c hash=\"sha-1\" xmlns=\"http://jabber.org/protocol/caps\" node=\"http://www.profanity.im\" ver=\"f8mrtdyAmhnj8Ca+630bThSL718=\"/>"
"</presence>"
);
prof_input("/connect stabber@localhost server 127.0.0.1 port 5230 tls allow");
2015-06-13 14:41:11 -04:00
prof_input("password");
// Allow time for profanity to connect
exp_timeout = 30;
assert_true(prof_output_glob("stabber@localhost logged in successfully, *online* (priority 0)."));
exp_timeout = 10;
2015-07-14 19:23:46 -04:00
stbbr_wait_for("prof_presence_*");
2015-05-28 15:02:16 -04:00
}
void
prof_connect(void)
{
prof_connect_with_roster(
"<item jid=\"buddy1@localhost\" subscription=\"both\" name=\"Buddy1\"/>"
"<item jid=\"buddy2@localhost\" subscription=\"both\" name=\"Buddy2\"/>"
);
}