]> git.ipfire.org Git - thirdparty/freeswitch.git/commitdiff
[Unit-Tests] Fix switch_core_video test to use temporary path for generated files...
authorAndrey Volk <andywolk@gmail.com>
Fri, 22 Oct 2021 20:43:42 +0000 (23:43 +0300)
committerAndrey Volk <andywolk@gmail.com>
Sat, 23 Oct 2021 19:00:25 +0000 (22:00 +0300)
tests/unit/.gitignore
tests/unit/switch_core.c
tests/unit/switch_core_video.c

index 630dbd17754334a3dd2d52052318837079e04bb6..b3689b97aba40bf063cd6984d4030d8b7bb13a9e 100644 (file)
@@ -5,16 +5,13 @@
 \#*
 *.log
 *.trs
+[0-9]*/**
+conf_sofia/[0-9]*/**
+.libs/
 perf.data
 perf.data.old
 Makefile.in
 freeswitch.xml.fsxml.tmp
-test-argb.png
-test-rgb.png
-images/test_patched_banner_alpha.png
-images/test_patched_banner_noalpha.png
-images/test_patched_signalwire_alpha.png
-images/test_patched_signalwire_no_alpha.png
 switch_console
 switch_core
 switch_core_codec
@@ -42,11 +39,5 @@ switch_estimators
 switch_jitter_buffer
 .deps/
 Makefile
-cluecon-argb-write.png
-cluecon-argb.png
-cluecon-jpg-write.jpg
-cluecon-jpg.png
-cluecon-rgb-write.png
-cluecon-rgb.png
 conf/*/
 conf_playsay/*/
index c8c268387b4064c5ea372253d190996c6a9bd51a..126921997c6df766cdfe3f09de7fab63833d4cd5 100644 (file)
@@ -30,8 +30,6 @@
  *
  */
 #include <switch.h>
-#include <stdlib.h>
-
 #include <test/switch_test.h>
 
 #if defined(HAVE_OPENSSL)
