summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSiarhei Siamashka <siarhei.siamashka@nokia.com>2010-05-12 00:10:04 +0300
committerSiarhei Siamashka <siarhei.siamashka@nokia.com>2010-05-13 21:04:36 +0300
commitf905ebb03d8ed8a3ceb76c84a10735aa209168d3 (patch)
tree6548ebb4c7b2581b3185015d287fc11e9e6c406b
parentbe387701a5b44e68110d5c9df07924d1029e87ac (diff)
test: scaling-test updated to use new fuzzer_test_main() function
-rw-r--r--test/scaling-test-bisect.rb38
-rw-r--r--test/scaling-test.c72
2 files changed, 11 insertions, 99 deletions
diff --git a/test/scaling-test-bisect.rb b/test/scaling-test-bisect.rb
deleted file mode 100644
index ab34262..0000000
--- a/test/scaling-test-bisect.rb
+++ /dev/null
@@ -1,38 +0,0 @@
-#!/usr/bin/env ruby
-
-if not ARGV[0] or not ARGV[1] then
- printf("Please provide two 'scaling-test' static binaries in the command line.\n\n")
- printf("The first should be linked with the correct reference pixman library.\n")
- printf("The second binrary should be linked with the pixman library to be tested.\n")
- exit(0)
-end
-
-$MAX = 3000000
-$MIN = 1
-$AVG = 0
-
-if `#{ARGV[0]} #{$MAX} 2>/dev/null` == `#{ARGV[1]} #{$MAX} 2>/dev/null` then
- printf("test ok\n")
- exit(0)
-end
-
-printf("test failed, bisecting...\n")
-
-while $MAX != $MIN + 1 do
- $AVG = (($MIN + $MAX) / 2).to_i
- res1 = `#{ARGV[0]} #{$AVG} 2>/dev/null`
- res2 = `#{ARGV[1]} #{$AVG} 2>/dev/null`
- if res1 != res2 then
- $MAX = $AVG
- else
- $MIN = $AVG
- end
-end
-
-printf("-- ref --\n")
-printf("%s\n", `#{ARGV[0]} -#{$MAX}`)
-printf("-- new --\n")
-printf("%s\n", `#{ARGV[1]} -#{$MAX}`)
-
-printf("\nFailed test number is %d, you can reproduce the problematic conditions\n", $MAX)
-printf("by running 'scaling-test -%d'\n", $MAX)
diff --git a/test/scaling-test.c b/test/scaling-test.c
index 2977290..16583d0 100644
--- a/test/scaling-test.c
+++ b/test/scaling-test.c
@@ -1,24 +1,11 @@
/*
- * Test program, which can detect problems with nearest neighbout scaling
- * implementation. Also SRC and OVER opetations tested for 16bpp and 32bpp
- * images.
+ * Test program, which can detect some problems with nearest neighbour
+ * and bilinear scaling in pixman. Testing is done by running lots
+ * of random SRC and OVER compositing operations a8r8g8b8, x8a8r8g8b8
+ * and r5g6b5 color formats.
*
- * Just run it without any command line arguments, and it will report either
- * "scaling test passed" - everything is ok
- * "scaling test failed!" - there is some problem
- *
- * In the case of failure, finding the problem involves the following steps:
- * 1. Get the reference 'scaling-test' binary. It makes sense to disable all
- * the cpu specific optimizations in pixman and also configure it with
- * '--disable-shared' option. Those who are paranoid can also tweak the
- * sources to disable all fastpath functions. The resulting binary
- * can be renamed to something like 'scaling-test.ref'.
- * 2. Compile the buggy binary (also with the '--disable-shared' option).
- * 3. Run 'ruby scaling-test-bisect.rb ./scaling-test.ref ./scaling-test'
- * 4. Look at the information about failed case (destination buffer content
- * will be shown) and try to figure out what is wrong. It is possible
- * to use debugging print to stderr in pixman to get more information,
- * this does not interfere with the testing script.
+ * Script 'fuzzer-find-diff.pl' can be used to narrow down the problem in
+ * the case of test failure.
*/
#include <assert.h>
#include <stdlib.h>
@@ -35,8 +22,7 @@
* Composite operation with pseudorandom images
*/
uint32_t
-test_composite (uint32_t initcrc,
- int testnum,
+test_composite (int testnum,
int verbose)
{
int i;
@@ -239,53 +225,17 @@ test_composite (uint32_t initcrc,
pixman_image_unref (src_img);
pixman_image_unref (dst_img);
- crc32 = compute_crc32 (initcrc, dstbuf, dst_stride * dst_height);
+ crc32 = compute_crc32 (0, dstbuf, dst_stride * dst_height);
free (srcbuf);
free (dstbuf);
return crc32;
}
int
-main (int argc, char *argv[])
+main (int argc, const char *argv[])
{
- int i, n = 0;
- uint32_t crc = 0;
-
pixman_disable_out_of_bounds_workaround ();
- if (argc >= 2)
- n = atoi (argv[1]);
-
- if (n == 0) n = 3000000;
-
- if (n < 0)
- {
- crc = test_composite (0, -n, 1);
- printf ("crc32=%08X\n", crc);
- }
- else
- {
- for (i = 1; i <= n; i++)
- crc = test_composite (crc, i, 0);
-
- printf ("crc32=%08X\n", crc);
-
- if (n == 3000000)
- {
- /* predefined value for running with all the fastpath functions disabled */
- /* it needs to be updated every time changes are introduced to this program! */
-
- if (crc == 0x2168ACD1)
- {
- printf ("scaling test passed\n");
- }
- else
- {
- printf ("scaling test failed!\n");
- return 1;
- }
- }
- }
-
- return 0;
+ return fuzzer_test_main("scaling", 3000000, 0x7833766A,
+ test_composite, argc, argv);
}