diff options
Diffstat (limited to 'xc/test/xsuite/xtest/tset/CH08/mpntfy/mpntfy.m')
-rw-r--r-- | xc/test/xsuite/xtest/tset/CH08/mpntfy/mpntfy.m | 405 |
1 files changed, 405 insertions, 0 deletions
diff --git a/xc/test/xsuite/xtest/tset/CH08/mpntfy/mpntfy.m b/xc/test/xsuite/xtest/tset/CH08/mpntfy/mpntfy.m new file mode 100644 index 000000000..444cefe92 --- /dev/null +++ b/xc/test/xsuite/xtest/tset/CH08/mpntfy/mpntfy.m @@ -0,0 +1,405 @@ +/* + * Copyright 1990, 1991 by the Massachusetts Institute of Technology and + * UniSoft Group Limited. + * + * Permission to use, copy, modify, distribute, and sell this software and + * its documentation for any purpose is hereby granted without fee, + * provided that the above copyright notice appear in all copies and that + * both that copyright notice and this permission notice appear in + * supporting documentation, and that the names of MIT and UniSoft not be + * used in advertising or publicity pertaining to distribution of the + * software without specific, written prior permission. MIT and UniSoft + * make no representations about the suitability of this software for any + * purpose. It is provided "as is" without express or implied warranty. + * + * $XConsortium$ + */ +>>TITLE MapNotify CH08 +>>EXTERN +#define EVENT MapNotify +#define MASK StructureNotifyMask +#define MASKP SubstructureNotifyMask +>>ASSERTION Good A +When a window's state changes from unmapped to mapped +as a result of save-set processing, +then a xname event is generated. +>>STRATEGY +Create client2. +Create parent window with client2. +Create child window as inferior to parent. +Add child window to client2's save-set. +Set client2's shut down mode to DestroyAll. +Select for MapNotify events on child. +Call XCloseDisplay with client2. +Verify that a MapNotify event was delivered. +Verify that event member fields are correctly set. +>>CODE +Display *display = Dsp; +Display *client2; +Window child; +Window parent; +XEvent event_return; +XMapEvent good; +struct area area; + +/* Create client2. */ + if (config.display == (char *) NULL) { + delete("config.display not set"); + return; + } + else + CHECK; + client2 = XOpenDisplay(config.display); + if (client2 == (Display *) NULL) { + delete("Couldn't create client2."); + return; + } + else + CHECK; +/* Create parent window with client2. */ + /* must avoid resource registration! */ + parent = XCreateSimpleWindow(display, DRW(display), 1, 1, W_STDWIDTH, W_STDHEIGHT, 1, 0L, 0L); + XSync(client2, True); +/* Create child window as inferior to parent. */ + area.x = 1; + area.y = 1; + area.width = W_STDWIDTH/2; + area.height = W_STDHEIGHT/2; + child = mkwinchild(display, (XVisualInfo *) NULL, &area, False, parent, 1); + XSync(display, True); +/* Add child window to client2's save-set. */ + XAddToSaveSet(client2, child); +/* Set client2's shut down mode to DestroyAll. */ + XSetCloseDownMode(client2, DestroyAll); +/* Select for MapNotify events on child. */ + XSelectInput(display, child, MASK); +/* Call XCloseDisplay with client2. */ + XSync(display, True); + XSync(client2, True); + XCloseDisplay(client2); + XSync(display, False); +/* Verify that a MapNotify event was delivered. */ + if (!XCheckTypedWindowEvent(display, child, EVENT, &event_return)) { + report("Expected %s event, got none", eventname(EVENT)); + FAIL; + } + else + CHECK; +/* Verify that event member fields are correctly set. */ + good = event_return.xmap; + good.type = EVENT; + good.event = child; + good.window = child; + if (checkevent((XEvent *) &good, &event_return)) { + report("Unexpected values in delivered event"); + FAIL; + } + else + CHECK; + + CHECKPASS(4); +>>#NOTEm >>ASSERTION +>>#NOTEm When a window's state changes from unmapped to mapped +>>#NOTEm as a result of a call to +>>#NOTEm .F XMapWindow , +>>#NOTEm .F XMapRaised , +>>#NOTEm .F XMapSubwindows , +>>#NOTEm or +>>#NOTEm .F XReparentWindow , +>>#NOTEm then ARTICLE xname event is generated. +>>ASSERTION Good A +When a xname event is generated, +then all clients having set +.S StructureNotifyMask +event mask bits on the mapped window are delivered +a xname event. +>>STRATEGY +Create clients client2 and client3. +Create window. +Select for MapNotify events using StructureNotifyMask. +Select for MapNotify events using StructureNotifyMask with client2. +Select for no events with client3. +Generate MapNotify event. +Verify that a MapNotify event was delivered. +Verify that event member fields are correctly set. +Verify that a MapNotify event was delivered to client2. +Verify that event member fields are correctly set. +Verify that no events were delivered to client3. +>>CODE +Display *display = Dsp; +Display *client2; +Display *client3; +Window w; +int count; +XEvent event_return; +XMapEvent good; + +/* Create clients client2 and client3. */ + if ((client2 = opendisplay()) == (Display *) NULL) { + delete("Couldn't create client2."); + return; + } + else + CHECK; + if ((client3 = opendisplay()) == (Display *) NULL) { + delete("Couldn't create client3."); + return; + } + else + CHECK; +/* Create window. */ + w = mkwin(display, (XVisualInfo *) NULL, (struct area *) NULL, False); +/* Select for MapNotify events using StructureNotifyMask. */ + XSelectInput(display, w, MASK); +/* Select for MapNotify events using StructureNotifyMask with client2. */ + XSelectInput(client2, w, MASK); +/* Select for no events with client3. */ + XSelectInput(client3, w, NoEventMask); +/* Generate MapNotify event. */ + XSync(display, True); + XSync(client2, True); + XSync(client3, True); + XMapWindow(display, w); + XSync(display, False); + XSync(client2, False); + XSync(client3, False); +/* Verify that a MapNotify event was delivered. */ +/* Verify that event member fields are correctly set. */ + if (!XCheckTypedWindowEvent(display, w, EVENT, &event_return)) { + report("Expected %s event, got none", eventname(EVENT)); + FAIL; + } + else + CHECK; + good = event_return.xmap; + good.type = EVENT; + good.event = w; + good.window = w; + good.override_redirect = config.debug_override_redirect; + if (checkevent((XEvent *) &good, &event_return)) { + report("Unexpected values in delivered event"); + FAIL; + } + else + CHECK; +/* Verify that a MapNotify event was delivered to client2. */ +/* Verify that event member fields are correctly set. */ + if (!XCheckTypedWindowEvent(client2, w, EVENT, &event_return)) { + report("Expected %s event, got none", eventname(EVENT)); + FAIL; + } + else + CHECK; + good = event_return.xmap; + good.type = EVENT; + good.event = w; + good.window = w; + good.override_redirect = config.debug_override_redirect; + if (checkevent((XEvent *) &good, &event_return)) { + report("Unexpected values in delivered event for client2"); + FAIL; + } + else + CHECK; +/* Verify that no events were delivered to client3. */ + count = XPending(client3); + if (count != 0) { + report("Got %d events, expected %d for client3", count, 0); + FAIL; + return; + } + else + CHECK; + + CHECKPASS(7); +>>ASSERTION Good A +When a xname event is generated, +then all clients having set +.S SubstructureNotifyMask +event mask bits on the parent of the mapped window are delivered +a xname event. +>>STRATEGY +Create clients client2 and client3. +Create window. +Select for MapNotify events using SubstructureNotifyMask. +Select for MapNotify events using SubstructureNotifyMask with client2. +Select for no events with client3. +Generate MapNotify event. +Verify that a MapNotify event was delivered. +Verify that event member fields are correctly set. +Verify that a MapNotify event was delivered to client2. +Verify that event member fields are correctly set. +Verify that no events were delivered to client3. +>>CODE +Display *display = Dsp; +Display *client2; +Display *client3; +Window w; +int count; +XEvent event_return; +XMapEvent good; + +/* Create clients client2 and client3. */ + if ((client2 = opendisplay()) == (Display *) NULL) { + delete("Couldn't create client2."); + return; + } + else + CHECK; + if ((client3 = opendisplay()) == (Display *) NULL) { + delete("Couldn't create client3."); + return; + } + else + CHECK; +/* Create window. */ + w = mkwin(display, (XVisualInfo *) NULL, (struct area *) NULL, False); +/* Select for MapNotify events using SubstructureNotifyMask. */ + XSelectInput(display, DRW(display), MASKP); +/* Select for MapNotify events using SubstructureNotifyMask with client2. */ + XSelectInput(client2, DRW(display), MASKP); +/* Select for no events with client3. */ + XSelectInput(client3, DRW(display), NoEventMask); +/* Generate MapNotify event. */ + XSync(display, True); + XSync(client2, True); + XSync(client3, True); + XMapWindow(display, w); + XSync(display, False); + XSync(client2, False); + XSync(client3, False); +/* Verify that a MapNotify event was delivered. */ +/* Verify that event member fields are correctly set. */ + if (!XCheckTypedWindowEvent(display, DRW(display), EVENT, &event_return)) { + report("Expected %s event, got none", eventname(EVENT)); + FAIL; + } + else + CHECK; + good = event_return.xmap; + good.type = EVENT; + good.event = DRW(display); + good.window = w; + good.override_redirect = config.debug_override_redirect; + if (checkevent((XEvent *) &good, &event_return)) { + report("Unexpected values in delivered event"); + FAIL; + } + else + CHECK; +/* Verify that a MapNotify event was delivered to client2. */ +/* Verify that event member fields are correctly set. */ + if (!XCheckTypedWindowEvent(client2, DRW(display), EVENT, &event_return)) { + report("Expected %s event, got none", eventname(EVENT)); + FAIL; + } + else + CHECK; + good = event_return.xmap; + good.type = EVENT; + good.event = DRW(display); + good.window = w; + good.override_redirect = config.debug_override_redirect; + if (checkevent((XEvent *) &good, &event_return)) { + report("Unexpected values in delivered event for client2"); + FAIL; + } + else + CHECK; +/* Verify that no events were delivered to client3. */ + count = XPending(client3); + if (count != 0) { + report("Got %d events, expected %d for client3", count, 0); + FAIL; + return; + } + else + CHECK; + + CHECKPASS(7); +>>ASSERTION def +>>#NOTE Tested for in previous two assertions. +When a xname event is generated, +then +clients not having set +.S StructureNotifyMask +event mask bits on the +mapped window +and also not having set +.S SubstructureNotifyMask +event mask bits on the +parent of the mapped window +are not delivered +a xname event. +>>#NOTEs >>ASSERTION +>>#NOTEs When ARTICLE xname event is delivered, +>>#NOTEs then +>>#NOTEs .M type +>>#NOTEs is set to +>>#NOTEs xname. +>>#NOTEs >>ASSERTION +>>#NOTEs >>#NOTE The method of expansion is not clear. +>>#NOTEs When ARTICLE xname event is delivered, +>>#NOTEs then +>>#NOTEs .M serial +>>#NOTEs is set +>>#NOTEs from the serial number reported in the protocol +>>#NOTEs but expanded from the 16-bit least-significant bits +>>#NOTEs to a full 32-bit value. +>>#NOTEm >>ASSERTION +>>#NOTEm When ARTICLE xname event is delivered +>>#NOTEm and the event came from a +>>#NOTEm .S SendEvent +>>#NOTEm protocol request, +>>#NOTEm then +>>#NOTEm .M send_event +>>#NOTEm is set to +>>#NOTEm .S True . +>>#NOTEs >>ASSERTION +>>#NOTEs When ARTICLE xname event is delivered +>>#NOTEs and the event was not generated by a +>>#NOTEs .S SendEvent +>>#NOTEs protocol request, +>>#NOTEs then +>>#NOTEs .M send_event +>>#NOTEs is set to +>>#NOTEs .S False . +>>#NOTEs >>ASSERTION +>>#NOTEs When ARTICLE xname event is delivered, +>>#NOTEs then +>>#NOTEs .M display +>>#NOTEs is set to +>>#NOTEs a pointer to the display on which the event was read. +>>#NOTEs >>ASSERTION +>>#NOTEs When ARTICLE xname event is delivered +>>#NOTEs and +>>#NOTEs .S StructureNotify +>>#NOTEs was selected, +>>#NOTEs then +>>#NOTEs .M event +>>#NOTEs is set to +>>#NOTEs the WINDOWTYPE window. +>>#NOTEs >>ASSERTION +>>#NOTEs When ARTICLE xname event is delivered +>>#NOTEs and +>>#NOTEs .S SubstructureNotify +>>#NOTEs was selected, +>>#NOTEs then +>>#NOTEs .M event +>>#NOTEs is set to +>>#NOTEs the WINDOWTYPE window's parent. +>>#NOTEs >>ASSERTION +>>#NOTEs >>#NOTE Global except for MappingNotify and KeymapNotify. +>>#NOTEs When ARTICLE xname event is delivered, +>>#NOTEs then +>>#NOTEs .M window +>>#NOTEs is set to +>>#NOTEs the +>>#NOTEs ifdef(`WINDOWTYPE', WINDOWTYPE, event) +>>#NOTEs window. +>>#NOTEs >>ASSERTION +>>#NOTEs When ARTICLE xname event is delivered, +>>#NOTEs then +>>#NOTEs .M override_redirect +>>#NOTEs is set to the override-redirect attribute of +>>#NOTEs .M window . |