Merge the new wxWebView classes from the SOC2011_WEBVIEW branch.
git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@69049 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
This commit is contained in:
247
tests/controls/webtest.cpp
Normal file
247
tests/controls/webtest.cpp
Normal file
@@ -0,0 +1,247 @@
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
// Name: tests/controls/webtest.cpp
|
||||
// Purpose: wxWebView unit test
|
||||
// Author: Steven Lamerton
|
||||
// Created: 2011-07-08
|
||||
// RCS-ID: $Id$
|
||||
// Copyright: (c) 2011 Steven Lamerton
|
||||
///////////////////////////////////////////////////////////////////////////////
|
||||
|
||||
#include "testprec.h"
|
||||
|
||||
#if wxUSE_WEBVIEW
|
||||
|
||||
#ifdef __BORLANDC__
|
||||
#pragma hdrstop
|
||||
#endif
|
||||
|
||||
#ifndef WX_PRECOMP
|
||||
#include "wx/app.h"
|
||||
#endif // WX_PRECOMP
|
||||
|
||||
#include "testableframe.h"
|
||||
#include "wx/uiaction.h"
|
||||
#include "wx/webview.h"
|
||||
#include "asserthelper.h"
|
||||
|
||||
class WebTestCase : public CppUnit::TestCase
|
||||
{
|
||||
public:
|
||||
WebTestCase() { }
|
||||
|
||||
void setUp();
|
||||
void tearDown();
|
||||
|
||||
private:
|
||||
CPPUNIT_TEST_SUITE( WebTestCase );
|
||||
CPPUNIT_TEST( Title );
|
||||
CPPUNIT_TEST( Url );
|
||||
CPPUNIT_TEST( History );
|
||||
CPPUNIT_TEST( HistoryEnable );
|
||||
CPPUNIT_TEST( HistoryClear );
|
||||
CPPUNIT_TEST( HistoryList );
|
||||
CPPUNIT_TEST( Editable );
|
||||
CPPUNIT_TEST( Selection );
|
||||
CPPUNIT_TEST( Zoom );
|
||||
CPPUNIT_TEST( RunScript );
|
||||
CPPUNIT_TEST_SUITE_END();
|
||||
|
||||
void Title();
|
||||
void Url();
|
||||
void History();
|
||||
void HistoryEnable();
|
||||
void HistoryClear();
|
||||
void HistoryList();
|
||||
void Editable();
|
||||
void Selection();
|
||||
void Zoom();
|
||||
void RunScript();
|
||||
void LoadUrl(int times = 1);
|
||||
|
||||
wxWebView* m_browser;
|
||||
|
||||
DECLARE_NO_COPY_CLASS(WebTestCase)
|
||||
};
|
||||
|
||||
// register in the unnamed registry so that these tests are run by default
|
||||
CPPUNIT_TEST_SUITE_REGISTRATION( WebTestCase );
|
||||
|
||||
// also include in its own registry so that these tests can be run alone
|
||||
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( WebTestCase, "WebTestCase" );
|
||||
|
||||
void WebTestCase::setUp()
|
||||
{
|
||||
m_browser = wxWebView::New(wxTheApp->GetTopWindow(), wxID_ANY);
|
||||
//We yield to let the initial page load
|
||||
wxYield();
|
||||
}
|
||||
|
||||
void WebTestCase::tearDown()
|
||||
{
|
||||
wxDELETE(m_browser);
|
||||
}
|
||||
|
||||
void WebTestCase::LoadUrl(int times)
|
||||
{
|
||||
//We alternate between urls as otherwise webkit merges them in the history
|
||||
//we use about and about blank to avoid the need for a network connection
|
||||
for(int i = 0; i < times; i++)
|
||||
{
|
||||
if(i % 2 == 1)
|
||||
m_browser->LoadUrl("about:blank");
|
||||
else
|
||||
m_browser->LoadUrl("about:");
|
||||
wxYield();
|
||||
}
|
||||
}
|
||||
|
||||
void WebTestCase::Title()
|
||||
{
|
||||
CPPUNIT_ASSERT_EQUAL("", m_browser->GetCurrentTitle());
|
||||
|
||||
//Test title after loading raw html
|
||||
m_browser->SetPage("<html><title>Title</title><body>Text</body></html>", "");
|
||||
wxYield();
|
||||
CPPUNIT_ASSERT_EQUAL("Title", m_browser->GetCurrentTitle());
|
||||
|
||||
//Test title after loading a url, we yield to let events process
|
||||
LoadUrl();
|
||||
CPPUNIT_ASSERT_EQUAL("", m_browser->GetCurrentTitle());
|
||||
}
|
||||
|
||||
void WebTestCase::Url()
|
||||
{
|
||||
CPPUNIT_ASSERT_EQUAL("about:blank", m_browser->GetCurrentURL());
|
||||
|
||||
//After first loading about:blank the next in the sequence is about:
|
||||
LoadUrl();
|
||||
CPPUNIT_ASSERT_EQUAL("about:", m_browser->GetCurrentURL());
|
||||
}
|
||||
|
||||
void WebTestCase::History()
|
||||
{
|
||||
LoadUrl(3);
|
||||
|
||||
CPPUNIT_ASSERT(m_browser->CanGoBack());
|
||||
CPPUNIT_ASSERT(!m_browser->CanGoForward());
|
||||
|
||||
m_browser->GoBack();
|
||||
|
||||
CPPUNIT_ASSERT(m_browser->CanGoBack());
|
||||
CPPUNIT_ASSERT(m_browser->CanGoForward());
|
||||
|
||||
m_browser->GoBack();
|
||||
m_browser->GoBack();
|
||||
|
||||
//We should now be at the start of the history
|
||||
CPPUNIT_ASSERT(!m_browser->CanGoBack());
|
||||
CPPUNIT_ASSERT(m_browser->CanGoForward());
|
||||
}
|
||||
|
||||
void WebTestCase::HistoryEnable()
|
||||
{
|
||||
LoadUrl();
|
||||
m_browser->EnableHistory(false);
|
||||
|
||||
CPPUNIT_ASSERT(!m_browser->CanGoForward());
|
||||
CPPUNIT_ASSERT(!m_browser->CanGoBack());
|
||||
|
||||
LoadUrl();
|
||||
|
||||
CPPUNIT_ASSERT(!m_browser->CanGoForward());
|
||||
CPPUNIT_ASSERT(!m_browser->CanGoBack());
|
||||
}
|
||||
|
||||
void WebTestCase::HistoryClear()
|
||||
{
|
||||
LoadUrl(2);
|
||||
|
||||
//Now we are in the 'middle' of the history
|
||||
m_browser->GoBack();
|
||||
wxYield();
|
||||
|
||||
CPPUNIT_ASSERT(m_browser->CanGoForward());
|
||||
CPPUNIT_ASSERT(m_browser->CanGoBack());
|
||||
|
||||
m_browser->ClearHistory();
|
||||
|
||||
CPPUNIT_ASSERT(!m_browser->CanGoForward());
|
||||
CPPUNIT_ASSERT(!m_browser->CanGoBack());
|
||||
}
|
||||
|
||||
void WebTestCase::HistoryList()
|
||||
{
|
||||
LoadUrl(2);
|
||||
m_browser->GoBack();
|
||||
|
||||
CPPUNIT_ASSERT_EQUAL(1, m_browser->GetBackwardHistory().size());
|
||||
CPPUNIT_ASSERT_EQUAL(1, m_browser->GetForwardHistory().size());
|
||||
|
||||
m_browser->LoadHistoryItem(m_browser->GetForwardHistory()[0]);
|
||||
|
||||
CPPUNIT_ASSERT(!m_browser->CanGoForward());
|
||||
CPPUNIT_ASSERT_EQUAL(2, m_browser->GetBackwardHistory().size());
|
||||
}
|
||||
|
||||
void WebTestCase::Editable()
|
||||
{
|
||||
CPPUNIT_ASSERT(!m_browser->IsEditable());
|
||||
|
||||
m_browser->SetEditable(true);
|
||||
|
||||
CPPUNIT_ASSERT(m_browser->IsEditable());
|
||||
|
||||
m_browser->SetEditable(false);
|
||||
|
||||
CPPUNIT_ASSERT(!m_browser->IsEditable());
|
||||
}
|
||||
|
||||
void WebTestCase::Selection()
|
||||
{
|
||||
m_browser->SetPage("<html><body>Some <strong>strong</strong> text</body></html>", "");
|
||||
wxYield();
|
||||
CPPUNIT_ASSERT(!m_browser->HasSelection());
|
||||
|
||||
m_browser->SelectAll();
|
||||
|
||||
CPPUNIT_ASSERT(m_browser->HasSelection());
|
||||
CPPUNIT_ASSERT_EQUAL("Some strong text", m_browser->GetSelectedText());
|
||||
//We lower case the result as ie returns tags in uppercase
|
||||
CPPUNIT_ASSERT_EQUAL("some <strong>strong</strong> text",
|
||||
m_browser->GetSelectedSource().Lower());
|
||||
|
||||
m_browser->ClearSelection();
|
||||
CPPUNIT_ASSERT(!m_browser->HasSelection());
|
||||
}
|
||||
|
||||
void WebTestCase::Zoom()
|
||||
{
|
||||
if(m_browser->CanSetZoomType(wxWEB_VIEW_ZOOM_TYPE_LAYOUT))
|
||||
{
|
||||
m_browser->SetZoomType(wxWEB_VIEW_ZOOM_TYPE_LAYOUT);
|
||||
CPPUNIT_ASSERT_EQUAL(wxWEB_VIEW_ZOOM_TYPE_LAYOUT, m_browser->GetZoomType());
|
||||
|
||||
m_browser->SetZoom(wxWEB_VIEW_ZOOM_TINY);
|
||||
CPPUNIT_ASSERT_EQUAL(wxWEB_VIEW_ZOOM_TINY, m_browser->GetZoom());
|
||||
}
|
||||
|
||||
//Reset the zoom level
|
||||
m_browser->SetZoom(wxWEB_VIEW_ZOOM_MEDIUM);
|
||||
|
||||
if(m_browser->CanSetZoomType(wxWEB_VIEW_ZOOM_TYPE_TEXT))
|
||||
{
|
||||
m_browser->SetZoomType(wxWEB_VIEW_ZOOM_TYPE_TEXT);
|
||||
CPPUNIT_ASSERT_EQUAL(wxWEB_VIEW_ZOOM_TYPE_TEXT, m_browser->GetZoomType());
|
||||
|
||||
m_browser->SetZoom(wxWEB_VIEW_ZOOM_TINY);
|
||||
CPPUNIT_ASSERT_EQUAL(wxWEB_VIEW_ZOOM_TINY, m_browser->GetZoom());
|
||||
}
|
||||
}
|
||||
|
||||
void WebTestCase::RunScript()
|
||||
{
|
||||
m_browser->RunScript("document.write(\"Hello World!\");");
|
||||
CPPUNIT_ASSERT_EQUAL("Hello World!", m_browser->GetPageText());
|
||||
}
|
||||
|
||||
#endif //wxUSE_WEBVIEW
|
@@ -182,6 +182,7 @@
|
||||
controls/treectrltest.cpp
|
||||
controls/treelistctrltest.cpp
|
||||
controls/virtlistctrltest.cpp
|
||||
controls/webtest.cpp
|
||||
controls/windowtest.cpp
|
||||
events/clone.cpp
|
||||
events/propagation.cpp
|
||||
@@ -211,6 +212,7 @@
|
||||
window/setsize.cpp
|
||||
xml/xrctest.cpp
|
||||
</sources>
|
||||
<wx-lib>webview</wx-lib>
|
||||
<wx-lib>richtext</wx-lib>
|
||||
<wx-lib>media</wx-lib>
|
||||
<wx-lib>xrc</wx-lib>
|
||||
|
Reference in New Issue
Block a user