Refining the fuzzer. Adding new functions and fixing the old ones.
This commit is contained in:
parent
fc76a5fa6a
commit
279a841b64
3 changed files with 101 additions and 32 deletions
|
@ -1,8 +1,3 @@
|
||||||
#include <stdio.h>
|
|
||||||
#include <stdlib.h>
|
|
||||||
|
|
||||||
#include <string.h>
|
|
||||||
|
|
||||||
|
|
||||||
#include "../SDL_test.h"
|
#include "../SDL_test.h"
|
||||||
|
|
||||||
|
@ -77,43 +72,74 @@ RandomInteger()
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
RandomPositiveIntegerInRange(int min, int max)
|
RandomPositiveInteger()
|
||||||
{
|
{
|
||||||
int number = utl_randomInt(&rndContext3);
|
return abs(utl_randomInt(&rndContext3));
|
||||||
number = abs(number);
|
|
||||||
|
|
||||||
return (number % (max - min)) + min;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
int
|
int
|
||||||
RandomBoundaryValue(const int max)
|
RandomIntegerInRange(int min, int max)
|
||||||
{
|
{
|
||||||
// Note: somehow integrate with RandomInteger?
|
if(min > max || (min - max) == 0) {
|
||||||
// try to make more sensible & add new values
|
return -1; // Doesn't really make sense to return -1 on error?
|
||||||
int boundaryValues[] = {0, 1, 15, 16, 17, 31, 32, 33, 63, 64, 65};
|
}
|
||||||
int retValue = -1;
|
|
||||||
|
|
||||||
do {
|
int number = utl_randomInt(&rndContext3);
|
||||||
int index = RandomPositiveIntegerInRange(0, 10);
|
number = abs(number);
|
||||||
retValue = boundaryValues[index];
|
|
||||||
|
|
||||||
} while( !(retValue <= max) );
|
return (number % ((max + 1) - min)) + min;
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
GenerateBoundaryValueForSize(const int size)
|
||||||
|
{
|
||||||
|
if(size < 0) {
|
||||||
|
return -1;
|
||||||
|
}
|
||||||
|
|
||||||
|
const int adjustment = RandomIntegerInRange(-1, 1);
|
||||||
|
int retValue = (1 << (RandomPositiveInteger() % size)) + adjustment;
|
||||||
|
|
||||||
return retValue;
|
return retValue;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
RandomUint8BoundaryValue()
|
||||||
|
{
|
||||||
|
return GenerateBoundaryValueForSize(8);
|
||||||
|
}
|
||||||
|
|
||||||
|
int
|
||||||
|
RandomInt8BoundaryValue()
|
||||||
|
{
|
||||||
|
int value = GenerateBoundaryValueForSize(8);
|
||||||
|
|
||||||
|
return (RandomPositiveInteger() % 2 == 0 ? value : -value);
|
||||||
|
}
|
||||||
|
|
||||||
char *
|
char *
|
||||||
RandomAsciiString()
|
RandomAsciiString()
|
||||||
{
|
{
|
||||||
const int size = abs(RandomInteger);
|
return RandomAsciiStringWithMaximumLength(255);
|
||||||
|
}
|
||||||
|
|
||||||
|
char *
|
||||||
|
RandomAsciiStringWithMaximumLength(int maxSize)
|
||||||
|
{
|
||||||
|
if(maxSize < 0) {
|
||||||
|
return NULL;
|
||||||
|
}
|
||||||
|
|
||||||
|
const int size = abs(RandomInteger) % maxSize;
|
||||||
char *string = SDL_malloc(size * sizeof(size));
|
char *string = SDL_malloc(size * sizeof(size));
|
||||||
|
|
||||||
int counter = 0;
|
int counter = 0;
|
||||||
for( ; counter < size; ++counter) {
|
for( ; counter < size; ++counter) {
|
||||||
char character = (char) RandomPositiveIntegerInRange(0, 127);
|
char character = (char) RandomPositiveIntegerInRange(1, 127);
|
||||||
string[counter] = character;
|
string[counter] = character;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
string[counter] = '\0';
|
||||||
|
|
||||||
return string;
|
return string;
|
||||||
}
|
}
|
||||||
|
|
|
@ -25,11 +25,13 @@
|
||||||
#include "utl_md5.h"
|
#include "utl_md5.h"
|
||||||
#include "utl_random.h"
|
#include "utl_random.h"
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Inits the fuzzer for a test
|
* Inits the fuzzer for a test
|
||||||
*/
|
*/
|
||||||
void InitFuzzer(const int execKey);
|
void InitFuzzer(const int execKey);
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Deinits the fuzzer (for a test)
|
* Deinits the fuzzer (for a test)
|
||||||
*/
|
*/
|
||||||
|
@ -37,33 +39,68 @@ void DeinitFuzzer();
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Returns random integer
|
* Returns a random integer
|
||||||
*
|
*
|
||||||
* \returns Generated integer
|
* \returns Generated integer
|
||||||
*/
|
*/
|
||||||
int RandomInteger();
|
int RandomInteger();
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Returns positive integer in range [min, max]
|
* Returns a random positive integer
|
||||||
*
|
*
|
||||||
* \returns Generated integer
|
* \returns Generated integer
|
||||||
*/
|
*/
|
||||||
int RandomPositiveIntegerInRange(int min, int max);
|
int RandomPositiveInteger();
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Generates random ASCII string
|
* Returns integer in range [min, max]. Min and max
|
||||||
|
* value can be negative values as long as min is smaller than max.
|
||||||
|
* Min and max also can't be the same value.
|
||||||
|
*
|
||||||
|
* \returns Generated integer or ? in error
|
||||||
|
*/
|
||||||
|
int RandomIntegerInRange(int min, int max);
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* Generates random null-terminated string. The maximum length for
|
||||||
|
* the string is 255 characters and it can contain ASCII characters
|
||||||
|
* from 1 to 127.
|
||||||
|
*
|
||||||
|
* Note: Returned string needs to be deallocated.
|
||||||
*
|
*
|
||||||
* \returns newly allocated random string
|
* \returns newly allocated random string
|
||||||
*/
|
*/
|
||||||
char *RandomAsciiString();
|
char *RandomAsciiString();
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Generates a random boundary value. Max is the biggest
|
* Generates random null-terminated string. The maximum length for
|
||||||
* value the function can return.
|
* the string is defined by maxLenght parameter.
|
||||||
|
* String can contain ASCII characters from 1 to 127.
|
||||||
*
|
*
|
||||||
* \returns a boundary value
|
* Note: Returned string needs to be deallocated.
|
||||||
|
*
|
||||||
|
* \param maxLength Maximum length of the generated string
|
||||||
|
*
|
||||||
|
* \returns newly allocated random string
|
||||||
*/
|
*/
|
||||||
int RandomBoundaryValue(const int max);
|
char *RandomAsciiStringWithMaximumLength(int maxLength);
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* todo add markup
|
||||||
|
*/
|
||||||
|
int RandomUint8BoundaryValue();
|
||||||
|
|
||||||
|
|
||||||
|
/*!
|
||||||
|
* todo add markup
|
||||||
|
*/
|
||||||
|
int RandomInt8BoundaryValue();
|
||||||
|
|
||||||
|
|
||||||
/*!
|
/*!
|
||||||
* Generates execution key (used for random seed) for a test
|
* Generates execution key (used for random seed) for a test
|
||||||
|
|
|
@ -91,9 +91,15 @@ dummycase1(void *arg)
|
||||||
{
|
{
|
||||||
AssertEquals(5, 5, "Assert message");
|
AssertEquals(5, 5, "Assert message");
|
||||||
|
|
||||||
|
for(; 1 ;) {
|
||||||
|
Log(0, "uint8: %d", RandomUint8BoundaryValue());
|
||||||
|
Log(0, "int8: %d", RandomInt8BoundaryValue());
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
for(; 0 ;) {
|
for(; 0 ;) {
|
||||||
int min = 50;
|
int min = -5;
|
||||||
int max = 69;
|
int max = 5;
|
||||||
int random = RandomPositiveIntegerInRange(min, max);
|
int random = RandomPositiveIntegerInRange(min, max);
|
||||||
if(random < min || random > max ) {
|
if(random < min || random > max ) {
|
||||||
AssertFail("Generated incorrect integer");
|
AssertFail("Generated incorrect integer");
|
||||||
|
@ -101,7 +107,7 @@ dummycase1(void *arg)
|
||||||
Log(0, "%d", random);
|
Log(0, "%d", random);
|
||||||
}
|
}
|
||||||
|
|
||||||
//Log(0, "Random: %s", RandomAsciiString());
|
//Log(0, "Random: %s", RandomAsciiStringWithMaximumLength(2));
|
||||||
}
|
}
|
||||||
|
|
||||||
void
|
void
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue