diff options
| author | Richard Maudsley <richard.maudsley@isode.com> | 2014-01-13 15:26:24 (GMT) | 
|---|---|---|
| committer | Swift Review <review@swift.im> | 2014-07-09 14:01:41 (GMT) | 
| commit | f2bcc401477dcb5ca52b5d9d5e85f4bf7bae9285 (patch) | |
| tree | 01cf807b2ad59f5ea6504fd28d12e0f994e2f907 /Swift/Controllers/Chat/UnitTest | |
| parent | 8e03583fe21bcd5e0025da81d8f4a34ed05cd058 (diff) | |
| download | swift-contrib-f2bcc401477dcb5ca52b5d9d5e85f4bf7bae9285.zip swift-contrib-f2bcc401477dcb5ca52b5d9d5e85f4bf7bae9285.tar.bz2 | |
Reworked highlight rules dialog. Added support for highlighting individual words in messages.
Change-Id: I378fa69077c29008db4ef7c2265e5212924bc2ce
Diffstat (limited to 'Swift/Controllers/Chat/UnitTest')
| -rw-r--r-- | Swift/Controllers/Chat/UnitTest/ChatMessageParserTest.cpp | 134 | ||||
| -rw-r--r-- | Swift/Controllers/Chat/UnitTest/MUCControllerTest.cpp | 7 | 
2 files changed, 123 insertions, 18 deletions
| diff --git a/Swift/Controllers/Chat/UnitTest/ChatMessageParserTest.cpp b/Swift/Controllers/Chat/UnitTest/ChatMessageParserTest.cpp index 0a14303..5dca63a 100644 --- a/Swift/Controllers/Chat/UnitTest/ChatMessageParserTest.cpp +++ b/Swift/Controllers/Chat/UnitTest/ChatMessageParserTest.cpp @@ -49,4 +49,9 @@ public:  	} +	void assertHighlight(const ChatWindow::ChatMessage& result, size_t index, const std::string& text) { +		boost::shared_ptr<ChatWindow::ChatHighlightingMessagePart> part = boost::dynamic_pointer_cast<ChatWindow::ChatHighlightingMessagePart>(result.getParts()[index]); +		CPPUNIT_ASSERT_EQUAL(text, part->text); +	} +  	void assertURL(const ChatWindow::ChatMessage& result, size_t index, const std::string& text) {  		boost::shared_ptr<ChatWindow::ChatURIMessagePart> part = boost::dynamic_pointer_cast<ChatWindow::ChatURIMessagePart>(result.getParts()[index]); @@ -54,21 +59,124 @@ public:  	} +	static HighlightRule ruleFromKeyword(const std::string& keyword, bool matchCase, bool matchWholeWord) +	{ +		HighlightRule rule; +		std::vector<std::string> keywords; +		keywords.push_back(keyword); +		rule.setKeywords(keywords); +		rule.setMatchCase(matchCase); +		rule.setMatchWholeWords(matchWholeWord); +		rule.setMatchChat(true); +		return rule; +	} + +	static const HighlightRulesListPtr ruleListFromKeyword(const std::string& keyword, bool matchCase, bool matchWholeWord) +	{ +		boost::shared_ptr<HighlightManager::HighlightRulesList> list = boost::make_shared<HighlightManager::HighlightRulesList>(); +		list->addRule(ruleFromKeyword(keyword, matchCase, matchWholeWord)); +		return list; +	} + +	static const HighlightRulesListPtr ruleListFromKeywords(const HighlightRule &rule1, const HighlightRule &rule2) +	{ +		boost::shared_ptr<HighlightManager::HighlightRulesList> list = boost::make_shared<HighlightManager::HighlightRulesList>(); +		list->addRule(rule1); +		list->addRule(rule2); +		return list; +	} +  	void testFullBody() { -		ChatMessageParser testling(emoticons_); -		ChatWindow::ChatMessage result = testling.parseMessageBody(":) shiny :( :) http://wonderland.lit/blah http://denmark.lit boom boom"); +		const std::string no_special_message = "a message with no special content"; +		ChatMessageParser testling(emoticons_, boost::make_shared<HighlightManager::HighlightRulesList>()); +		ChatWindow::ChatMessage result = testling.parseMessageBody(no_special_message); +		assertText(result, 0, no_special_message); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeyword("trigger", false, false)); +		result = testling.parseMessageBody(":) shiny :( trigger :) http://wonderland.lit/blah http://denmark.lit boom boom");  		assertEmoticon(result, 0, smile1_, smile1Path_);  		assertText(result, 1, " shiny ");  		assertEmoticon(result, 2, smile2_, smile2Path_);  		assertText(result, 3, " "); -		assertEmoticon(result, 4, smile1_, smile1Path_); +		assertHighlight(result, 4, "trigger");  		assertText(result, 5, " "); -		assertURL(result, 6, "http://wonderland.lit/blah"); +		assertEmoticon(result, 6, smile1_, smile1Path_);  		assertText(result, 7, " "); -		assertURL(result, 8, "http://denmark.lit"); -		assertText(result, 9, " boom boom"); +		assertURL(result, 8, "http://wonderland.lit/blah"); +		assertText(result, 9, " "); +		assertURL(result, 10, "http://denmark.lit"); +		assertText(result, 11, " boom boom"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeyword("trigger", false, false)); +		result = testling.parseMessageBody("testtriggermessage"); +		assertText(result, 0, "test"); +		assertHighlight(result, 1, "trigger"); +		assertText(result, 2, "message"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeyword("trigger", false, true)); +		result = testling.parseMessageBody("testtriggermessage"); +		assertText(result, 0, "testtriggermessage"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeyword("trigger", true, false)); +		result = testling.parseMessageBody("TrIgGeR"); +		assertText(result, 0, "TrIgGeR"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeyword("trigger", false, false)); +		result = testling.parseMessageBody("TrIgGeR"); +		assertHighlight(result, 0, "TrIgGeR"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeyword("trigger", false, false)); +		result = testling.parseMessageBody("partialTrIgGeRmatch"); +		assertText(result, 0, "partial"); +		assertHighlight(result, 1, "TrIgGeR"); +		assertText(result, 2, "match"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeywords(ruleFromKeyword("one", false, false), ruleFromKeyword("three", false, false))); +		result = testling.parseMessageBody("zero one two three"); +		assertText(result, 0, "zero "); +		assertHighlight(result, 1, "one"); +		assertText(result, 2, " two "); +		assertHighlight(result, 3, "three"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeywords(ruleFromKeyword("one", false, false), ruleFromKeyword("three", false, false))); +		result = testling.parseMessageBody("zero oNe two tHrEe"); +		assertText(result, 0, "zero "); +		assertHighlight(result, 1, "oNe"); +		assertText(result, 2, " two "); +		assertHighlight(result, 3, "tHrEe"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeywords(ruleFromKeyword("one", false, false), ruleFromKeyword("three", true, false))); +		result = testling.parseMessageBody("zero oNe two tHrEe"); +		assertText(result, 0, "zero "); +		assertHighlight(result, 1, "oNe"); +		assertText(result, 2, " two tHrEe"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeywords(ruleFromKeyword("one", true, false), ruleFromKeyword("three", true, false))); +		result = testling.parseMessageBody("zero oNe two tHrEe"); +		assertText(result, 0, "zero oNe two tHrEe"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeywords(ruleFromKeyword("one", false, false), ruleFromKeyword("three", false, false))); +		result = testling.parseMessageBody("zeroonetwothree"); +		assertText(result, 0, "zero"); +		assertHighlight(result, 1, "one"); +		assertText(result, 2, "two"); +		assertHighlight(result, 3, "three"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeywords(ruleFromKeyword("one", true, false), ruleFromKeyword("three", false, false))); +		result = testling.parseMessageBody("zeroOnEtwoThReE"); +		assertText(result, 0, "zeroOnEtwo"); +		assertHighlight(result, 1, "ThReE"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeywords(ruleFromKeyword("one", false, true), ruleFromKeyword("three", false, false))); +		result = testling.parseMessageBody("zeroonetwothree"); +		assertText(result, 0, "zeroonetwo"); +		assertHighlight(result, 1, "three"); + +		testling = ChatMessageParser(emoticons_, ruleListFromKeywords(ruleFromKeyword("one", false, true), ruleFromKeyword("three", false, true))); +		result = testling.parseMessageBody("zeroonetwothree"); +		assertText(result, 0, "zeroonetwothree");  	}  	void testOneEmoticon() { -		ChatMessageParser testling(emoticons_); +		ChatMessageParser testling(emoticons_, boost::make_shared<HighlightManager::HighlightRulesList>());  		ChatWindow::ChatMessage result = testling.parseMessageBody(" :) ");  		assertText(result, 0, " "); @@ -79,5 +187,5 @@ public:  	void testBareEmoticon() { -		ChatMessageParser testling(emoticons_); +		ChatMessageParser testling(emoticons_, boost::make_shared<HighlightManager::HighlightRulesList>());  		ChatWindow::ChatMessage result = testling.parseMessageBody(":)");  		assertEmoticon(result, 0, smile1_, smile1Path_); @@ -85,5 +193,5 @@ public:  	void testHiddenEmoticon() { -		ChatMessageParser testling(emoticons_); +		ChatMessageParser testling(emoticons_, boost::make_shared<HighlightManager::HighlightRulesList>());  		ChatWindow::ChatMessage result = testling.parseMessageBody("b:)a");  		assertText(result, 0, "b:)a"); @@ -91,5 +199,5 @@ public:  	void testEndlineEmoticon() { -		ChatMessageParser testling(emoticons_); +		ChatMessageParser testling(emoticons_, boost::make_shared<HighlightManager::HighlightRulesList>());  		ChatWindow::ChatMessage result = testling.parseMessageBody("Lazy:)");  		assertText(result, 0, "Lazy"); @@ -98,5 +206,5 @@ public:  	void testBoundedEmoticons() { -		ChatMessageParser testling(emoticons_); +		ChatMessageParser testling(emoticons_, boost::make_shared<HighlightManager::HighlightRulesList>());  		ChatWindow::ChatMessage result = testling.parseMessageBody(":)Lazy:(");  		assertEmoticon(result, 0, smile1_, smile1Path_); @@ -106,5 +214,5 @@ public:  	void testEmoticonParenthesis() { -		ChatMessageParser testling(emoticons_); +		ChatMessageParser testling(emoticons_, boost::make_shared<HighlightManager::HighlightRulesList>());  		ChatWindow::ChatMessage result = testling.parseMessageBody("(Like this :))");  		assertText(result, 0, "(Like this "); @@ -113,5 +221,4 @@ public:  	} -  private:  	std::map<std::string, std::string> emoticons_; @@ -123,3 +230,2 @@ private:  CPPUNIT_TEST_SUITE_REGISTRATION(ChatMessageParserTest); - diff --git a/Swift/Controllers/Chat/UnitTest/MUCControllerTest.cpp b/Swift/Controllers/Chat/UnitTest/MUCControllerTest.cpp index 7268878..bb22e43 100644 --- a/Swift/Controllers/Chat/UnitTest/MUCControllerTest.cpp +++ b/Swift/Controllers/Chat/UnitTest/MUCControllerTest.cpp @@ -1,4 +1,4 @@  /* - * Copyright (c) 2010-2013 Kevin Smith + * Copyright (c) 2010-2014 Kevin Smith   * Licensed under the GNU General Public License v3.   * See Documentation/Licenses/GPLv3.txt for more information. @@ -82,5 +82,5 @@ public:  		muc_ = boost::make_shared<MockMUC>(mucJID_);  		mocks_->ExpectCall(chatWindowFactory_, ChatWindowFactory::createChatWindow).With(muc_->getJID(), uiEventStream_).Return(window_); -		chatMessageParser_ = new ChatMessageParser(std::map<std::string, std::string>()); +		chatMessageParser_ = boost::make_shared<ChatMessageParser>(std::map<std::string, std::string>(), highlightManager_->getRules(), true);  		vcardStorage_ = new VCardMemoryStorage(crypto_.get());  		vcardManager_ = new VCardManager(self_, iqRouter_, vcardStorage_); @@ -106,5 +106,4 @@ public:  		delete mucRegistry_;  		delete avatarManager_; -		delete chatMessageParser_;  	} @@ -430,5 +429,5 @@ private:  	DummySettingsProvider* settings_;  	HighlightManager* highlightManager_; -	ChatMessageParser* chatMessageParser_; +	boost::shared_ptr<ChatMessageParser> chatMessageParser_;  	boost::shared_ptr<CryptoProvider> crypto_;  	VCardManager* vcardManager_; | 
 Swift
 Swift