/* * tests for the language neutral word breaker * * Copyright 2006 Mike McCormack for CodeWeavers * * This library is free software; you can redistribute it and/or * modify it under the terms of the GNU Lesser General Public * License as published by the Free Software Foundation; either * version 2.1 of the License, or (at your option) any later version. * * This library is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU * Lesser General Public License for more details. * * You should have received a copy of the GNU Lesser General Public * License along with this library; if not, write to the Free Software * Foundation, Inc., 51 Franklin St, Fifth Floor, Boston, MA 02110-1301, USA */ #define COBJMACROS #define CONST_VTABLE #include #include #include "indexsrv.h" #include "cierror.h" #include "wine/test.h" #include DEFINE_GUID(CLSID_wb_neutral, 0x369647e0,0x17b0,0x11ce,0x99,0x50,0x00,0xaa,0x00,0x4b,0xbb,0x1f); DEFINE_GUID(_IID_IWordBreaker, 0xD53552C8,0x77E3,0x101A,0xB5,0x52,0x08,0x00,0x2B,0x33,0xB0,0xE6); static const WCHAR teststring[] = L"square circle triangle box"; struct expected { UINT ofs; UINT len; WCHAR data[10]; }; static int wordnum; static struct expected testres[] = { { 0, 6, L"square" }, { 7, 6, L"circle" }, { 14, 8, L"triangle" }, { 23, 3, L"box" }, }; static HRESULT WINAPI ws_QueryInterface(IWordSink *iface, REFIID riid, void **ppvObject) { ok(0, "not expected\n"); return E_NOINTERFACE; } static ULONG WINAPI ws_AddRef(IWordSink *iface) { ok(0, "not expected\n"); return 2; } static ULONG WINAPI ws_Release(IWordSink *iface) { ok(0, "not expected\n"); return 1; } static HRESULT WINAPI ws_PutWord(IWordSink *iface, ULONG cwc, const WCHAR *pwcInBuf, ULONG cwcSrcLen, ULONG cwcSrcPos) { HRESULT rc = S_OK; winetest_push_context("word %d", wordnum); if (wordnum < ARRAY_SIZE(testres)) { ok(testres[wordnum].len == cwcSrcLen, "expected length %d, got %ld\n", testres[wordnum].len, cwcSrcLen); ok(!cwcSrcPos || (testres[wordnum].ofs == cwcSrcPos), "expected offset %d, got %ld\n", testres[wordnum].ofs, cwcSrcPos); ok(!memcmp(testres[wordnum].data, pwcInBuf, cwcSrcLen), "expected data %s, got %s\n", wine_dbgstr_wn(testres[wordnum].data, cwcSrcLen), wine_dbgstr_wn(pwcInBuf, cwcSrcLen)); } else { ok(0, "found too many words: %d\n", wordnum + 1); rc = E_FAIL; } winetest_pop_context(); wordnum++; return rc; } static HRESULT WINAPI ws_PutAltWord(IWordSink *iface, ULONG cwc, const WCHAR *pwcInBuf, ULONG cwcSrcLen, ULONG cwcSrcPos) { ok(0, "not expected\n"); return S_OK; } static HRESULT WINAPI ws_StartAltPhrase(IWordSink *iface) { ok(0, "not expected\n"); return S_OK; } static HRESULT WINAPI ws_EndAltPhrase(IWordSink *iface) { ok(0, "not expected\n"); return S_OK; } static HRESULT WINAPI ws_PutBreak(IWordSink *iface, WORDREP_BREAK_TYPE breakType) { ok(0, "not expected\n"); return S_OK; } static const IWordSinkVtbl wsvt = { ws_QueryInterface, ws_AddRef, ws_Release, ws_PutWord, ws_PutAltWord, ws_StartAltPhrase, ws_EndAltPhrase, ws_PutBreak, }; typedef struct _wordsink_impl { IWordSink IWordSink_iface; } wordsink_impl; static wordsink_impl wordsink = { { &wsvt } }; static HRESULT WINAPI fillbuf_none(TEXT_SOURCE *ts) { return WBREAK_E_END_OF_TEXT; } static HRESULT WINAPI fillbuf_many(TEXT_SOURCE *ts) { int i; if (ts->awcBuffer == NULL) ts->awcBuffer = teststring; else ts->awcBuffer += ts->iEnd; if (!ts->awcBuffer[0]) return WBREAK_E_END_OF_TEXT; for( i=0; ts->awcBuffer[i] && ts->awcBuffer[i] != ' '; i++) ; if (ts->awcBuffer[i] == ' ') i++; ts->iCur = 0; ts->iEnd = i; return S_OK; } START_TEST(infosoft) { HRESULT r; BOOL license; IWordBreaker *wb = NULL; TEXT_SOURCE ts; r = CoInitialize(NULL); ok( r == S_OK, "failed: %08lx\n", r); r = CoCreateInstance( &CLSID_wb_neutral, NULL, CLSCTX_INPROC_SERVER, &_IID_IWordBreaker, (LPVOID)&wb); if (FAILED(r)) return; r = IWordBreaker_Init( wb, FALSE, 0x100, &license ); ok( r == S_OK, "failed to init the wordbreaker\n"); /* ok( license == TRUE, "should be no license\n"); */ wordnum = 0; ts.pfnFillTextBuffer = fillbuf_none; ts.awcBuffer = teststring; ts.iEnd = lstrlenW(ts.awcBuffer); ts.iCur = 0; r = IWordBreaker_BreakText(wb, &ts, &wordsink.IWordSink_iface, NULL); ok( r == S_OK, "failed: %08lx\n", r); ok(wordnum == 4, "expected 4 words, got %d\n", wordnum); wordnum = 0; ts.pfnFillTextBuffer = fillbuf_many; ts.awcBuffer = teststring; ts.iEnd = 0; ts.iCur = 0; r = fillbuf_many(&ts); ok( r == S_OK, "failed: %08lx\n", r); r = IWordBreaker_BreakText(wb, &ts, &wordsink.IWordSink_iface, NULL); ok( r == S_OK, "failed: %08lx\n", r); ok(wordnum == 4, "expected 4 words, got %d\n", wordnum); IWordBreaker_Release( wb ); CoUninitialize(); }