]> git.saurik.com Git - wxWidgets.git/blame - tests/font/fonttest.cpp
Don't compare invalid iterators in wxCommandProcessor code.
[wxWidgets.git] / tests / font / fonttest.cpp
CommitLineData
5b06a80f
FM
1///////////////////////////////////////////////////////////////////////////////
2// Name: tests/font/fonttest.cpp
3// Purpose: wxFont unit test
4// Author: Francesco Montorsi
5// Created: 16.3.09
6// RCS-ID: $Id$
7// Copyright: (c) 2009 Francesco Montorsi
8// Licence: wxWindows licence
9///////////////////////////////////////////////////////////////////////////////
10
11// ----------------------------------------------------------------------------
12// headers
13// ----------------------------------------------------------------------------
14
15#include "testprec.h"
16
17#ifdef __BORLANDC__
18 #pragma hdrstop
19#endif
20
21#ifndef WX_PRECOMP
22 #include "wx/wx.h"
23#endif // WX_PRECOMP
24
25#if wxUSE_FONTMAP
26
27#include "wx/font.h"
28
29// ----------------------------------------------------------------------------
30// test class
31// ----------------------------------------------------------------------------
32
33class FontTestCase : public CppUnit::TestCase
34{
35public:
36 FontTestCase() { }
37
38private:
39 CPPUNIT_TEST_SUITE( FontTestCase );
40 CPPUNIT_TEST( GetSet );
c56fc0dc
VZ
41 CPPUNIT_TEST( NativeFontInfo );
42 CPPUNIT_TEST( NativeFontInfoUserDesc );
5b06a80f
FM
43 CPPUNIT_TEST_SUITE_END();
44
45 void GetSet();
c56fc0dc
VZ
46 void NativeFontInfo();
47 void NativeFontInfoUserDesc();
48
49 static const wxFont *GetTestFonts(unsigned& numFonts)
50 {
51 static const wxFont testfonts[] =
52 {
53 *wxNORMAL_FONT,
54 *wxSMALL_FONT,
55 *wxITALIC_FONT,
56 *wxSWISS_FONT,
57 wxFont(5, wxFONTFAMILY_TELETYPE, wxFONTSTYLE_NORMAL, wxFONTWEIGHT_NORMAL)
58 };
59
60 numFonts = WXSIZEOF(testfonts);
61
62 return testfonts;
63 }
5b06a80f
FM
64
65 DECLARE_NO_COPY_CLASS(FontTestCase)
66};
67
68// register in the unnamed registry so that these tests are run by default
69CPPUNIT_TEST_SUITE_REGISTRATION( FontTestCase );
70
71// also include in it's own registry so that these tests can be run alone
72CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( FontTestCase, "FontTestCase" );
73
aeecbca0
FM
74wxString DumpFont(const wxFont *font)
75{
76 // dumps the internal properties of a wxFont in the same order they
77 // are checked by wxFontBase::operator==()
c56fc0dc 78
aeecbca0 79 wxASSERT(font->IsOk());
c56fc0dc 80
aeecbca0
FM
81 wxString s;
82 s.Printf(wxS("%d-%d;%d-%d-%d-%d-%d-%s-%d"),
83 font->GetPointSize(),
84 font->GetPixelSize().x,
85 font->GetPixelSize().y,
86 font->GetFamily(),
87 font->GetStyle(),
88 font->GetWeight(),
89 font->GetUnderlined() ? 1 : 0,
90 font->GetFaceName(),
91 font->GetEncoding());
92
93 return s;
94}
5b06a80f
FM
95
96void FontTestCase::GetSet()
97{
c56fc0dc
VZ
98 unsigned numFonts;
99 const wxFont *pf = GetTestFonts(numFonts);
b7cb8553 100 for ( unsigned n = 0; n < numFonts; n++ )
5b06a80f 101 {
c56fc0dc 102 wxFont test(*pf++);
5b06a80f
FM
103
104 // remember: getters can only be called when wxFont::IsOk() == true
105 CPPUNIT_ASSERT( test.IsOk() );
106
107
108 // test Get/SetFaceName()
5b06a80f
FM
109 CPPUNIT_ASSERT( !test.SetFaceName("a dummy face name") );
110 CPPUNIT_ASSERT( !test.IsOk() );
111
3f7c8a87
VZ
112 // if the call to SetFaceName() below fails on your system/port,
113 // consider adding another branch to this #if
114#if defined(__WXMSW__) || defined(__WXOSX__)
115 static const char *knownGoodFaceName = "Arial";
116#else
b7cb8553 117 static const char *knownGoodFaceName = "Monospace";
3f7c8a87
VZ
118#endif
119
b7cb8553
VZ
120 WX_ASSERT_MESSAGE
121 (
122 ("failed to set face name \"%s\" for test font #%u\n"
123 "(this failure is harmless if this face name is not "
124 "available on this system)", knownGoodFaceName, n),
125 test.SetFaceName(knownGoodFaceName)
126 );
5b06a80f
FM
127 CPPUNIT_ASSERT( test.IsOk() );
128
129
130 // test Get/SetFamily()
131
6aea1e4a 132 test.SetFamily( wxFONTFAMILY_ROMAN );
14a83cbf 133 CPPUNIT_ASSERT( test.IsOk() );
aa6b8882
VZ
134
135 // note that there is always the possibility that GetFamily() returns
136 // wxFONTFAMILY_DEFAULT (meaning "unknown" in this case) so that we
137 // consider it as a valid return value
138 const wxFontFamily family = test.GetFamily();
139 if ( family != wxFONTFAMILY_DEFAULT )
140 CPPUNIT_ASSERT_EQUAL( wxFONTFAMILY_ROMAN, family );
6aea1e4a 141
5b06a80f 142
5b06a80f
FM
143 // test Get/SetEncoding()
144
145 //test.SetEncoding( wxFONTENCODING_KOI8 );
14a83cbf 146 //CPPUNIT_ASSERT( test.IsOk() );
5b06a80f
FM
147 //CPPUNIT_ASSERT_EQUAL( wxFONTENCODING_KOI8 , test.GetEncoding() );
148
c56fc0dc
VZ
149
150 // test Get/SetPointSize()
151
152 test.SetPointSize(30);
153 CPPUNIT_ASSERT( test.IsOk() );
154 CPPUNIT_ASSERT_EQUAL( 30, test.GetPointSize() );
155
156
157 // test Get/SetPixelSize()
158
159 test.SetPixelSize(wxSize(0,30));
160 CPPUNIT_ASSERT( test.IsOk() );
161 CPPUNIT_ASSERT( test.GetPixelSize().GetHeight() <= 30 );
162 // NOTE: the match found by SetPixelSize() may be not 100% precise; it
163 // only grants that a font smaller than the required height will
164 // be selected
165
166
167 // test Get/SetStyle()
168
169 test.SetStyle(wxFONTSTYLE_SLANT);
170 CPPUNIT_ASSERT( test.IsOk() );
171#ifdef __WXMSW__
172 // on wxMSW wxFONTSTYLE_SLANT==wxFONTSTYLE_ITALIC
173 CPPUNIT_ASSERT( wxFONTSTYLE_SLANT == test.GetStyle() ||
174 wxFONTSTYLE_ITALIC == test.GetStyle() );
175#else
176 CPPUNIT_ASSERT_EQUAL( wxFONTSTYLE_SLANT, test.GetStyle() );
177#endif
178
179 // test Get/SetUnderlined()
180
181 test.SetUnderlined(true);
182 CPPUNIT_ASSERT( test.IsOk() );
183 CPPUNIT_ASSERT_EQUAL( true, test.GetUnderlined() );
184
185
186 // test Get/SetWeight()
187
188 test.SetWeight(wxFONTWEIGHT_BOLD);
189 CPPUNIT_ASSERT( test.IsOk() );
190 CPPUNIT_ASSERT_EQUAL( wxFONTWEIGHT_BOLD, test.GetWeight() );
191 }
192}
193
194void FontTestCase::NativeFontInfo()
195{
196 unsigned numFonts;
197 const wxFont *pf = GetTestFonts(numFonts);
198 for ( size_t n = 0; n < numFonts; n++ )
199 {
200 wxFont test(*pf++);
201
5b06a80f
FM
202 const wxString& nid = test.GetNativeFontInfoDesc();
203 CPPUNIT_ASSERT( !nid.empty() );
14a83cbf 204 // documented to be never empty
c56fc0dc 205
5b06a80f 206 wxFont temp;
14a83cbf
FM
207 CPPUNIT_ASSERT( temp.SetNativeFontInfo(nid) );
208 CPPUNIT_ASSERT( temp.IsOk() );
c56fc0dc 209 WX_ASSERT_MESSAGE(
aeecbca0
FM
210 ("Test #%lu failed\ndump of test font: \"%s\"\ndump of temp font: \"%s\"", \
211 n, DumpFont(&test), DumpFont(&temp)),
9b5e0a6d 212 temp == test );
c56fc0dc
VZ
213 }
214
215 // test that clearly invalid font info strings do not work
216 wxFont font;
217 CPPUNIT_ASSERT( !font.SetNativeFontInfo("") );
541aafe2
VZ
218
219 // pango_font_description_from_string() used by wxFont in wxGTK and wxX11
220 // never returns an error at all so this assertion fails there -- and as it
221 // doesn't seem to be possible to do anything about it maybe we should
222 // change wxMSW and other ports to also accept any strings?
223#if !defined(__WXGTK__) && !defined(__WXX11__)
c56fc0dc 224 CPPUNIT_ASSERT( !font.SetNativeFontInfo("bloordyblop") );
541aafe2 225#endif
c56fc0dc
VZ
226}
227
228void FontTestCase::NativeFontInfoUserDesc()
229{
230 unsigned numFonts;
231 const wxFont *pf = GetTestFonts(numFonts);
232 for ( size_t n = 0; n < numFonts; n++ )
233 {
234 wxFont test(*pf++);
14a83cbf 235
5b06a80f
FM
236 const wxString& niud = test.GetNativeFontInfoUserDesc();
237 CPPUNIT_ASSERT( !niud.empty() );
14a83cbf 238 // documented to be never empty
c56fc0dc 239
5b06a80f 240 wxFont temp2;
14a83cbf
FM
241 CPPUNIT_ASSERT( temp2.SetNativeFontInfoUserDesc(niud) );
242 CPPUNIT_ASSERT( temp2.IsOk() );
243
244#ifdef __WXGTK__
245 // Pango saves/restores all font info in the user-friendly string:
c56fc0dc 246 WX_ASSERT_MESSAGE(
6aafb945
FM
247 ("Test #%lu failed; native info user desc was \"%s\" for test and \"%s\" for temp2", \
248 n, niud, temp2.GetNativeFontInfoUserDesc()),
9b5e0a6d 249 temp2 == test );
14a83cbf
FM
250#else
251 // NOTE: as documented GetNativeFontInfoUserDesc/SetNativeFontInfoUserDesc
252 // are not granted to save/restore all font info.
253 // In fact e.g. the font family is not saved at all; test only those
254 // info which GetNativeFontInfoUserDesc() does indeed save:
255 CPPUNIT_ASSERT_EQUAL( test.GetWeight(), temp2.GetWeight() );
256 CPPUNIT_ASSERT_EQUAL( test.GetStyle(), temp2.GetStyle() );
14a83cbf 257
c56fc0dc
VZ
258 // if the original face name was empty, it means that any face name (in
259 // this family) can be used for the new font so we shouldn't be
260 // surprised to find that they differ in this case
261 const wxString facename = test.GetFaceName();
262 if ( !facename.empty() )
263 {
264 CPPUNIT_ASSERT_EQUAL( facename.Upper(), temp2.GetFaceName().Upper() );
265 }
14a83cbf 266
c56fc0dc
VZ
267 CPPUNIT_ASSERT_EQUAL( test.GetPointSize(), temp2.GetPointSize() );
268 CPPUNIT_ASSERT_EQUAL( test.GetEncoding(), temp2.GetEncoding() );
14a83cbf 269#endif
5b06a80f
FM
270 }
271}
272
273#endif // wxUSE_FONTMAP