summaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
authorDavid Herrmann <dh.herrmann@googlemail.com>2012-04-14 19:45:11 +0200
committerDavid Herrmann <dh.herrmann@googlemail.com>2012-04-14 19:45:11 +0200
commit7a27de465bbe55dd55ab413bc5f26158548c5623 (patch)
tree8709719ce0a48f8d0408275547ac05d6a9468fb3 /tests
parentb56ec68a91bda3914304b39ced9a4d5a2ca76360 (diff)
test_output: use new test_include.h header
The test_include.h header now provides the basic initialization that will later be used in all other tests. This allows us to use the same program-parameters that kmscon uses and makes sure everything is initialized properly before we run the tests. Signed-off-by: David Herrmann <dh.herrmann@googlemail.com>
Diffstat (limited to 'tests')
-rw-r--r--tests/test_include.h98
-rw-r--r--tests/test_output.c22
2 files changed, 108 insertions, 12 deletions
diff --git a/tests/test_include.h b/tests/test_include.h
new file mode 100644
index 0000000..060c78c
--- /dev/null
+++ b/tests/test_include.h
@@ -0,0 +1,98 @@
+/*
+ * kmscon - Common test functions
+ *
+ * Copyright (c) 2012 David Herrmann <dh.herrmann@googlemail.com>
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining
+ * a copy of this software and associated documentation files
+ * (the "Software"), to deal in the Software without restriction, including
+ * without limitation the rights to use, copy, modify, merge, publish,
+ * distribute, sublicense, and/or sell copies of the Software, and to
+ * permit persons to whom the Software is furnished to do so, subject to
+ * the following conditions:
+ *
+ * The above copyright notice and this permission notice shall be included
+ * in all copies or substantial portions of the Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS
+ * OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF
+ * MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.
+ * IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY
+ * CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT,
+ * TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE
+ * SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
+ */
+
+#include <errno.h>
+#include <signal.h>
+#include <stdbool.h>
+#include <stdlib.h>
+#include <string.h>
+#include <sys/signalfd.h>
+#include "conf.h"
+#include "eloop.h"
+#include "log.h"
+
+static void sig_generic(struct ev_eloop *p, struct signalfd_siginfo *info,
+ void *data)
+{
+ struct ev_eloop *eloop = data;
+
+ ev_eloop_exit(eloop);
+ log_info("terminating due to caught signal %d", info->ssi_signo);
+}
+
+static int test_prepare(int argc, char **argv, struct ev_eloop **out)
+{
+ int ret;
+ struct ev_eloop *eloop;
+
+ ret = conf_parse_argv(argc, argv);
+ if (ret)
+ return -EINVAL;
+
+ if (conf_global.exit)
+ return -1;
+
+ if (!conf_global.debug && !conf_global.verbose && conf_global.silent)
+ log_set_config(&LOG_CONFIG_WARNING(0, 0, 0, 0));
+ else
+ log_set_config(&LOG_CONFIG_INFO(conf_global.debug,
+ conf_global.verbose));
+
+ log_print_init(argv[0]);
+
+ ret = ev_eloop_new(&eloop);
+ if (ret)
+ return ret;
+
+ ret = ev_eloop_register_signal_cb(eloop, SIGTERM, sig_generic, eloop);
+ if (ret) {
+ ev_eloop_unref(eloop);
+ return ret;
+ }
+
+ ret = ev_eloop_register_signal_cb(eloop, SIGINT, sig_generic, eloop);
+ if (ret) {
+ ev_eloop_unregister_signal_cb(eloop, SIGTERM,
+ sig_generic, eloop);
+ ev_eloop_unref(eloop);
+ return ret;
+ }
+
+ *out = eloop;
+ return 0;
+}
+
+static void test_fail(int ret)
+{
+ if (ret)
+ log_err("init failed, errno %d: %s", ret, strerror(-ret));
+}
+
+static void test_exit(struct ev_eloop *eloop)
+{
+ ev_eloop_unregister_signal_cb(eloop, SIGINT, sig_generic, eloop);
+ ev_eloop_unregister_signal_cb(eloop, SIGTERM, sig_generic, eloop);
+ ev_eloop_unref(eloop);
+}
diff --git a/tests/test_output.c b/tests/test_output.c
index 8bd3358..061f6dc 100644
--- a/tests/test_output.c
+++ b/tests/test_output.c
@@ -51,6 +51,7 @@
#include "gl.h"
#include "log.h"
#include "uterm.h"
+#include "test_include.h"
/* a colored quad */
float d_vert[] = { -1, -1, 1, -1, -1, 1, 1, -1, 1, 1, -1, 1 };
@@ -187,26 +188,19 @@ int main(int argc, char **argv)
int ret;
struct ev_eloop *eloop;
- log_print_init("test_output");
- log_set_config(&LOG_CONFIG_INFO(1, 1));
-
- ret = ev_eloop_new(&eloop);
+ ret = test_prepare(argc, argv, &eloop);
if (ret)
- return EXIT_FAILURE;
+ goto err_fail;
log_notice("Creating video object...");
ret = uterm_video_new(&video, UTERM_VIDEO_DRM, eloop);
- if (ret) {
- log_err("Cannot create video object: %d", ret);
- return abs(ret);
- }
+ if (ret)
+ goto err_exit;
log_notice("Wakeing up video object...");
ret = uterm_video_wake_up(video);
- if (ret < 0) {
- log_err("Cannot wakeup video object: %d", ret);
+ if (ret < 0)
goto err_unref;
- }
if (argc < 2) {
ret = list_outputs(video);
@@ -224,5 +218,9 @@ int main(int argc, char **argv)
err_unref:
uterm_video_unref(video);
+err_exit:
+ test_exit(eloop);
+err_fail:
+ test_fail(ret);
return abs(ret);
}