Added Apoorv Upreti's GSoC2013 work: visual test suite.
See visualtest/README.txt for details.
This commit is contained in:
parent
247313174a
commit
5206975778
347 changed files with 33523 additions and 0 deletions
225
visualtest/src/variator_common.c
Executable file
225
visualtest/src/variator_common.c
Executable file
|
@ -0,0 +1,225 @@
|
|||
/* See COPYING.txt for the full license governing this code. */
|
||||
/**
|
||||
* \file variator_common.c
|
||||
*
|
||||
* Source file for some common functionality used by variators.
|
||||
*/
|
||||
|
||||
#include <SDL_test.h>
|
||||
#include "SDL_visualtest_variator_common.h"
|
||||
|
||||
int
|
||||
SDLVisualTest_NextValue(SDLVisualTest_SUTOptionValue* var,
|
||||
SDLVisualTest_SUTOption* opt)
|
||||
{
|
||||
if(!var)
|
||||
{
|
||||
SDLTest_LogError("var argument cannot be NULL");
|
||||
return -1;
|
||||
}
|
||||
if(!opt)
|
||||
{
|
||||
SDLTest_LogError("opt argument cannot be NULL");
|
||||
return -1;
|
||||
}
|
||||
|
||||
switch(opt->type)
|
||||
{
|
||||
case SDL_SUT_OPTIONTYPE_BOOL:
|
||||
if(var->bool_value)
|
||||
{
|
||||
var->bool_value = SDL_FALSE;
|
||||
return 1;
|
||||
}
|
||||
else
|
||||
{
|
||||
var->bool_value = SDL_TRUE;
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
|
||||
case SDL_SUT_OPTIONTYPE_ENUM:
|
||||
var->enumerated.index++;
|
||||
if(!opt->data.enum_values[var->enumerated.index])
|
||||
{
|
||||
var->enumerated.index = 0;
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
break;
|
||||
|
||||
case SDL_SUT_OPTIONTYPE_INT:
|
||||
{
|
||||
int increment = (opt->data.range.max - opt->data.range.min) /
|
||||
SDL_SUT_INTEGER_OPTION_TEST_STEPS;
|
||||
/* prevents infinite loop when rounding */
|
||||
if(increment == 0)
|
||||
increment = 1;
|
||||
var->integer.value += increment;
|
||||
if(var->integer.value > opt->data.range.max)
|
||||
{
|
||||
var->integer.value = opt->data.range.min;
|
||||
return 1;
|
||||
}
|
||||
return 0;
|
||||
}
|
||||
break;
|
||||
|
||||
case SDL_SUT_OPTIONTYPE_STRING:
|
||||
return 1;
|
||||
break;
|
||||
}
|
||||
return -1;
|
||||
}
|
||||
|
||||
int
|
||||
SDLVisualTest_MakeStrFromVariation(SDLVisualTest_Variation* variation,
|
||||
SDLVisualTest_SUTConfig* config,
|
||||
char* buffer, int size)
|
||||
{
|
||||
int i, index;
|
||||
SDLVisualTest_SUTOptionValue* vars;
|
||||
SDLVisualTest_SUTOption* options;
|
||||
if(!variation)
|
||||
{
|
||||
SDLTest_LogError("variation argument cannot be NULL");
|
||||
return 0;
|
||||
}
|
||||
if(!config)
|
||||
{
|
||||
SDLTest_LogError("config argument cannot be NULL");
|
||||
return 0;
|
||||
}
|
||||
if(!buffer)
|
||||
{
|
||||
SDLTest_LogError("buffer argument cannot be NULL");
|
||||
return 0;
|
||||
}
|
||||
if(size <= 0)
|
||||
{
|
||||
SDLTest_LogError("size argument should be positive");
|
||||
return 0;
|
||||
}
|
||||
|
||||
index = 0;
|
||||
buffer[0] = '\0';
|
||||
options = config->options;
|
||||
vars = variation->vars;
|
||||
for(i = 0; i < variation->num_vars; i++)
|
||||
{
|
||||
int n, enum_index;
|
||||
if(index >= size - 1)
|
||||
{
|
||||
SDLTest_LogError("String did not fit in buffer size");
|
||||
return 0;
|
||||
}
|
||||
switch(options[i].type)
|
||||
{
|
||||
case SDL_SUT_OPTIONTYPE_BOOL:
|
||||
if(vars[i].bool_value)
|
||||
{
|
||||
n = SDL_snprintf(buffer + index, size - index, "%s ",
|
||||
options[i].name);
|
||||
if(n <= 0)
|
||||
{
|
||||
SDLTest_LogError("SDL_snprintf() failed");
|
||||
return 0;
|
||||
}
|
||||
index += n;
|
||||
}
|
||||
break;
|
||||
|
||||
case SDL_SUT_OPTIONTYPE_ENUM:
|
||||
if(vars[i].enumerated.on)
|
||||
{
|
||||
enum_index = vars[i].enumerated.index;
|
||||
n = SDL_snprintf(buffer + index, size - index, "%s %s ",
|
||||
options[i].name, options[i].data.enum_values[enum_index]);
|
||||
index += n;
|
||||
}
|
||||
break;
|
||||
|
||||
case SDL_SUT_OPTIONTYPE_INT:
|
||||
if(vars[i].integer.on)
|
||||
{
|
||||
n = SDL_snprintf(buffer + index, size - index, "%s %d ",
|
||||
options[i].name, vars[i].integer.value);
|
||||
index += n;
|
||||
}
|
||||
break;
|
||||
|
||||
case SDL_SUT_OPTIONTYPE_STRING:
|
||||
if(vars[i].string.on)
|
||||
{
|
||||
n = SDL_snprintf(buffer + index, size - index, "%s %s ",
|
||||
options[i].name, vars[i].string.value);
|
||||
index += n;
|
||||
}
|
||||
break;
|
||||
}
|
||||
}
|
||||
return 1;
|
||||
}
|
||||
|
||||
int
|
||||
SDLVisualTest_InitVariation(SDLVisualTest_Variation* variation,
|
||||
SDLVisualTest_SUTConfig* config)
|
||||
{
|
||||
int i;
|
||||
SDLVisualTest_SUTOptionValue* vars;
|
||||
SDLVisualTest_SUTOption* options;
|
||||
if(!variation)
|
||||
{
|
||||
SDLTest_LogError("variation argument cannot be NULL");
|
||||
return 0;
|
||||
}
|
||||
if(!config)
|
||||
{
|
||||
SDLTest_LogError("config argument cannot be NULL");
|
||||
return 0;
|
||||
}
|
||||
|
||||
/* initialize the first variation */
|
||||
if(config->num_options <= 0)
|
||||
{
|
||||
SDLTest_LogError("config->num_options must be positive");
|
||||
return 0;
|
||||
}
|
||||
variation->vars = (SDLVisualTest_SUTOptionValue*)SDL_malloc(config->num_options *
|
||||
sizeof(SDLVisualTest_SUTOptionValue));
|
||||
if(!variation->vars)
|
||||
{
|
||||
SDLTest_LogError("malloc() failed");
|
||||
return 0;
|
||||
}
|
||||
variation->num_vars = config->num_options;
|
||||
vars = variation->vars;
|
||||
options = config->options;
|
||||
for(i = 0; i < variation->num_vars; i++)
|
||||
{
|
||||
switch(options[i].type)
|
||||
{
|
||||
case SDL_SUT_OPTIONTYPE_BOOL:
|
||||
vars[i].bool_value = SDL_FALSE;
|
||||
break;
|
||||
|
||||
case SDL_SUT_OPTIONTYPE_ENUM:
|
||||
vars[i].enumerated.on = SDL_TRUE;
|
||||
vars[i].enumerated.index = 0;
|
||||
break;
|
||||
|
||||
case SDL_SUT_OPTIONTYPE_INT:
|
||||
{
|
||||
vars[i].integer.on = SDL_TRUE;
|
||||
vars[i].integer.value = options[i].data.range.min;
|
||||
}
|
||||
break;
|
||||
|
||||
case SDL_SUT_OPTIONTYPE_STRING:
|
||||
vars[i].string.on = SDL_TRUE;
|
||||
vars[i].string.value = options[i].name;
|
||||
break;
|
||||
}
|
||||
}
|
||||
return 1;
|
||||
}
|
Loading…
Add table
Add a link
Reference in a new issue