--- /dev/null
+///////////////////////////////////////////////////////////////////////////////
+// Name:        tests/controls/clientsize.cpp
+// Purpose:     Client vs. window size handling unit test
+// Author:      Vaclav Slavik
+// Created:     2008-02-12
+// RCS-ID:      $Id: clientsize.cpp 53740 2008-05-25 02:56:22Z VZ $
+// Copyright:   (c) 2008 Vaclav Slavik <vslavik@fastmail.fm>
+///////////////////////////////////////////////////////////////////////////////
+
+// ----------------------------------------------------------------------------
+// headers
+// ----------------------------------------------------------------------------
+
+#include "testprec.h"
+
+#if wxUSE_GRAPHICS_CONTEXT
+
+#ifdef __BORLANDC__
+    #pragma hdrstop
+#endif
+
+#ifndef WX_PRECOMP
+    #include "wx/app.h"
+    #include "wx/font.h"
+    #include "wx/window.h"
+#endif // WX_PRECOMP
+
+#include "wx/graphics.h"
+// ----------------------------------------------------------------------------
+// test class
+// ----------------------------------------------------------------------------
+
+class MeasuringContextTestCase : public CppUnit::TestCase
+{
+public:
+    MeasuringContextTestCase() { }
+
+    virtual void setUp();
+    virtual void tearDown();
+
+private:
+    CPPUNIT_TEST_SUITE( MeasuringContextTestCase );
+        CPPUNIT_TEST( GetTextExtent );
+    CPPUNIT_TEST_SUITE_END();
+
+    void GetTextExtent();
+
+    wxWindow *m_win;
+
+    DECLARE_NO_COPY_CLASS(MeasuringContextTestCase)
+};
+
+// register in the unnamed registry so that these tests are run by default
+CPPUNIT_TEST_SUITE_REGISTRATION( MeasuringContextTestCase );
+
+// also include in it's own registry so that these tests can be run alone
+CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( MeasuringContextTestCase, "MeasuringContextTestCase" );
+
+// ----------------------------------------------------------------------------
+// test initialization
+// ----------------------------------------------------------------------------
+
+void MeasuringContextTestCase::setUp()
+{
+    m_win = wxTheApp->GetTopWindow();
+}
+
+void MeasuringContextTestCase::tearDown()
+{
+    m_win = NULL;
+}
+
+// ----------------------------------------------------------------------------
+// tests themselves
+// ----------------------------------------------------------------------------
+
+void MeasuringContextTestCase::GetTextExtent()
+{
+    wxGraphicsRenderer* renderer = wxGraphicsRenderer::GetDefaultRenderer();
+    CPPUNIT_ASSERT(renderer);
+    wxGraphicsContext* context = renderer->CreateMeasuringContext();
+    CPPUNIT_ASSERT(context);
+    wxFont font(12, wxFONTFAMILY_DEFAULT, wxFONTSTYLE_NORMAL, wxFONTWEIGHT_NORMAL);
+    CPPUNIT_ASSERT(font.IsOk());
+    context->SetFont(font, *wxBLACK);
+    double width, height, descent, externalLeading = 0.0;
+    context->GetTextExtent("x", &width, &height, &descent, &externalLeading);
+
+    // TODO: Determine a way to make these tests more robust.
+    CPPUNIT_ASSERT(width > 0.0);
+    CPPUNIT_ASSERT(height > 0.0);
+
+}
+
+#endif