index 5c3731eb7ff9eaf6a414459b358f68229202b2a9..27c961029291ced04e874f808c85b06b118368cb 100644 (file)
@@ -36,7 +36,7 @@
 
 FST_CORE_BEGIN("./conf")
 {
-       FST_SUITE_BEGIN(switch_ivr_originate)
+       FST_SUITE_BEGIN(switch_core_video)
        {
                FST_SETUP_BEGIN()
                {
@@ -51,6 +51,8 @@ FST_CORE_BEGIN("./conf")
                FST_TEST_BEGIN(data_url_test)
                {
                        char *data_url = NULL;
+                       char *rgb_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test-rgb.png", SWITCH_GLOBAL_dirs.temp_dir);
+                       char *argb_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test-argb.png", SWITCH_GLOBAL_dirs.temp_dir);
                        switch_image_t *img = switch_img_alloc(NULL, SWITCH_IMG_FMT_I420, 120, 60, 1);
                        switch_image_t *argb_img = switch_img_alloc(NULL, SWITCH_IMG_FMT_ARGB, 120, 60, 1);
                        switch_rgb_color_t color = { 0 };
@@ -60,7 +62,7 @@ FST_CORE_BEGIN("./conf")
 
                        switch_img_fill(img, 0, 0, img->d_w, img->d_h, &color);
                        switch_img_add_text(img->planes[0], img->d_w, 10, 10, "-1234567890");
-                       switch_img_write_png(img, "images/test-rgb.png");
+                       switch_img_write_png(img, rgb_filename);
 
                        switch_img_data_url_png(img, &data_url);
                        switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "I420: %s\n", data_url);
@@ -74,7 +76,7 @@ FST_CORE_BEGIN("./conf")
                                switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "%d %d %d %d\n", *p, *(p+1), *(p+2), *(p+3));
                        }
 
-                       switch_img_write_png(argb_img, "images/test-argb.png");
+                       switch_img_write_png(argb_img, argb_filename);
                        switch_img_data_url_png(argb_img, &data_url);
                        switch_log_printf(SWITCH_CHANNEL_LOG, SWITCH_LOG_INFO, "ARGB: %s\n", data_url);
                        free(data_url);
@@ -82,36 +84,46 @@ FST_CORE_BEGIN("./conf")
 
                        switch_img_free(&img);
                        switch_img_free(&argb_img);
+                       unlink(rgb_filename);
+                       unlink(argb_filename);
                }
                FST_TEST_END()
 
                FST_TEST_BEGIN(img_patch)
                {
+                       char *filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test.png", SWITCH_GLOBAL_dirs.temp_dir);
+                       char *text_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test_text.png", SWITCH_GLOBAL_dirs.temp_dir);
+                       char *patch_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test_patched.png", SWITCH_GLOBAL_dirs.temp_dir);
                        int width = 320;
                        int height = 240;
+                       switch_status_t status;
+                       switch_image_t *img = NULL;
+                       switch_rgb_color_t bgcolor = {0, 0, 0}; // red
 
                        switch_image_t *timg = switch_img_write_text_img(width, height, SWITCH_FALSE, "#ffffff:transparent:FreeMono.ttf:24:This is a test!");
                        fst_requires(timg != NULL);
-                       switch_status_t status = switch_img_write_png(timg, "images/test_text.png");
+                       status = switch_img_write_png(timg, text_filename);
                        fst_check(status == SWITCH_STATUS_SUCCESS);
+                       unlink(text_filename);
 
                        width *=2;
                        height *=2;
 
-                       switch_rgb_color_t bgcolor = {0, 0, 0}; // red
                        bgcolor.b = 255;
 
-                       switch_image_t *img = switch_img_alloc(NULL, SWITCH_IMG_FMT_I420, width, height, 1);
+                       img = switch_img_alloc(NULL, SWITCH_IMG_FMT_I420, width, height, 1);
                        fst_requires(img);
                        switch_img_fill(img, 0, 0, width, height, &bgcolor);
-                       status = switch_img_write_png(img, "images/test.png");
+                       status = switch_img_write_png(img, filename);
                        fst_check(status == SWITCH_STATUS_SUCCESS);
+                       unlink(filename);
 
                        switch_img_patch(img, timg, 0, 0);
 
-                       status = switch_img_write_png(img, "images/test_patched.png");
+                       status = switch_img_write_png(img, patch_filename);
 
                        fst_check(status == SWITCH_STATUS_SUCCESS);
+                       unlink(patch_filename);
 
                        switch_img_free(&img);
                        switch_img_free(&timg);
@@ -120,20 +132,37 @@ FST_CORE_BEGIN("./conf")
 
                FST_TEST_BEGIN(img_patch_alpha)
                {
-                       switch_image_t *timg = switch_img_read_png("images/test_text.png", SWITCH_IMG_FMT_ARGB);
+                       char *text_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test_text.png", SWITCH_GLOBAL_dirs.temp_dir);
+                       char *patch_filename_alpha = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test_patched_alpha.png", SWITCH_GLOBAL_dirs.temp_dir);
+                       char *patch_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test_patched_noalpha.png", SWITCH_GLOBAL_dirs.temp_dir);
+                       int width = 320;
+                       int height = 240;
+                       switch_image_t *img = NULL;
+                       switch_status_t status;
+
+                       switch_image_t *timg = switch_img_write_text_img(width, height, SWITCH_FALSE, "#ffffff:transparent:FreeMono.ttf:24:This is a test!");
+                       fst_requires(timg != NULL);
+                       status = switch_img_write_png(timg, text_filename);
+                       fst_check(status == SWITCH_STATUS_SUCCESS);
+                       switch_img_free(&timg);
+
+                       timg = switch_img_read_png(text_filename, SWITCH_IMG_FMT_ARGB);
+                       unlink(text_filename);
                        fst_requires(timg != NULL);
 
-                       switch_image_t *img = switch_img_read_png("images/banner.png", SWITCH_IMG_FMT_ARGB);
+                       img = switch_img_read_png("images/banner.png", SWITCH_IMG_FMT_ARGB);
                        fst_requires(img);
                        switch_img_patch(img, timg, 0, 0);
-                       switch_status_t status = switch_img_write_png(img, "images/test_patched_alpha.png");
+                       status = switch_img_write_png(img, patch_filename_alpha);
                        fst_check(status == SWITCH_STATUS_SUCCESS);
+                       unlink(patch_filename_alpha);
 
                        switch_img_free(&img);
                        img = switch_img_read_png("images/banner.png", SWITCH_IMG_FMT_ARGB);
                        switch_img_patch_rgb(img, timg, 0, 0, SWITCH_TRUE);
-                       status = switch_img_write_png(img, "images/test_patched_noalpha.png");
+                       status = switch_img_write_png(img, patch_filename);
                        fst_check(status == SWITCH_STATUS_SUCCESS);
+                       unlink(patch_filename);
 
                        switch_img_free(&img);
                        switch_img_free(&timg);
@@ -142,20 +171,24 @@ FST_CORE_BEGIN("./conf")
 
                FST_TEST_BEGIN(img_patch_banner_alpha)
                {
+                       char *patch_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test_patched_banner_noalpha.png", SWITCH_GLOBAL_dirs.temp_dir);
+                       char *patch_filename_alpha = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test_patched_banner_alpha.png", SWITCH_GLOBAL_dirs.temp_dir);
                        switch_status_t status;
                        switch_image_t *img = switch_img_read_png("images/banner.png", SWITCH_IMG_FMT_ARGB);
                        switch_image_t *img2 = switch_img_read_png("images/banner.png", SWITCH_IMG_FMT_ARGB);
                        fst_requires(img);
                        fst_requires(img2);
                        switch_img_patch(img, img2, 80, 20);
-                       status = switch_img_write_png(img, "images/test_patched_banner_alpha.png");
+                       status = switch_img_write_png(img, patch_filename_alpha);
                        fst_check(status == SWITCH_STATUS_SUCCESS);
+                       unlink(patch_filename_alpha);
 
                        switch_img_free(&img);
                        img = switch_img_read_png("images/banner.png", SWITCH_IMG_FMT_ARGB);
                        switch_img_patch_rgb(img, img2, 80, 20, SWITCH_TRUE);
-                       status = switch_img_write_png(img, "images/test_patched_banner_noalpha.png");
+                       status = switch_img_write_png(img, patch_filename);
                        fst_check(status == SWITCH_STATUS_SUCCESS);
+                       unlink(patch_filename);
 
                        switch_img_free(&img);
                        switch_img_free(&img2);
@@ -164,50 +197,56 @@ FST_CORE_BEGIN("./conf")
 
                FST_TEST_BEGIN(img_patch_signalwire_alpha)
                {
+                       char *patch_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test_patched_signalwire_alpha.png", SWITCH_GLOBAL_dirs.temp_dir);
                        switch_image_t *timg_small = NULL;
                        switch_image_t *timg = switch_img_read_png("images/signalwire.png", SWITCH_IMG_FMT_ARGB);
-                       fst_requires(timg != NULL);
-
                        switch_image_t *img = switch_img_read_png("images/banner.png", SWITCH_IMG_FMT_ARGB);
+                       switch_status_t status;
+
+                       fst_requires(timg != NULL);
                        fst_requires(img);
                        switch_img_scale(timg, &timg_small, timg->d_w / 5, timg->d_h / 5);
                        switch_img_patch(img, timg_small, 80, 20);
-                       switch_status_t status = switch_img_write_png(img, "images/test_patched_signalwire_alpha.png");
+                       status = switch_img_write_png(img, patch_filename);
                        fst_check(status == SWITCH_STATUS_SUCCESS);
 
                        switch_img_free(&img);
                        switch_img_free(&timg);
                        switch_img_free(&timg_small);
+                       unlink(patch_filename);
                }
                FST_TEST_END()
 
                FST_TEST_BEGIN(img_patch_signalwire_no_alpha)
                {
+                       char *patch_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "test_patched_signalwire_no_alpha.png", SWITCH_GLOBAL_dirs.temp_dir);
                        switch_image_t *timg_small = NULL;
                        switch_image_t *timg = switch_img_read_png("images/signalwire.png", SWITCH_IMG_FMT_ARGB);
-                       fst_requires(timg != NULL);
-
                        switch_image_t *img = switch_img_read_png("images/banner.png", SWITCH_IMG_FMT_ARGB);
+                       switch_status_t status;
+
+                       fst_requires(timg != NULL);
                        fst_requires(img);
                        switch_img_scale(timg, &timg_small, timg->d_w / 5, timg->d_h / 5);
                        switch_img_patch_rgb(img, timg_small, 80, 20, SWITCH_TRUE);
-                       switch_status_t status = switch_img_write_png(img, "images/test_patched_signalwire_no_alpha.png");
+                       status = switch_img_write_png(img, patch_filename);
                        fst_check(status == SWITCH_STATUS_SUCCESS);
 
                        switch_img_free(&img);
                        switch_img_free(&timg);
                        switch_img_free(&timg_small);
+                       unlink(patch_filename);
                }
                FST_TEST_END()
 
                FST_TEST_BEGIN(stb_data_url)
                {
                        switch_image_t *img = switch_img_alloc(NULL, SWITCH_IMG_FMT_I420, 120, 60, 1);
+                       char *data_url = NULL;
                        switch_rgb_color_t color = { 0 };
                        color.r = 255;
                        // color.g = 255;
                        // color.b = 255;
-                       char *data_url = NULL;
 
                        switch_img_fill(img, 0, 0, img->d_w, img->d_h, &color);
                        switch_img_add_text(img->planes[0], img->d_w, 10, 10, "-1234567890");
@@ -228,21 +267,27 @@ FST_CORE_BEGIN("./conf")
                FST_TEST_BEGIN(read_from_file)
                {
                        switch_image_t *img;
+                       char *rgb_write_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "cluecon-rgb.png", SWITCH_GLOBAL_dirs.temp_dir);
+                       char *argb_write_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "cluecon-argb.png", SWITCH_GLOBAL_dirs.temp_dir);
+                       char *jpg_write_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "cluecon-jpg.png", SWITCH_GLOBAL_dirs.temp_dir);
 
                        img = switch_img_read_from_file("../../images/cluecon.png", SWITCH_IMG_FMT_I420);
                        fst_requires(img);
-                       switch_img_write_png(img, "cluecon-rgb.png");
+                       switch_img_write_png(img, rgb_write_filename);
                        switch_img_free(&img);
+                       unlink(rgb_write_filename);
 
                        img = switch_img_read_from_file("../../images/cluecon.png", SWITCH_IMG_FMT_ARGB);
                        fst_requires(img);
-                       switch_img_write_png(img, "cluecon-argb.png");
+                       switch_img_write_png(img, argb_write_filename);
                        switch_img_free(&img);
+                       unlink(argb_write_filename);
 
                        img = switch_img_read_from_file("../../images/cluecon.jpg", SWITCH_IMG_FMT_I420);
                        fst_requires(img);
-                       switch_img_write_png(img, "cluecon-jpg.png");
+                       switch_img_write_png(img, jpg_write_filename);
                        switch_img_free(&img);
+                       unlink(jpg_write_filename);
                }
                FST_TEST_END()
 
