diff options
author | Aleksander Guryanov <caiiiycuk@gmail.com> | 2013-01-30 23:04:49 +0700 |
---|---|---|
committer | Aleksander Guryanov <caiiiycuk@gmail.com> | 2013-01-30 23:09:05 +0700 |
commit | bd6623777f5695602e533e741839b54842ce9926 (patch) | |
tree | 3c781482c44e3724a71d9630a2a2d9438dc83d92 | |
parent | 21d81d9b21832eb15f9a367dc678a4873efb96ee (diff) |
Add automation for sdl palette test
-rwxr-xr-x | tests/runner.py | 26 | ||||
-rw-r--r-- | tests/sdl_canvas_palette_2.c | 60 | ||||
-rw-r--r-- | tests/sdl_canvas_palette_b.png | bin | 0 -> 6708 bytes | |||
-rw-r--r-- | tests/sdl_canvas_palette_g.png | bin | 0 -> 6712 bytes | |||
-rw-r--r-- | tests/sdl_canvas_palette_r.png | bin | 0 -> 6709 bytes |
5 files changed, 50 insertions, 36 deletions
diff --git a/tests/runner.py b/tests/runner.py index 9280bd8e..06b74caa 100755 --- a/tests/runner.py +++ b/tests/runner.py @@ -10389,12 +10389,28 @@ elif 'browser' in str(sys.argv): shutil.copyfile(path_from_root('tests', 'screenshot.png'), os.path.join(self.get_dir(), 'example.png')) self.btest('sdl_rotozoom.c', reference='sdl_rotozoom.png', args=['--preload-file', 'example.png']) - def zzztest_sdl_canvas_palette_2(self): # XXX disabled until we have proper automation - open(os.path.join(self.get_dir(), 'sdl_canvas_palette_2.c'), 'w').write(self.with_report_result(open(path_from_root('tests', 'sdl_canvas_palette_2.c')).read())) - open(os.path.join(self.get_dir(), 'pre.js'), 'w').write('Module[\'preRun\'] = function() { SDL.defaults.copyOnLock = false }') + def test_sdl_canvas_palette_2(self): + open(os.path.join(self.get_dir(), 'pre.js'), 'w').write(''' + Module['preRun'].push(function() { + SDL.defaults.copyOnLock = false; + }); + ''') + + open(os.path.join(self.get_dir(), 'args-r.js'), 'w').write(''' + Module['arguments'] = ['-r']; + ''') - Popen([PYTHON, EMCC, os.path.join(self.get_dir(), 'sdl_canvas_palette_2.c'), '-o', 'page.html', '--pre-js', 'pre.js']).communicate() - self.run_browser('page.html', '') + open(os.path.join(self.get_dir(), 'args-g.js'), 'w').write(''' + Module['arguments'] = ['-g']; + ''') + + open(os.path.join(self.get_dir(), 'args-b.js'), 'w').write(''' + Module['arguments'] = ['-b']; + ''') + + self.btest('sdl_canvas_palette_2.c', reference='sdl_canvas_palette_r.png', args=['--pre-js', 'pre.js', '--pre-js', 'args-r.js']) + self.btest('sdl_canvas_palette_2.c', reference='sdl_canvas_palette_g.png', args=['--pre-js', 'pre.js', '--pre-js', 'args-g.js']) + self.btest('sdl_canvas_palette_2.c', reference='sdl_canvas_palette_b.png', args=['--pre-js', 'pre.js', '--pre-js', 'args-b.js']) def test_glbegin_points(self): shutil.copyfile(path_from_root('tests', 'screenshot.png'), os.path.join(self.get_dir(), 'screenshot.png')) diff --git a/tests/sdl_canvas_palette_2.c b/tests/sdl_canvas_palette_2.c index db9c3207..11d727ac 100644 --- a/tests/sdl_canvas_palette_2.c +++ b/tests/sdl_canvas_palette_2.c @@ -1,59 +1,40 @@ #include <stdio.h> #include <SDL/SDL.h> #include <emscripten.h> +#include <string.h> static const int COLOR_COUNT = 32; static SDL_Surface *screen; static SDL_Color pal[COLOR_COUNT +1]; -void initializePalette() { +void pallete(int red, int green, int blue) { //initialize sdl palette - //with red green and blue - //colors + //with gradient colors pal[0].r = 0; pal[0].g = 0; pal[0].b = 0; pal[0].unused = 0; for (int i=1; i< 1 + COLOR_COUNT; i++) { - pal[i].r = 255 / COLOR_COUNT * i; - pal[i].g = 0; - pal[i].b = 0; + pal[i].r = (float) red / COLOR_COUNT * i; + pal[i].g = (float) green / COLOR_COUNT * i; + pal[i].b = (float) blue / COLOR_COUNT * i; pal[i].unused = 0; } SDL_SetColors(screen, pal, 0, 1 + COLOR_COUNT); } -void animatePalette() { - SDL_Color temporary; - temporary = pal[1]; - for (int i=2; i< 1 + COLOR_COUNT; i++) { - pal[i-1] = pal[i]; - } - pal[COLOR_COUNT] = temporary; - - SDL_SetColors(screen, pal, 1, COLOR_COUNT); - - //refreshing - SDL_LockSurface(screen); - SDL_UnlockSurface(screen); - - printf("yet another cycle\n"); -} - -int main() { +int main(int argc, char** argv) { SDL_Init(SDL_INIT_VIDEO); - screen = SDL_SetVideoMode(600, 400, 8, SDL_HWSURFACE | SDL_HWPALETTE); + screen = SDL_SetVideoMode(600, 450, 8, SDL_HWSURFACE | SDL_HWPALETTE); //test empty pallete SDL_LockSurface(screen); SDL_UnlockSurface(screen); - initializePalette(); - - //palette is red yellow blue + //Draw gradient SDL_LockSurface(screen); int size = screen->h * screen->pitch; char *color = screen->pixels; @@ -66,9 +47,26 @@ int main() { } SDL_UnlockSurface(screen); - //Animation - printf("you should see red gradient animation\n"); - emscripten_set_main_loop(animatePalette, 0, 1); + //Set pallete + if (argc > 1) { + printf("%s\n", argv[1]); + if (strcmp(argv[1], "-r") == 0) { + printf("set [red]\n"); + pallete(255, 0, 0); + } + if (strcmp(argv[1], "-g") == 0) { + printf("set [green]\n"); + pallete(0, 255, 0); + } + if (strcmp(argv[1], "-b") == 0) { + printf("set [blue]\n"); + pallete(0, 0, 255); + } + } + + //refreshing + SDL_LockSurface(screen); + SDL_UnlockSurface(screen); SDL_Quit(); diff --git a/tests/sdl_canvas_palette_b.png b/tests/sdl_canvas_palette_b.png Binary files differnew file mode 100644 index 00000000..54ed7e9a --- /dev/null +++ b/tests/sdl_canvas_palette_b.png diff --git a/tests/sdl_canvas_palette_g.png b/tests/sdl_canvas_palette_g.png Binary files differnew file mode 100644 index 00000000..a2a5484d --- /dev/null +++ b/tests/sdl_canvas_palette_g.png diff --git a/tests/sdl_canvas_palette_r.png b/tests/sdl_canvas_palette_r.png Binary files differnew file mode 100644 index 00000000..29b8226b --- /dev/null +++ b/tests/sdl_canvas_palette_r.png |