tests: remove static data from ivi-layout-test-client

Using static data will mess things up when the test harness no longer fork()'s
each sub-test. Hence it needs to be converted to "normal" data.

Unfortunately here the cached value was actually used, so keeping that
behaviour is a handful. Yes, it was all leaked also before.

Signed-off-by: Pekka Paalanen <pekka.paalanen@collabora.com>
This commit is contained in:
Pekka Paalanen 2019-11-05 17:03:34 +02:00 committed by Daniel Stone
parent 9551dd7827
commit f8086fb839

View File

@ -115,10 +115,7 @@ get_ivi_application(struct client *client)
{ {
struct global *g; struct global *g;
struct global *global_iviapp = NULL; struct global *global_iviapp = NULL;
static struct ivi_application *iviapp; struct ivi_application *iviapp;
if (iviapp)
return iviapp;
wl_list_for_each(g, &client->global_list, link) { wl_list_for_each(g, &client->global_list, link) {
if (strcmp(g->interface, "ivi_application")) if (strcmp(g->interface, "ivi_application"))
@ -148,13 +145,12 @@ struct ivi_window {
}; };
static struct ivi_window * static struct ivi_window *
client_create_ivi_window(struct client *client, uint32_t ivi_id) client_create_ivi_window(struct client *client,
struct ivi_application *iviapp,
uint32_t ivi_id)
{ {
struct ivi_application *iviapp;
struct ivi_window *wnd; struct ivi_window *wnd;
iviapp = get_ivi_application(client);
wnd = xzalloc(sizeof(*wnd)); wnd = xzalloc(sizeof(*wnd));
wnd->wl_surface = wl_compositor_create_surface(client->wl_compositor); wnd->wl_surface = wl_compositor_create_surface(client->wl_compositor);
wnd->ivi_surface = ivi_application_surface_create(iviapp, ivi_id, wnd->ivi_surface = ivi_application_surface_create(iviapp, ivi_id,
@ -221,12 +217,14 @@ TEST_P(ivi_layout_runner, basic_test_names)
const char * const *test_name = data; const char * const *test_name = data;
struct client *client; struct client *client;
struct runner *runner; struct runner *runner;
struct ivi_application *iviapp;
struct ivi_window *wnd; struct ivi_window *wnd;
client = create_client(); client = create_client();
runner = client_create_runner(client); runner = client_create_runner(client);
iviapp = get_ivi_application(client);
wnd = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); wnd = client_create_ivi_window(client, iviapp, IVI_TEST_SURFACE_ID(0));
runner_run(runner, *test_name); runner_run(runner, *test_name);
@ -238,13 +236,17 @@ TEST(ivi_layout_surface_create)
{ {
struct client *client; struct client *client;
struct runner *runner; struct runner *runner;
struct ivi_application *iviapp;
struct ivi_window *winds[2]; struct ivi_window *winds[2];
client = create_client(); client = create_client();
runner = client_create_runner(client); runner = client_create_runner(client);
iviapp = get_ivi_application(client);
winds[0] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); winds[0] = client_create_ivi_window(client, iviapp,
winds[1] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(1)); IVI_TEST_SURFACE_ID(0));
winds[1] = client_create_ivi_window(client, iviapp,
IVI_TEST_SURFACE_ID(1));
runner_run(runner, "surface_create_p1"); runner_run(runner, "surface_create_p1");
@ -262,12 +264,14 @@ TEST_P(commit_changes_after_properties_set_surface_destroy, surface_property_com
const char * const *test_name = data; const char * const *test_name = data;
struct client *client; struct client *client;
struct runner *runner; struct runner *runner;
struct ivi_application *iviapp;
struct ivi_window *wnd; struct ivi_window *wnd;
client = create_client(); client = create_client();
runner = client_create_runner(client); runner = client_create_runner(client);
iviapp = get_ivi_application(client);
wnd = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); wnd = client_create_ivi_window(client, iviapp, IVI_TEST_SURFACE_ID(0));
runner_run(runner, *test_name); runner_run(runner, *test_name);
@ -282,12 +286,14 @@ TEST(get_surface_after_destroy_ivi_surface)
{ {
struct client *client; struct client *client;
struct runner *runner; struct runner *runner;
struct ivi_application *iviapp;
struct ivi_window *wnd; struct ivi_window *wnd;
client = create_client(); client = create_client();
runner = client_create_runner(client); runner = client_create_runner(client);
iviapp = get_ivi_application(client);
wnd = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); wnd = client_create_ivi_window(client, iviapp, IVI_TEST_SURFACE_ID(0));
ivi_surface_destroy(wnd->ivi_surface); ivi_surface_destroy(wnd->ivi_surface);
@ -302,12 +308,14 @@ TEST(get_surface_after_destroy_wl_surface)
{ {
struct client *client; struct client *client;
struct runner *runner; struct runner *runner;
struct ivi_application *iviapp;
struct ivi_window *wnd; struct ivi_window *wnd;
client = create_client(); client = create_client();
runner = client_create_runner(client); runner = client_create_runner(client);
iviapp = get_ivi_application(client);
wnd = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); wnd = client_create_ivi_window(client, iviapp, IVI_TEST_SURFACE_ID(0));
wl_surface_destroy(wnd->wl_surface); wl_surface_destroy(wnd->wl_surface);
@ -324,14 +332,19 @@ TEST_P(ivi_layout_layer_render_order_runner, render_order_test_names)
const char * const *test_name = data; const char * const *test_name = data;
struct client *client; struct client *client;
struct runner *runner; struct runner *runner;
struct ivi_application *iviapp;
struct ivi_window *winds[3]; struct ivi_window *winds[3];
client = create_client(); client = create_client();
runner = client_create_runner(client); runner = client_create_runner(client);
iviapp = get_ivi_application(client);
winds[0] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); winds[0] = client_create_ivi_window(client, iviapp,
winds[1] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(1)); IVI_TEST_SURFACE_ID(0));
winds[2] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(2)); winds[1] = client_create_ivi_window(client, iviapp,
IVI_TEST_SURFACE_ID(1));
winds[2] = client_create_ivi_window(client, iviapp,
IVI_TEST_SURFACE_ID(2));
runner_run(runner, *test_name); runner_run(runner, *test_name);
@ -345,14 +358,19 @@ TEST(destroy_surface_after_layer_render_order)
{ {
struct client *client; struct client *client;
struct runner *runner; struct runner *runner;
struct ivi_application *iviapp;
struct ivi_window *winds[3]; struct ivi_window *winds[3];
client = create_client(); client = create_client();
runner = client_create_runner(client); runner = client_create_runner(client);
iviapp = get_ivi_application(client);
winds[0] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); winds[0] = client_create_ivi_window(client, iviapp,
winds[1] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(1)); IVI_TEST_SURFACE_ID(0));
winds[2] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(2)); winds[1] = client_create_ivi_window(client, iviapp,
IVI_TEST_SURFACE_ID(1));
winds[2] = client_create_ivi_window(client, iviapp,
IVI_TEST_SURFACE_ID(2));
runner_run(runner, "test_layer_render_order_destroy_one_surface_p1"); runner_run(runner, "test_layer_render_order_destroy_one_surface_p1");
@ -369,14 +387,19 @@ TEST(commit_changes_after_render_order_set_surface_destroy)
{ {
struct client *client; struct client *client;
struct runner *runner; struct runner *runner;
struct ivi_application *iviapp;
struct ivi_window *winds[3]; struct ivi_window *winds[3];
client = create_client(); client = create_client();
runner = client_create_runner(client); runner = client_create_runner(client);
iviapp = get_ivi_application(client);
winds[0] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); winds[0] = client_create_ivi_window(client, iviapp,
winds[1] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(1)); IVI_TEST_SURFACE_ID(0));
winds[2] = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(2)); winds[1] = client_create_ivi_window(client, iviapp,
IVI_TEST_SURFACE_ID(1));
winds[2] = client_create_ivi_window(client, iviapp,
IVI_TEST_SURFACE_ID(2));
runner_run(runner, "commit_changes_after_render_order_set_surface_destroy"); runner_run(runner, "commit_changes_after_render_order_set_surface_destroy");
@ -394,15 +417,17 @@ TEST(ivi_layout_surface_configure_notification)
{ {
struct client *client; struct client *client;
struct runner *runner; struct runner *runner;
struct ivi_application *iviapp;
struct ivi_window *wind; struct ivi_window *wind;
struct buffer *buffer; struct buffer *buffer;
client = create_client(); client = create_client();
runner = client_create_runner(client); runner = client_create_runner(client);
iviapp = get_ivi_application(client);
runner_run(runner, "surface_configure_notification_p1"); runner_run(runner, "surface_configure_notification_p1");
wind = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); wind = client_create_ivi_window(client, iviapp, IVI_TEST_SURFACE_ID(0));
buffer = create_shm_buffer_a8r8g8b8(client, 200, 300); buffer = create_shm_buffer_a8r8g8b8(client, 200, 300);
@ -427,19 +452,21 @@ TEST(ivi_layout_surface_create_notification)
{ {
struct client *client; struct client *client;
struct runner *runner; struct runner *runner;
struct ivi_application *iviapp;
struct ivi_window *wind; struct ivi_window *wind;
client = create_client(); client = create_client();
runner = client_create_runner(client); runner = client_create_runner(client);
iviapp = get_ivi_application(client);
runner_run(runner, "surface_create_notification_p1"); runner_run(runner, "surface_create_notification_p1");
wind = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); wind = client_create_ivi_window(client, iviapp, IVI_TEST_SURFACE_ID(0));
runner_run(runner, "surface_create_notification_p2"); runner_run(runner, "surface_create_notification_p2");
ivi_window_destroy(wind); ivi_window_destroy(wind);
wind = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); wind = client_create_ivi_window(client, iviapp, IVI_TEST_SURFACE_ID(0));
runner_run(runner, "surface_create_notification_p3"); runner_run(runner, "surface_create_notification_p3");
ivi_window_destroy(wind); ivi_window_destroy(wind);
@ -450,18 +477,20 @@ TEST(ivi_layout_surface_remove_notification)
{ {
struct client *client; struct client *client;
struct runner *runner; struct runner *runner;
struct ivi_application *iviapp;
struct ivi_window *wind; struct ivi_window *wind;
client = create_client(); client = create_client();
runner = client_create_runner(client); runner = client_create_runner(client);
iviapp = get_ivi_application(client);
wind = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); wind = client_create_ivi_window(client, iviapp, IVI_TEST_SURFACE_ID(0));
runner_run(runner, "surface_remove_notification_p1"); runner_run(runner, "surface_remove_notification_p1");
ivi_window_destroy(wind); ivi_window_destroy(wind);
runner_run(runner, "surface_remove_notification_p2"); runner_run(runner, "surface_remove_notification_p2");
wind = client_create_ivi_window(client, IVI_TEST_SURFACE_ID(0)); wind = client_create_ivi_window(client, iviapp, IVI_TEST_SURFACE_ID(0));
ivi_window_destroy(wind); ivi_window_destroy(wind);
runner_run(runner, "surface_remove_notification_p3"); runner_run(runner, "surface_remove_notification_p3");