f4b80e5337
Don't support this compiler any more, this allows to get rid of tons of MSVC6-specific workarounds, in particular we can now use Bind() and natural template functions calls in the library code. Also remove MSVC6 project and solution files and don't generate them when bakefile_gen is ran any more (removing the remaining occurrences of msvc6prj from the bakefiles results in weird bake-time errors, so it's simpler to just leave them there). git-svn-id: https://svn.wxwidgets.org/svn/wx/wxWidgets/trunk@76532 c3d73ce0-8a6f-49c7-b76d-6d57e0e08775
892 lines
23 KiB
C++
892 lines
23 KiB
C++
///////////////////////////////////////////////////////////////////////////////
|
|
// Name: tests/controls/richtextctrltest.cpp
|
|
// Purpose: wxRichTextCtrl unit test
|
|
// Author: Steven Lamerton
|
|
// Created: 2010-07-07
|
|
// Copyright: (c) 2010 Steven Lamerton
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
#include "testprec.h"
|
|
|
|
#if wxUSE_RICHTEXT
|
|
|
|
#ifdef __BORLANDC__
|
|
#pragma hdrstop
|
|
#endif
|
|
|
|
#ifndef WX_PRECOMP
|
|
#include "wx/app.h"
|
|
#endif // WX_PRECOMP
|
|
|
|
#include "wx/richtext/richtextctrl.h"
|
|
#include "wx/richtext/richtextstyles.h"
|
|
#include "testableframe.h"
|
|
#include "asserthelper.h"
|
|
#include "wx/uiaction.h"
|
|
|
|
class RichTextCtrlTestCase : public CppUnit::TestCase
|
|
{
|
|
public:
|
|
RichTextCtrlTestCase() { }
|
|
|
|
void setUp();
|
|
void tearDown();
|
|
|
|
private:
|
|
CPPUNIT_TEST_SUITE( RichTextCtrlTestCase );
|
|
WXUISIM_TEST( CharacterEvent );
|
|
WXUISIM_TEST( DeleteEvent );
|
|
WXUISIM_TEST( ReturnEvent );
|
|
CPPUNIT_TEST( StyleEvent );
|
|
CPPUNIT_TEST( BufferResetEvent );
|
|
WXUISIM_TEST( UrlEvent );
|
|
WXUISIM_TEST( TextEvent );
|
|
CPPUNIT_TEST( CutCopyPaste );
|
|
CPPUNIT_TEST( UndoRedo );
|
|
CPPUNIT_TEST( CaretPosition );
|
|
CPPUNIT_TEST( Selection );
|
|
WXUISIM_TEST( Editable );
|
|
CPPUNIT_TEST( Range );
|
|
CPPUNIT_TEST( Alignment );
|
|
CPPUNIT_TEST( Bold );
|
|
CPPUNIT_TEST( Italic );
|
|
CPPUNIT_TEST( Underline );
|
|
CPPUNIT_TEST( Indent );
|
|
CPPUNIT_TEST( LineSpacing );
|
|
CPPUNIT_TEST( ParagraphSpacing );
|
|
CPPUNIT_TEST( TextColour );
|
|
CPPUNIT_TEST( NumberedBullet );
|
|
CPPUNIT_TEST( SymbolBullet );
|
|
CPPUNIT_TEST( FontSize );
|
|
CPPUNIT_TEST( Font );
|
|
CPPUNIT_TEST( Delete );
|
|
CPPUNIT_TEST( Url );
|
|
CPPUNIT_TEST( Table );
|
|
CPPUNIT_TEST_SUITE_END();
|
|
|
|
void CharacterEvent();
|
|
void DeleteEvent();
|
|
void ReturnEvent();
|
|
void StyleEvent();
|
|
void BufferResetEvent();
|
|
void UrlEvent();
|
|
void TextEvent();
|
|
void CutCopyPaste();
|
|
void UndoRedo();
|
|
void CaretPosition();
|
|
void Selection();
|
|
void Editable();
|
|
void Range();
|
|
void Alignment();
|
|
void Bold();
|
|
void Italic();
|
|
void Underline();
|
|
void Indent();
|
|
void LineSpacing();
|
|
void ParagraphSpacing();
|
|
void TextColour();
|
|
void NumberedBullet();
|
|
void SymbolBullet();
|
|
void FontSize();
|
|
void Font();
|
|
void Delete();
|
|
void Url();
|
|
void Table();
|
|
|
|
wxRichTextCtrl* m_rich;
|
|
|
|
DECLARE_NO_COPY_CLASS(RichTextCtrlTestCase)
|
|
};
|
|
|
|
// register in the unnamed registry so that these tests are run by default
|
|
CPPUNIT_TEST_SUITE_REGISTRATION( RichTextCtrlTestCase );
|
|
|
|
// also include in its own registry so that these tests can be run alone
|
|
CPPUNIT_TEST_SUITE_NAMED_REGISTRATION( RichTextCtrlTestCase, "RichTextCtrlTestCase" );
|
|
|
|
void RichTextCtrlTestCase::setUp()
|
|
{
|
|
m_rich = new wxRichTextCtrl(wxTheApp->GetTopWindow(), wxID_ANY, "",
|
|
wxDefaultPosition, wxSize(400, 200), wxWANTS_CHARS);
|
|
}
|
|
|
|
void RichTextCtrlTestCase::tearDown()
|
|
{
|
|
wxDELETE(m_rich);
|
|
}
|
|
|
|
void RichTextCtrlTestCase::CharacterEvent()
|
|
{
|
|
#if wxUSE_UIACTIONSIMULATOR
|
|
|
|
// There seems to be an event sequence problem on GTK+ that causes the events
|
|
// to be disconnected before they're processed, generating spurious errors.
|
|
#if !defined(__WXGTK__)
|
|
EventCounter character(m_rich, wxEVT_RICHTEXT_CHARACTER);
|
|
EventCounter content(m_rich, wxEVT_RICHTEXT_CONTENT_INSERTED);
|
|
|
|
m_rich->SetFocus();
|
|
|
|
wxUIActionSimulator sim;
|
|
sim.Text("abcdef");
|
|
wxYield();
|
|
|
|
CPPUNIT_ASSERT_EQUAL(6, character.GetCount());
|
|
CPPUNIT_ASSERT_EQUAL(6, content.GetCount());
|
|
|
|
character.Clear();
|
|
content.Clear();
|
|
|
|
//As these are not characters they shouldn't count
|
|
sim.Char(WXK_RETURN);
|
|
sim.Char(WXK_SHIFT);
|
|
wxYield();
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, character.GetCount());
|
|
CPPUNIT_ASSERT_EQUAL(1, content.GetCount());
|
|
#endif
|
|
#endif
|
|
}
|
|
|
|
void RichTextCtrlTestCase::DeleteEvent()
|
|
{
|
|
#if wxUSE_UIACTIONSIMULATOR
|
|
// There seems to be an event sequence problem on GTK+ that causes the events
|
|
// to be disconnected before they're processed, generating spurious errors.
|
|
#if !defined(__WXGTK__)
|
|
EventCounter deleteevent(m_rich, wxEVT_RICHTEXT_DELETE);
|
|
EventCounter contentdelete(m_rich, wxEVT_RICHTEXT_CONTENT_DELETED);
|
|
|
|
m_rich->SetFocus();
|
|
|
|
wxUIActionSimulator sim;
|
|
sim.Text("abcdef");
|
|
sim.Char(WXK_BACK);
|
|
sim.Char(WXK_DELETE);
|
|
wxYield();
|
|
|
|
CPPUNIT_ASSERT_EQUAL(2, deleteevent.GetCount());
|
|
//Only one as the delete doesn't delete anthing
|
|
CPPUNIT_ASSERT_EQUAL(1, contentdelete.GetCount());
|
|
#endif
|
|
#endif
|
|
}
|
|
|
|
void RichTextCtrlTestCase::ReturnEvent()
|
|
{
|
|
#if wxUSE_UIACTIONSIMULATOR
|
|
// There seems to be an event sequence problem on GTK+ that causes the events
|
|
// to be disconnected before they're processed, generating spurious errors.
|
|
#if !defined(__WXGTK__)
|
|
EventCounter returnevent(m_rich, wxEVT_RICHTEXT_RETURN);
|
|
|
|
m_rich->SetFocus();
|
|
|
|
wxUIActionSimulator sim;
|
|
sim.Char(WXK_RETURN);
|
|
wxYield();
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, returnevent.GetCount());
|
|
#endif
|
|
#endif
|
|
}
|
|
|
|
void RichTextCtrlTestCase::StyleEvent()
|
|
{
|
|
EventCounter stylechanged(m_rich, wxEVT_RICHTEXT_STYLE_CHANGED);
|
|
|
|
m_rich->SetValue("Sometext");
|
|
m_rich->SetStyle(0, 8, wxTextAttr(*wxRED, *wxWHITE));
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, stylechanged.GetCount());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::BufferResetEvent()
|
|
{
|
|
EventCounter reset(m_rich, wxEVT_RICHTEXT_BUFFER_RESET);
|
|
|
|
m_rich->AppendText("more text!");
|
|
m_rich->SetValue("");
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, reset.GetCount());
|
|
|
|
reset.Clear();
|
|
m_rich->AppendText("more text!");
|
|
m_rich->Clear();
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, reset.GetCount());
|
|
|
|
reset.Clear();
|
|
|
|
//We expect a buffer reset here as setvalue clears the existing text
|
|
m_rich->SetValue("replace");
|
|
CPPUNIT_ASSERT_EQUAL(1, reset.GetCount());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::UrlEvent()
|
|
{
|
|
#if wxUSE_UIACTIONSIMULATOR
|
|
// Mouse up event not being caught on GTK+
|
|
#if !defined(__WXGTK__)
|
|
EventCounter url(m_rich, wxEVT_TEXT_URL);
|
|
|
|
m_rich->BeginURL("http://www.wxwidgets.org");
|
|
m_rich->WriteText("http://www.wxwidgets.org");
|
|
m_rich->EndURL();
|
|
|
|
wxUIActionSimulator sim;
|
|
sim.MouseMove(m_rich->ClientToScreen(wxPoint(10, 10)));
|
|
wxYield();
|
|
|
|
sim.MouseClick();
|
|
wxYield();
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, url.GetCount());
|
|
#endif
|
|
#endif
|
|
}
|
|
|
|
void RichTextCtrlTestCase::TextEvent()
|
|
{
|
|
#if wxUSE_UIACTIONSIMULATOR
|
|
#if !defined(__WXGTK__)
|
|
EventCounter updated(m_rich, wxEVT_TEXT);
|
|
|
|
m_rich->SetFocus();
|
|
|
|
wxUIActionSimulator sim;
|
|
sim.Text("abcdef");
|
|
wxYield();
|
|
|
|
CPPUNIT_ASSERT_EQUAL("abcdef", m_rich->GetValue());
|
|
CPPUNIT_ASSERT_EQUAL(6, updated.GetCount());
|
|
#endif
|
|
#endif
|
|
}
|
|
|
|
void RichTextCtrlTestCase::CutCopyPaste()
|
|
{
|
|
#ifndef __WXOSX__
|
|
m_rich->AppendText("sometext");
|
|
m_rich->SelectAll();
|
|
|
|
if(m_rich->CanCut() && m_rich->CanPaste())
|
|
{
|
|
m_rich->Cut();
|
|
CPPUNIT_ASSERT(m_rich->IsEmpty());
|
|
|
|
wxYield();
|
|
|
|
m_rich->Paste();
|
|
CPPUNIT_ASSERT_EQUAL("sometext", m_rich->GetValue());
|
|
}
|
|
|
|
m_rich->SelectAll();
|
|
|
|
if(m_rich->CanCopy() && m_rich->CanPaste())
|
|
{
|
|
m_rich->Copy();
|
|
m_rich->Clear();
|
|
CPPUNIT_ASSERT(m_rich->IsEmpty());
|
|
|
|
wxYield();
|
|
|
|
m_rich->Paste();
|
|
CPPUNIT_ASSERT_EQUAL("sometext", m_rich->GetValue());
|
|
}
|
|
#endif
|
|
}
|
|
|
|
void RichTextCtrlTestCase::UndoRedo()
|
|
{
|
|
m_rich->AppendText("sometext");
|
|
|
|
CPPUNIT_ASSERT(m_rich->CanUndo());
|
|
|
|
m_rich->Undo();
|
|
|
|
CPPUNIT_ASSERT(m_rich->IsEmpty());
|
|
CPPUNIT_ASSERT(m_rich->CanRedo());
|
|
|
|
m_rich->Redo();
|
|
|
|
CPPUNIT_ASSERT_EQUAL("sometext", m_rich->GetValue());
|
|
|
|
m_rich->AppendText("Batch undo");
|
|
m_rich->SelectAll();
|
|
|
|
//Also test batch operations
|
|
m_rich->BeginBatchUndo("batchtest");
|
|
|
|
m_rich->ApplyBoldToSelection();
|
|
m_rich->ApplyItalicToSelection();
|
|
|
|
m_rich->EndBatchUndo();
|
|
|
|
CPPUNIT_ASSERT(m_rich->CanUndo());
|
|
|
|
m_rich->Undo();
|
|
|
|
CPPUNIT_ASSERT(!m_rich->IsSelectionBold());
|
|
CPPUNIT_ASSERT(!m_rich->IsSelectionItalics());
|
|
CPPUNIT_ASSERT(m_rich->CanRedo());
|
|
|
|
m_rich->Redo();
|
|
|
|
CPPUNIT_ASSERT(m_rich->IsSelectionBold());
|
|
CPPUNIT_ASSERT(m_rich->IsSelectionItalics());
|
|
|
|
//And surpressing undo
|
|
m_rich->BeginSuppressUndo();
|
|
|
|
m_rich->AppendText("Can't undo this");
|
|
|
|
CPPUNIT_ASSERT(m_rich->CanUndo());
|
|
|
|
m_rich->EndSuppressUndo();
|
|
}
|
|
|
|
void RichTextCtrlTestCase::CaretPosition()
|
|
{
|
|
m_rich->AddParagraph("This is paragraph one");
|
|
m_rich->AddParagraph("Paragraph two\n has \nlots of\n lines");
|
|
|
|
m_rich->SetInsertionPoint(2);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(1, m_rich->GetCaretPosition());
|
|
|
|
m_rich->MoveToParagraphStart();
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, m_rich->GetCaretPosition());
|
|
|
|
m_rich->MoveRight();
|
|
m_rich->MoveRight(2);
|
|
m_rich->MoveLeft(1);
|
|
m_rich->MoveLeft(0);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(2, m_rich->GetCaretPosition());
|
|
|
|
m_rich->MoveToParagraphEnd();
|
|
|
|
CPPUNIT_ASSERT_EQUAL(21, m_rich->GetCaretPosition());
|
|
|
|
m_rich->MoveToLineStart();
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, m_rich->GetCaretPosition());
|
|
|
|
m_rich->MoveToLineEnd();
|
|
|
|
CPPUNIT_ASSERT_EQUAL(21, m_rich->GetCaretPosition());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Selection()
|
|
{
|
|
m_rich->SetValue("some more text");
|
|
|
|
m_rich->SelectAll();
|
|
|
|
CPPUNIT_ASSERT_EQUAL("some more text", m_rich->GetStringSelection());
|
|
|
|
m_rich->SelectNone();
|
|
|
|
CPPUNIT_ASSERT_EQUAL("", m_rich->GetStringSelection());
|
|
|
|
m_rich->SelectWord(1);
|
|
|
|
CPPUNIT_ASSERT_EQUAL("some", m_rich->GetStringSelection());
|
|
|
|
m_rich->SetSelection(5, 14);
|
|
|
|
CPPUNIT_ASSERT_EQUAL("more text", m_rich->GetStringSelection());
|
|
|
|
wxRichTextRange range(5, 9);
|
|
|
|
m_rich->SetSelectionRange(range);
|
|
|
|
CPPUNIT_ASSERT_EQUAL("more", m_rich->GetStringSelection());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Editable()
|
|
{
|
|
#if wxUSE_UIACTIONSIMULATOR
|
|
#if !defined(__WXGTK__)
|
|
EventCounter updated(m_rich, wxEVT_TEXT);
|
|
|
|
m_rich->SetFocus();
|
|
|
|
wxUIActionSimulator sim;
|
|
sim.Text("abcdef");
|
|
wxYield();
|
|
|
|
CPPUNIT_ASSERT_EQUAL("abcdef", m_rich->GetValue());
|
|
CPPUNIT_ASSERT_EQUAL(6, updated.GetCount());
|
|
updated.Clear();
|
|
|
|
m_rich->SetEditable(false);
|
|
sim.Text("gh");
|
|
wxYield();
|
|
|
|
CPPUNIT_ASSERT_EQUAL("abcdef", m_rich->GetValue());
|
|
CPPUNIT_ASSERT_EQUAL(0, updated.GetCount());
|
|
#endif
|
|
#endif
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Range()
|
|
{
|
|
wxRichTextRange range(0, 10);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, range.GetStart());
|
|
CPPUNIT_ASSERT_EQUAL(10, range.GetEnd());
|
|
CPPUNIT_ASSERT_EQUAL(11, range.GetLength());
|
|
CPPUNIT_ASSERT(range.Contains(5));
|
|
|
|
wxRichTextRange outside(12, 14);
|
|
|
|
CPPUNIT_ASSERT(outside.IsOutside(range));
|
|
|
|
wxRichTextRange inside(6, 7);
|
|
|
|
CPPUNIT_ASSERT(inside.IsWithin(range));
|
|
|
|
range.LimitTo(inside);
|
|
|
|
CPPUNIT_ASSERT(inside == range);
|
|
CPPUNIT_ASSERT(inside + range == outside);
|
|
CPPUNIT_ASSERT(outside - range == inside);
|
|
|
|
range.SetStart(4);
|
|
range.SetEnd(6);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(4, range.GetStart());
|
|
CPPUNIT_ASSERT_EQUAL(6, range.GetEnd());
|
|
CPPUNIT_ASSERT_EQUAL(3, range.GetLength());
|
|
|
|
inside.SetRange(6, 4);
|
|
inside.Swap();
|
|
|
|
CPPUNIT_ASSERT(inside == range);
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Alignment()
|
|
{
|
|
m_rich->SetValue("text to align");
|
|
m_rich->SelectAll();
|
|
|
|
m_rich->ApplyAlignmentToSelection(wxTEXT_ALIGNMENT_RIGHT);
|
|
|
|
CPPUNIT_ASSERT(m_rich->IsSelectionAligned(wxTEXT_ALIGNMENT_RIGHT));
|
|
|
|
m_rich->BeginAlignment(wxTEXT_ALIGNMENT_CENTRE);
|
|
m_rich->AddParagraph("middle aligned");
|
|
m_rich->EndAlignment();
|
|
|
|
m_rich->SetSelection(20, 25);
|
|
|
|
CPPUNIT_ASSERT(m_rich->IsSelectionAligned(wxTEXT_ALIGNMENT_CENTRE));
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Bold()
|
|
{
|
|
m_rich->SetValue("text to bold");
|
|
m_rich->SelectAll();
|
|
m_rich->ApplyBoldToSelection();
|
|
|
|
CPPUNIT_ASSERT(m_rich->IsSelectionBold());
|
|
|
|
m_rich->BeginBold();
|
|
m_rich->AddParagraph("bold paragraph");
|
|
m_rich->EndBold();
|
|
m_rich->AddParagraph("not bold paragraph");
|
|
|
|
m_rich->SetSelection(15, 20);
|
|
|
|
CPPUNIT_ASSERT(m_rich->IsSelectionBold());
|
|
|
|
m_rich->SetSelection(30, 35);
|
|
|
|
CPPUNIT_ASSERT(!m_rich->IsSelectionBold());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Italic()
|
|
{
|
|
m_rich->SetValue("text to italic");
|
|
m_rich->SelectAll();
|
|
m_rich->ApplyItalicToSelection();
|
|
|
|
CPPUNIT_ASSERT(m_rich->IsSelectionItalics());
|
|
|
|
m_rich->BeginItalic();
|
|
m_rich->AddParagraph("italic paragraph");
|
|
m_rich->EndItalic();
|
|
m_rich->AddParagraph("not italic paragraph");
|
|
|
|
m_rich->SetSelection(20, 25);
|
|
|
|
CPPUNIT_ASSERT(m_rich->IsSelectionItalics());
|
|
|
|
m_rich->SetSelection(35, 40);
|
|
|
|
CPPUNIT_ASSERT(!m_rich->IsSelectionItalics());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Underline()
|
|
{
|
|
m_rich->SetValue("text to underline");
|
|
m_rich->SelectAll();
|
|
m_rich->ApplyUnderlineToSelection();
|
|
|
|
CPPUNIT_ASSERT(m_rich->IsSelectionUnderlined());
|
|
|
|
m_rich->BeginUnderline();
|
|
m_rich->AddParagraph("underline paragraph");
|
|
m_rich->EndUnderline();
|
|
m_rich->AddParagraph("not underline paragraph");
|
|
|
|
m_rich->SetSelection(20, 25);
|
|
|
|
CPPUNIT_ASSERT(m_rich->IsSelectionUnderlined());
|
|
|
|
m_rich->SetSelection(40, 45);
|
|
|
|
CPPUNIT_ASSERT(!m_rich->IsSelectionUnderlined());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Indent()
|
|
{
|
|
m_rich->BeginLeftIndent(12, -5);
|
|
m_rich->BeginRightIndent(14);
|
|
m_rich->AddParagraph("A paragraph with indents");
|
|
m_rich->EndLeftIndent();
|
|
m_rich->EndRightIndent();
|
|
m_rich->AddParagraph("No more indent");
|
|
|
|
wxTextAttr indent;
|
|
m_rich->GetStyle(5, indent);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(12, indent.GetLeftIndent());
|
|
CPPUNIT_ASSERT_EQUAL(-5, indent.GetLeftSubIndent());
|
|
CPPUNIT_ASSERT_EQUAL(14, indent.GetRightIndent());
|
|
|
|
m_rich->GetStyle(35, indent);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(0, indent.GetLeftIndent());
|
|
CPPUNIT_ASSERT_EQUAL(0, indent.GetLeftSubIndent());
|
|
CPPUNIT_ASSERT_EQUAL(0, indent.GetRightIndent());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::LineSpacing()
|
|
{
|
|
m_rich->BeginLineSpacing(20);
|
|
m_rich->AddParagraph("double spaced");
|
|
m_rich->EndLineSpacing();
|
|
m_rich->BeginLineSpacing(wxTEXT_ATTR_LINE_SPACING_HALF);
|
|
m_rich->AddParagraph("1.5 spaced");
|
|
m_rich->EndLineSpacing();
|
|
m_rich->AddParagraph("normally spaced");
|
|
|
|
wxTextAttr spacing;
|
|
m_rich->GetStyle(5, spacing);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(20, spacing.GetLineSpacing());
|
|
|
|
m_rich->GetStyle(20, spacing);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(15, spacing.GetLineSpacing());
|
|
|
|
m_rich->GetStyle(30, spacing);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(10, spacing.GetLineSpacing());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::ParagraphSpacing()
|
|
{
|
|
m_rich->BeginParagraphSpacing(15, 20);
|
|
m_rich->AddParagraph("spaced paragraph");
|
|
m_rich->EndParagraphSpacing();
|
|
m_rich->AddParagraph("non-spaced paragraph");
|
|
|
|
wxTextAttr spacing;
|
|
m_rich->GetStyle(5, spacing);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(15, spacing.GetParagraphSpacingBefore());
|
|
CPPUNIT_ASSERT_EQUAL(20, spacing.GetParagraphSpacingAfter());
|
|
|
|
m_rich->GetStyle(25, spacing);
|
|
|
|
//Make sure we test against the defaults
|
|
CPPUNIT_ASSERT_EQUAL(m_rich->GetBasicStyle().GetParagraphSpacingBefore(),
|
|
spacing.GetParagraphSpacingBefore());
|
|
CPPUNIT_ASSERT_EQUAL(m_rich->GetBasicStyle().GetParagraphSpacingAfter(),
|
|
spacing.GetParagraphSpacingAfter());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::TextColour()
|
|
{
|
|
m_rich->BeginTextColour(*wxRED);
|
|
m_rich->AddParagraph("red paragraph");
|
|
m_rich->EndTextColour();
|
|
m_rich->AddParagraph("default paragraph");
|
|
|
|
wxTextAttr colour;
|
|
m_rich->GetStyle(5, colour);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(*wxRED, colour.GetTextColour());
|
|
|
|
m_rich->GetStyle(25, colour);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(m_rich->GetBasicStyle().GetTextColour(),
|
|
colour.GetTextColour());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::NumberedBullet()
|
|
{
|
|
m_rich->BeginNumberedBullet(1, 15, 20);
|
|
m_rich->AddParagraph("bullet one");
|
|
m_rich->EndNumberedBullet();
|
|
m_rich->BeginNumberedBullet(2, 25, -5);
|
|
m_rich->AddParagraph("bullet two");
|
|
m_rich->EndNumberedBullet();
|
|
|
|
wxTextAttr bullet;
|
|
m_rich->GetStyle(5, bullet);
|
|
|
|
CPPUNIT_ASSERT(bullet.HasBulletStyle());
|
|
CPPUNIT_ASSERT(bullet.HasBulletNumber());
|
|
CPPUNIT_ASSERT_EQUAL(1, bullet.GetBulletNumber());
|
|
CPPUNIT_ASSERT_EQUAL(15, bullet.GetLeftIndent());
|
|
CPPUNIT_ASSERT_EQUAL(20, bullet.GetLeftSubIndent());
|
|
|
|
m_rich->GetStyle(15, bullet);
|
|
|
|
CPPUNIT_ASSERT(bullet.HasBulletStyle());
|
|
CPPUNIT_ASSERT(bullet.HasBulletNumber());
|
|
CPPUNIT_ASSERT_EQUAL(2, bullet.GetBulletNumber());
|
|
CPPUNIT_ASSERT_EQUAL(25, bullet.GetLeftIndent());
|
|
CPPUNIT_ASSERT_EQUAL(-5, bullet.GetLeftSubIndent());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::SymbolBullet()
|
|
{
|
|
m_rich->BeginSymbolBullet("*", 15, 20);
|
|
m_rich->AddParagraph("bullet one");
|
|
m_rich->EndSymbolBullet();
|
|
m_rich->BeginSymbolBullet("%", 25, -5);
|
|
m_rich->AddParagraph("bullet two");
|
|
m_rich->EndSymbolBullet();
|
|
|
|
wxTextAttr bullet;
|
|
m_rich->GetStyle(5, bullet);
|
|
|
|
CPPUNIT_ASSERT(bullet.HasBulletStyle());
|
|
CPPUNIT_ASSERT(bullet.HasBulletText());
|
|
CPPUNIT_ASSERT_EQUAL("*", bullet.GetBulletText());
|
|
CPPUNIT_ASSERT_EQUAL(15, bullet.GetLeftIndent());
|
|
CPPUNIT_ASSERT_EQUAL(20, bullet.GetLeftSubIndent());
|
|
|
|
m_rich->GetStyle(15, bullet);
|
|
|
|
CPPUNIT_ASSERT(bullet.HasBulletStyle());
|
|
CPPUNIT_ASSERT(bullet.HasBulletText());
|
|
CPPUNIT_ASSERT_EQUAL("%", bullet.GetBulletText());
|
|
CPPUNIT_ASSERT_EQUAL(25, bullet.GetLeftIndent());
|
|
CPPUNIT_ASSERT_EQUAL(-5, bullet.GetLeftSubIndent());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::FontSize()
|
|
{
|
|
m_rich->BeginFontSize(24);
|
|
m_rich->AddParagraph("Large text");
|
|
m_rich->EndFontSize();
|
|
|
|
wxTextAttr size;
|
|
m_rich->GetStyle(5, size);
|
|
|
|
CPPUNIT_ASSERT(size.HasFontSize());
|
|
CPPUNIT_ASSERT_EQUAL(24, size.GetFontSize());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Font()
|
|
{
|
|
wxFont font(14, wxFONTFAMILY_DEFAULT, wxFONTSTYLE_NORMAL, wxFONTWEIGHT_NORMAL);
|
|
m_rich->BeginFont(font);
|
|
m_rich->AddParagraph("paragraph with font");
|
|
m_rich->EndFont();
|
|
|
|
wxTextAttr fontstyle;
|
|
m_rich->GetStyle(5, fontstyle);
|
|
|
|
CPPUNIT_ASSERT_EQUAL(font, fontstyle.GetFont());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Delete()
|
|
{
|
|
m_rich->AddParagraph("here is a long long line in a paragraph");
|
|
m_rich->SetSelection(0, 6);
|
|
|
|
CPPUNIT_ASSERT(m_rich->CanDeleteSelection());
|
|
|
|
m_rich->DeleteSelection();
|
|
|
|
CPPUNIT_ASSERT_EQUAL("is a long long line in a paragraph", m_rich->GetValue());
|
|
|
|
m_rich->SetSelection(0, 5);
|
|
|
|
CPPUNIT_ASSERT(m_rich->CanDeleteSelection());
|
|
|
|
m_rich->DeleteSelectedContent();
|
|
|
|
CPPUNIT_ASSERT_EQUAL("long long line in a paragraph", m_rich->GetValue());
|
|
|
|
m_rich->Delete(wxRichTextRange(14, 29));
|
|
|
|
CPPUNIT_ASSERT_EQUAL("long long line", m_rich->GetValue());
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Url()
|
|
{
|
|
m_rich->BeginURL("http://www.wxwidgets.org");
|
|
m_rich->WriteText("http://www.wxwidgets.org");
|
|
m_rich->EndURL();
|
|
|
|
wxTextAttr url;
|
|
m_rich->GetStyle(5, url);
|
|
|
|
CPPUNIT_ASSERT(url.HasURL());
|
|
CPPUNIT_ASSERT_EQUAL("http://www.wxwidgets.org", url.GetURL());
|
|
}
|
|
|
|
// Helper function for ::Table()
|
|
wxRichTextTable* GetCurrentTableInstance(wxRichTextParagraph* para)
|
|
{
|
|
wxRichTextTable* table = wxDynamicCast(para->FindObjectAtPosition(0), wxRichTextTable);
|
|
CPPUNIT_ASSERT(table);
|
|
return table;
|
|
}
|
|
|
|
void RichTextCtrlTestCase::Table()
|
|
{
|
|
m_rich->BeginSuppressUndo();
|
|
wxRichTextTable* table = m_rich->WriteTable(1, 1);
|
|
m_rich->EndSuppressUndo();
|
|
CPPUNIT_ASSERT(table);
|
|
CPPUNIT_ASSERT(m_rich->CanUndo() == false);
|
|
|
|
// Run the tests twice: first for the original table, then for a contained one
|
|
for (int t = 0; t < 2; ++t)
|
|
{
|
|
// Undo() and Redo() switch table instances, so invalidating 'table'
|
|
// The containing paragraph isn't altered, and so can be used to find the current object
|
|
wxRichTextParagraph* para = wxDynamicCast(table->GetParent(), wxRichTextParagraph);
|
|
CPPUNIT_ASSERT(para);
|
|
|
|
CPPUNIT_ASSERT(table->GetColumnCount() == 1);
|
|
CPPUNIT_ASSERT(table->GetRowCount() == 1);
|
|
|
|
// Test adding columns and rows
|
|
for (size_t n = 0; n < 3; ++n)
|
|
{
|
|
m_rich->BeginBatchUndo("Add col and row");
|
|
|
|
table->AddColumns(0, 1);
|
|
table->AddRows(0, 1);
|
|
|
|
m_rich->EndBatchUndo();
|
|
}
|
|
CPPUNIT_ASSERT(table->GetColumnCount() == 4);
|
|
CPPUNIT_ASSERT(table->GetRowCount() == 4);
|
|
|
|
// Test deleting columns and rows
|
|
for (size_t n = 0; n < 3; ++n)
|
|
{
|
|
m_rich->BeginBatchUndo("Delete col and row");
|
|
|
|
table->DeleteColumns(table->GetColumnCount() - 1, 1);
|
|
table->DeleteRows(table->GetRowCount() - 1, 1);
|
|
|
|
m_rich->EndBatchUndo();
|
|
}
|
|
CPPUNIT_ASSERT(table->GetColumnCount() == 1);
|
|
CPPUNIT_ASSERT(table->GetRowCount() == 1);
|
|
|
|
// Test undo, first of the deletions...
|
|
CPPUNIT_ASSERT(m_rich->CanUndo());
|
|
for (size_t n = 0; n < 3; ++n)
|
|
{
|
|
m_rich->Undo();
|
|
}
|
|
table = GetCurrentTableInstance(para);
|
|
CPPUNIT_ASSERT(table->GetColumnCount() == 4);
|
|
CPPUNIT_ASSERT(table->GetRowCount() == 4);
|
|
|
|
// ...then the additions
|
|
for (size_t n = 0; n < 3; ++n)
|
|
{
|
|
m_rich->Undo();
|
|
}
|
|
table = GetCurrentTableInstance(para);
|
|
CPPUNIT_ASSERT(table->GetColumnCount() == 1);
|
|
CPPUNIT_ASSERT(table->GetRowCount() == 1);
|
|
CPPUNIT_ASSERT(m_rich->CanUndo() == false);
|
|
|
|
// Similarly test redo. Additions:
|
|
CPPUNIT_ASSERT(m_rich->CanRedo());
|
|
for (size_t n = 0; n < 3; ++n)
|
|
{
|
|
m_rich->Redo();
|
|
}
|
|
table = GetCurrentTableInstance(para);
|
|
CPPUNIT_ASSERT(table->GetColumnCount() == 4);
|
|
CPPUNIT_ASSERT(table->GetRowCount() == 4);
|
|
|
|
// Deletions:
|
|
for (size_t n = 0; n < 3; ++n)
|
|
{
|
|
m_rich->Redo();
|
|
}
|
|
table = GetCurrentTableInstance(para);
|
|
CPPUNIT_ASSERT(table->GetColumnCount() == 1);
|
|
CPPUNIT_ASSERT(table->GetRowCount() == 1);
|
|
CPPUNIT_ASSERT(m_rich->CanRedo() == false);
|
|
|
|
// Now test multiple addition and deletion, and also suppression
|
|
m_rich->BeginSuppressUndo();
|
|
table->AddColumns(0, 3);
|
|
table->AddRows(0, 3);
|
|
CPPUNIT_ASSERT(table->GetColumnCount() == 4);
|
|
CPPUNIT_ASSERT(table->GetRowCount() == 4);
|
|
|
|
// Only delete 2 of these. This makes it easy to be sure we're dealing with the child table when we loop
|
|
table->DeleteColumns(0, 2);
|
|
table->DeleteRows(0, 2);
|
|
CPPUNIT_ASSERT(table->GetColumnCount() == 2);
|
|
CPPUNIT_ASSERT(table->GetRowCount() == 2);
|
|
m_rich->EndSuppressUndo();
|
|
|
|
m_rich->GetCommandProcessor()->ClearCommands(); // otherwise the command-history from this loop will cause CPPUNIT_ASSERT failures in the next one
|
|
|
|
if (t == 0)
|
|
{
|
|
// For round 2, re-run the tests on another table inside the last cell of the first one
|
|
wxRichTextCell* cell = table->GetCell(table->GetRowCount() - 1, table->GetColumnCount() - 1);
|
|
CPPUNIT_ASSERT(cell);
|
|
m_rich->SetFocusObject(cell);
|
|
m_rich->BeginSuppressUndo();
|
|
table = m_rich->WriteTable(1, 1);
|
|
m_rich->EndSuppressUndo();
|
|
CPPUNIT_ASSERT(table);
|
|
}
|
|
}
|
|
|
|
// Test ClearTable()
|
|
table->ClearTable();
|
|
CPPUNIT_ASSERT_EQUAL(0, table->GetCells().GetCount());
|
|
CPPUNIT_ASSERT_EQUAL(0, table->GetColumnCount());
|
|
CPPUNIT_ASSERT_EQUAL(0, table->GetRowCount());
|
|
|
|
m_rich->Clear();
|
|
m_rich->SetFocusObject(NULL);
|
|
}
|
|
|
|
#endif //wxUSE_RICHTEXT
|