aboutsummaryrefslogtreecommitdiff
path: root/tests
diff options
context:
space:
mode:
Diffstat (limited to 'tests')
-rwxr-xr-xtests/runner.py32
-rw-r--r--tests/sdl_mouse.c55
2 files changed, 87 insertions, 0 deletions
diff --git a/tests/runner.py b/tests/runner.py
index 3b4680a2..fa566c33 100755
--- a/tests/runner.py
+++ b/tests/runner.py
@@ -6409,6 +6409,38 @@ f.close()
Popen(['python', EMCC, os.path.join(self.get_dir(), 'sdl_key.c'), '-o', 'page.html', '--pre-js', 'pre.js']).communicate()
self.run_browser('page.html', '', '/report_result?30030')
+ def test_sdl_mouse(self):
+ open(os.path.join(self.get_dir(), 'pre.js'), 'w').write('''
+ function simulateMouseEvent(x, y, button) {
+ var event = document.createEvent("MouseEvents");
+ if (button) {
+ var event1 = document.createEvent("MouseEvents");
+ event1.initMouseEvent('mousedown', true, true, window,
+ 1, x, y, x, y,
+ 0, 0, 0, 0,
+ button, null);
+ dispatchEvent(event1);
+ var event2 = document.createEvent("MouseEvents");
+ event2.initMouseEvent('mouseup', true, true, window,
+ 1, x, y, x, y,
+ 0, 0, 0, 0,
+ button, null);
+ dispatchEvent(event2);
+ } else {
+ var event1 = document.createEvent("MouseEvents");
+ event1.initMouseEvent('mouseover', true, true, window,
+ 0, x, y, x, y,
+ 0, 0, 0, 0,
+ 0, null);
+ dispatchEvent(event1);
+ }
+ }
+ ''')
+ open(os.path.join(self.get_dir(), 'sdl_mouse.c'), 'w').write(self.with_report_result(open(path_from_root('tests', 'sdl_mouse.c')).read()))
+
+ Popen(['python', EMCC, os.path.join(self.get_dir(), 'sdl_mouse.c'), '-o', 'page.html', '--pre-js', 'pre.js']).communicate()
+ self.run_browser('page.html', '', '/report_result?740')
+
def test_worker(self):
# Test running in a web worker
output = Popen(['python', EMCC, path_from_root('tests', 'hello_world_worker.cpp'), '-o', 'worker.js'], stdout=PIPE, stderr=PIPE).communicate()
diff --git a/tests/sdl_mouse.c b/tests/sdl_mouse.c
new file mode 100644
index 00000000..87619ef2
--- /dev/null
+++ b/tests/sdl_mouse.c
@@ -0,0 +1,55 @@
+#include <stdio.h>
+#include <SDL/SDL.h>
+#include <SDL/SDL_ttf.h>
+#include <assert.h>
+#include <emscripten.h>
+
+int result = 1;
+
+void one() {
+ SDL_Event event;
+ while (SDL_PollEvent(&event)) {
+ switch(event.type) {
+ case SDL_MOUSEMOTION: {
+ SDL_MouseMotionEvent *m = (SDL_MouseMotionEvent*)&event;
+ int x, y;
+ SDL_GetMouseState(&x, &y);
+ assert(x == m->x && y == m->y);
+ printf("motion: %d,%d %d,%d\n", m->x, m->y, m->xrel, m->yrel);
+ result += 2 * (m->x + m->y + m->xrel + m->yrel);
+ break;
+ }
+ case SDL_MOUSEBUTTONDOWN: {
+ SDL_MouseButtonEvent *m = (SDL_MouseButtonEvent*)&event;
+ if (m->button == 2) {
+ REPORT_RESULT();
+ emscripten_run_script("throw 'done'");
+ }
+ printf("button down: %d,%d %d,%d\n", m->button, m->state, m->x, m->y);
+ result += 3 * (m->button + m->state + m->x + m->y);
+ break;
+ }
+ case SDL_MOUSEBUTTONUP: {
+ SDL_MouseButtonEvent *m = (SDL_MouseButtonEvent*)&event;
+ printf("button up: %d,%d %d,%d\n", m->button, m->state, m->x, m->y);
+ result += 5 * (m->button + m->state + m->x + m->y);
+ break;
+ }
+ }
+ }
+}
+
+int main() {
+ SDL_Init(SDL_INIT_VIDEO);
+ SDL_Surface *screen = SDL_SetVideoMode(600, 450, 32, SDL_HWSURFACE);
+
+ emscripten_run_script("simulateMouseEvent(10, 20, 0)"); // move from 0,0 to 10,20
+ emscripten_run_script("simulateMouseEvent(10, 20, 1)"); // click
+ emscripten_run_script("simulateMouseEvent(30, 77, 0)"); // move some more
+ emscripten_run_script("simulateMouseEvent(30, 77, 2)"); // trigger the end
+
+ emscripten_set_main_loop(one, 0);
+
+ return 0;
+}
+