@@ -250,24 +295,30 @@ FST_CORE_BEGIN("./conf")
                {
                        switch_image_t *img;
                        switch_status_t status;
+                       char *rgb_write_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "cluecon-rgb-write.png", SWITCH_GLOBAL_dirs.temp_dir);
+                       char *argb_write_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "cluecon-argb-write.png", SWITCH_GLOBAL_dirs.temp_dir);
+                       char *jpg_write_filename = switch_core_sprintf(fst_pool, "%s" SWITCH_PATH_SEPARATOR "cluecon-jpg-write.png", SWITCH_GLOBAL_dirs.temp_dir);
 
                        img = switch_img_read_from_file("../../images/cluecon.png", SWITCH_IMG_FMT_I420);
                        fst_requires(img);
-                       status = switch_img_write_to_file(img, "cluecon-rgb-write.png", 0);
+                       status = switch_img_write_to_file(img, rgb_write_filename, 0);
                        switch_img_free(&img);
                        fst_check(status == SWITCH_STATUS_SUCCESS);
+                       unlink(rgb_write_filename);
 
                        img = switch_img_read_from_file("../../images/cluecon.png", SWITCH_IMG_FMT_ARGB);
                        fst_requires(img);
-                       status = switch_img_write_to_file(img, "cluecon-argb-write.png", 0);
+                       status = switch_img_write_to_file(img, argb_write_filename, 0);
                        switch_img_free(&img);
                        fst_check(status == SWITCH_STATUS_SUCCESS);
+                       unlink(argb_write_filename);
 
                        img = switch_img_read_from_file("../../images/cluecon.jpg", SWITCH_IMG_FMT_I420);
                        fst_requires(img);
-                       status = switch_img_write_to_file(img, "cluecon-jpg-write.jpg", 100);
+                       status = switch_img_write_to_file(img, jpg_write_filename, 100);
                        switch_img_free(&img);
                        fst_check(status == SWITCH_STATUS_SUCCESS);
+                       unlink(jpg_write_filename);
                }
                FST_TEST_END()
        }