Jeremy White : twain_32: Add an interactive set of tests for a selected scanner.
Alexandre Julliard
julliard at winehq.org
Thu Jan 29 09:15:36 CST 2009
Module: wine
Branch: master
Commit: b161c1511ca1cf0dc9bd5a5507bae89d452a9fc3
URL: http://source.winehq.org/git/wine.git/?a=commit;h=b161c1511ca1cf0dc9bd5a5507bae89d452a9fc3
Author: Jeremy White <jwhite at winehq.org>
Date: Wed Jan 28 08:52:42 2009 -0600
twain_32: Add an interactive set of tests for a selected scanner.
---
dlls/twain_32/tests/dsm.c | 99 +++++++++++++++++++++++++++++++++++++++++++++
1 files changed, 99 insertions(+), 0 deletions(-)
diff --git a/dlls/twain_32/tests/dsm.c b/dlls/twain_32/tests/dsm.c
index 6ed0a90..293969b 100644
--- a/dlls/twain_32/tests/dsm.c
+++ b/dlls/twain_32/tests/dsm.c
@@ -57,6 +57,92 @@ static void get_condition_code(TW_IDENTITY *appid, TW_IDENTITY *source, TW_STATU
ok(rc == TWRC_SUCCESS, "Condition code not available, rc %d\n", rc);
}
+static void test_single_source(TW_IDENTITY *appid, TW_IDENTITY *source)
+{
+ TW_UINT16 rc;
+ TW_STATUS status;
+ TW_CAPABILITY cap;
+ UINT16 capabilities[CAP_CUSTOMBASE];
+
+ memset(&cap, 0, sizeof(cap));
+ cap.Cap = CAP_SUPPORTEDCAPS;
+ cap.ConType = TWON_DONTCARE16;
+
+ rc = pDSM_Entry(appid, source, DG_CONTROL, DAT_CAPABILITY, MSG_GET, &cap);
+ get_condition_code(appid, source, &status);
+ todo_wine
+ ok(rc == TWRC_SUCCESS || status.ConditionCode == TWCC_SUCCESS,
+ "Error obtaining CAP_SUPPORTEDCAPS\n");
+
+ memset(capabilities, 0, sizeof(capabilities));
+ if (rc == TWRC_SUCCESS && cap.ConType == TWON_ARRAY)
+ {
+ TW_ARRAY *a;
+ a = GlobalLock(cap.hContainer);
+ if (a)
+ {
+ if (a->ItemType == TWTY_UINT16)
+ {
+ int i;
+ UINT16 *u = (UINT16 *) a->ItemList;
+ trace("%d Capabilities:\n", a->NumItems);
+ for (i = 0; i < a->NumItems; i++)
+ if (u[i] < sizeof(capabilities) / sizeof(capabilities[0]))
+ {
+ capabilities[u[i]] = 1;
+ trace(" %d: 0x%x\n", i, u[i]);
+ }
+ }
+ GlobalUnlock(cap.hContainer);
+ }
+ }
+
+ /* For Twain 1.6, all sources must support: */
+ todo_wine
+ ok(capabilities[CAP_SUPPORTEDCAPS], "CAP_SUPPORTEDCAPS not supported\n");
+ todo_wine
+ ok(capabilities[CAP_XFERCOUNT], "CAP_XFERCOUNT not supported\n");
+ todo_wine
+ ok(capabilities[CAP_UICONTROLLABLE], "CAP_UICONTROLLABLE not supported\n");
+
+ if (source->SupportedGroups & DG_IMAGE)
+ {
+ /* For Twain 1.6:
+ Sources that supply image information must support DG_CONTROL / DAT_CAPABILITY /
+ MSG_GET, MSG_GETCURRENT, MSG_GETDEFAULT on:
+ */
+ todo_wine
+ ok(capabilities[ICAP_COMPRESSION], "ICAP_COMPRESSION not supported\n");
+ todo_wine
+ ok(capabilities[ICAP_PLANARCHUNKY], "ICAP_PLANARCHUNKY not supported\n");
+ todo_wine
+ ok(capabilities[ICAP_PHYSICALHEIGHT], "ICAP_PHYSICALHEIGHT not supported\n");
+ todo_wine
+ ok(capabilities[ICAP_PHYSICALWIDTH], "ICAP_PHYSICALWIDTH not supported\n");
+ todo_wine
+ ok(capabilities[ICAP_PIXELFLAVOR], "ICAP_PIXELFLAVOR not supported\n");
+
+ /* For Twain 1.6:
+ Sources that supply image information must support DG_CONTROL / DAT_CAPABILITY /
+ MSG_GET, MSG_GETCURRENT, MSG_GETDEFAULT, MSG_RESET and MSG_SET on:
+ */
+ todo_wine
+ ok(capabilities[ICAP_BITDEPTH], "ICAP_BITDEPTH not supported\n");
+ todo_wine
+ ok(capabilities[ICAP_BITORDER], "ICAP_BITORDER not supported\n");
+ todo_wine
+ ok(capabilities[ICAP_PIXELTYPE], "ICAP_PIXELTYPE not supported\n");
+ todo_wine
+ ok(capabilities[ICAP_UNITS], "ICAP_UNITS not supported\n");
+ todo_wine
+ ok(capabilities[ICAP_XFERMECH], "ICAP_XFERMECH not supported\n");
+ todo_wine
+ ok(capabilities[ICAP_XRESOLUTION], "ICAP_XRESOLUTION not supported\n");
+ todo_wine
+ ok(capabilities[ICAP_YRESOLUTION], "ICAP_YRESOLUTION not supported\n");
+ }
+}
+
static void test_sources(TW_IDENTITY *appid)
{
TW_UINT16 rc;
@@ -115,6 +201,19 @@ static void test_sources(TW_IDENTITY *appid)
rc = pDSM_Entry(appid, NULL, DG_CONTROL, DAT_IDENTITY, MSG_USERSELECT, &source);
get_condition_code(appid, NULL, &status);
ok(rc == TWRC_SUCCESS || rc == TWRC_CANCEL, "Userselect failed, rc %d, cc %d\n", rc, status.ConditionCode);
+
+ if (rc == TWRC_SUCCESS && status.ConditionCode == TWCC_SUCCESS)
+ {
+ rc = pDSM_Entry(appid, NULL, DG_CONTROL, DAT_IDENTITY, MSG_OPENDS, &source);
+ get_condition_code(appid, NULL, &status);
+ if (rc == TWRC_SUCCESS && status.ConditionCode == TWCC_SUCCESS)
+ {
+ test_single_source(appid, &source);
+ rc = pDSM_Entry(appid, NULL, DG_CONTROL, DAT_IDENTITY, MSG_CLOSEDS, &source);
+ get_condition_code(appid, NULL, &status);
+ ok(rc == TWRC_SUCCESS, "Close DS Failed, rc %d, cc %d\n", rc, status.ConditionCode);
+ }
+ }
}
}
More information about the wine-cvs
mailing list