mirror of
https://github.com/brl/mutter.git
synced 2024-11-25 09:30:45 -05:00
Add unit test to verify that modifying uniforms doesn't create chain
The recommended usage model for rendering pipelines with minor changes is to make a copy of a base pipeline just before rendering and then modify that. The new pipeline can then be used as the base pipeline for the next paint. Currently this has a known problem when modifying uniform values in that Cogl won't prune the redundant ancestry and instead it will end up with an ever-growing chain of pipelines. This is particularly bad for something like CoglGST where it could also end up leaking textures for the video frames if the pipelines are used to render video. The patch adds a test case for that situation so that we won't forget about the problem. The test is maked as a known failure. Additionally the patch adds a similar test for setting the blend constant to constrast the test with some state that does work correctly. Reviewed-by: Robert Bragg <robert@linux.intel.com> (cherry picked from commit 2550181543389d6e9e1cb9618d17cd352a0cf9b6)
This commit is contained in:
parent
9c2244396e
commit
6de83d504c
@ -38,6 +38,8 @@
|
||||
#include "cogl-snippet-private.h"
|
||||
#include "cogl-error-private.h"
|
||||
|
||||
#include <test-fixtures/test-unit.h>
|
||||
|
||||
#include "string.h"
|
||||
|
||||
#ifndef GL_FUNC_ADD
|
||||
@ -2090,3 +2092,74 @@ _cogl_pipeline_hash_fragment_snippets_state (CoglPipeline *authority,
|
||||
_cogl_pipeline_snippet_list_hash (&authority->big_state->fragment_snippets,
|
||||
&state->hash);
|
||||
}
|
||||
|
||||
UNIT_TEST (check_blend_constant_ancestry,
|
||||
0 /* no requirements */,
|
||||
0 /* no known failures */)
|
||||
{
|
||||
CoglPipeline *pipeline = cogl_pipeline_new (test_ctx);
|
||||
CoglNode *node;
|
||||
int pipeline_length = 0;
|
||||
int i;
|
||||
|
||||
/* Repeatedly making a copy of a pipeline and changing the same
|
||||
* state (in this case the blend constant) shouldn't cause a long
|
||||
* chain of pipelines to be created because the redundant ancestry
|
||||
* should be pruned. */
|
||||
|
||||
for (i = 0; i < 20; i++)
|
||||
{
|
||||
CoglColor color;
|
||||
CoglPipeline *tmp_pipeline;
|
||||
|
||||
cogl_color_init_from_4f (&color, i / 20.0f, 0.0f, 0.0f, 1.0f);
|
||||
|
||||
tmp_pipeline = cogl_pipeline_copy (pipeline);
|
||||
cogl_object_unref (pipeline);
|
||||
pipeline = tmp_pipeline;
|
||||
|
||||
cogl_pipeline_set_blend_constant (pipeline, &color);
|
||||
}
|
||||
|
||||
for (node = (CoglNode *) pipeline; node; node = node->parent)
|
||||
pipeline_length++;
|
||||
|
||||
g_assert_cmpint (pipeline_length, <=, 2);
|
||||
|
||||
cogl_object_unref (pipeline);
|
||||
}
|
||||
|
||||
UNIT_TEST (check_uniform_ancestry,
|
||||
0 /* no requirements */,
|
||||
TEST_KNOWN_FAILURE)
|
||||
{
|
||||
CoglPipeline *pipeline = cogl_pipeline_new (test_ctx);
|
||||
CoglNode *node;
|
||||
int pipeline_length = 0;
|
||||
int i;
|
||||
|
||||
/* Repeatedly making a copy of a pipeline and changing a uniform
|
||||
* shouldn't cause a long chain of pipelines to be created */
|
||||
|
||||
for (i = 0; i < 20; i++)
|
||||
{
|
||||
CoglPipeline *tmp_pipeline;
|
||||
int uniform_location;
|
||||
|
||||
tmp_pipeline = cogl_pipeline_copy (pipeline);
|
||||
cogl_object_unref (pipeline);
|
||||
pipeline = tmp_pipeline;
|
||||
|
||||
uniform_location =
|
||||
cogl_pipeline_get_uniform_location (pipeline, "a_uniform");
|
||||
|
||||
cogl_pipeline_set_uniform_1i (pipeline, uniform_location, i);
|
||||
}
|
||||
|
||||
for (node = (CoglNode *) pipeline; node; node = node->parent)
|
||||
pipeline_length++;
|
||||
|
||||
g_assert_cmpint (pipeline_length, <=, 2);
|
||||
|
||||
cogl_object_unref (pipeline);
|
||||
}
|
||||
|
Loading…
Reference in New Issue
Block a user