Refining the fuzzer. Adding new functions and fixing the old ones.
authorMarkus Kauppila <markus.kauppila@gmail.com>
Mon, 25 Jul 2011 18:51:57 +0300
changeset 5782 3e6c6c39f908
parent 5781 7ff8df8e36f2
child 5783 236ed35e4b34
Refining the fuzzer. Adding new functions and fixing the old ones.
test/test-automation/fuzzer/fuzzer.c
test/test-automation/fuzzer/fuzzer.h
test/test-automation/testdummy/testdummy.c
--- a/test/test-automation/fuzzer/fuzzer.c	Sun Jul 24 18:58:36 2011 +0300
+++ b/test/test-automation/fuzzer/fuzzer.c	Mon Jul 25 18:51:57 2011 +0300
@@ -1,8 +1,3 @@
-#include <stdio.h>
-#include <stdlib.h>
-
-#include <string.h>
-
 
 #include "../SDL_test.h"
 
@@ -77,43 +72,74 @@
 }
 
 int
-RandomPositiveIntegerInRange(int min, int max)
+RandomPositiveInteger()
 {
-	int number = utl_randomInt(&rndContext3);
-	number = abs(number);
-
-	return (number % (max - min)) + min;
+	return abs(utl_randomInt(&rndContext3));
 }
 
 int
-RandomBoundaryValue(const int max)
+RandomIntegerInRange(int min, int max)
 {
-	// Note: somehow integrate with RandomInteger?
-	// try to make more sensible & add new values
-	int boundaryValues[] = {0, 1, 15, 16, 17, 31, 32, 33, 63, 64, 65};
-	int retValue = -1;
+	if(min > max || (min - max) == 0) {
+		return -1; // Doesn't really make sense to return -1 on error?
+	}
+
+	int number = utl_randomInt(&rndContext3);
+	number = abs(number);
+
+	return (number % ((max + 1) - min)) + min;
+}
 
-	do {
-		int index = RandomPositiveIntegerInRange(0, 10);
-		retValue = boundaryValues[index];
+int
+GenerateBoundaryValueForSize(const int size)
+{
+	if(size < 0) {
+		return -1;
+	}
 
-	} while( !(retValue <= max) );
+	const int adjustment = RandomIntegerInRange(-1, 1);
+	int retValue = (1 << (RandomPositiveInteger() % size)) + adjustment;
 
 	return retValue;
 }
 
+int
+RandomUint8BoundaryValue()
+{
+	return GenerateBoundaryValueForSize(8);
+}
+
+int
+RandomInt8BoundaryValue()
+{
+	int value = GenerateBoundaryValueForSize(8);
+
+	return (RandomPositiveInteger() % 2 == 0 ? value : -value);
+}
 
 char *
 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));
 
 	int counter = 0;
 	for( ; counter < size; ++counter) {
-		char character = (char) RandomPositiveIntegerInRange(0, 127);
+		char character = (char) RandomPositiveIntegerInRange(1, 127);
 		string[counter] = character;
 	}
 
+	string[counter] = '\0';
+
 	return string;
 }
--- a/test/test-automation/fuzzer/fuzzer.h	Sun Jul 24 18:58:36 2011 +0300
+++ b/test/test-automation/fuzzer/fuzzer.h	Mon Jul 25 18:51:57 2011 +0300
@@ -25,11 +25,13 @@
 #include "utl_md5.h"
 #include "utl_random.h"
 
+
 /*!
  * Inits the fuzzer for a test
  */
 void InitFuzzer(const int execKey);
 
+
 /*!
  * Deinits the fuzzer (for a test)
  */
@@ -37,33 +39,68 @@
 
 
 /*!
- * Returns random integer
+ * Returns a random integer
  *
  * \returns Generated integer
  */
 int RandomInteger();
 
+
 /*!
- * Returns positive integer in range [min, max]
+ * Returns a random positive 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
  */
 char *RandomAsciiString();
 
+
 /*!
- * Generates a random boundary value. Max is the biggest
- * value the function can return.
+ * Generates random null-terminated string. The maximum length for
+ * the string is defined by maxLenght parameter.
+ * String can contain ASCII characters from 1 to 127.
+ *
+ * Note: Returned string needs to be deallocated.
+ *
+ * \param maxLength Maximum length of the generated string
  *
- * \returns a boundary value
+ * \returns newly allocated random string
+ */
+char *RandomAsciiStringWithMaximumLength(int maxLength);
+
+
+/*!
+ * todo add markup
  */
-int RandomBoundaryValue(const int max);
+int RandomUint8BoundaryValue();
+
+
+/*!
+ * todo add markup
+ */
+int RandomInt8BoundaryValue();
+
 
 /*!
  * Generates execution key (used for random seed) for a test
--- a/test/test-automation/testdummy/testdummy.c	Sun Jul 24 18:58:36 2011 +0300
+++ b/test/test-automation/testdummy/testdummy.c	Mon Jul 25 18:51:57 2011 +0300
@@ -91,9 +91,15 @@
 {
 	AssertEquals(5, 5, "Assert message");
 
+	for(; 1 ;) {
+		Log(0, "uint8: %d", RandomUint8BoundaryValue());
+		Log(0, "int8: %d", RandomInt8BoundaryValue());
+
+	}
+
 	for(; 0 ;) {
-		int min = 50;
-		int max = 69;
+		int min = -5;
+		int max = 5;
 		int random =  RandomPositiveIntegerInRange(min, max);
 		if(random < min || random > max ) {
 			AssertFail("Generated incorrect integer");
@@ -101,7 +107,7 @@
 		Log(0, "%d", random);
 	}
 
-	//Log(0, "Random: %s", RandomAsciiString());
+	//Log(0, "Random: %s", RandomAsciiStringWithMaximumLength(2));
 }
 
 void