Fixed segfault at POP3 connection error.

This commit is contained in:
Vincent Richard 2013-08-16 11:41:25 +02:00
parent 78a7c1fbe0
commit 757f8a7dc7
3 changed files with 87 additions and 10 deletions

View File

@ -416,6 +416,7 @@ libvmimetest_sources = [
'tests/net/messageSetTest.cpp',
'tests/net/pop3/POP3CommandTest.cpp',
'tests/net/pop3/POP3ResponseTest.cpp',
'tests/net/pop3/POP3StoreTest.cpp',
'tests/net/pop3/POP3UtilsTest.cpp',
'tests/net/imap/IMAPTagTest.cpp',
'tests/net/imap/IMAPParserTest.cpp',

View File

@ -188,18 +188,25 @@ void POP3Connection::disconnect()
void POP3Connection::internalDisconnect()
{
try
if (m_socket)
{
POP3Command::QUIT()->send(thisRef().dynamicCast <POP3Connection>());
POP3Response::readResponse(thisRef().dynamicCast <POP3Connection>());
}
catch (exception&)
{
// Not important
}
if (m_socket->isConnected())
{
try
{
POP3Command::QUIT()->send(thisRef().dynamicCast <POP3Connection>());
POP3Response::readResponse(thisRef().dynamicCast <POP3Connection>());
}
catch (exception&)
{
// Not important
}
m_socket->disconnect();
m_socket = NULL;
m_socket->disconnect();
}
m_socket = NULL;
}
m_timeoutHandler = NULL;

View File

@ -0,0 +1,69 @@
//
// VMime library (http://www.vmime.org)
// Copyright (C) 2002-2013 Vincent Richard <vincent@vmime.org>
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License as
// published by the Free Software Foundation; either version 3 of
// the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
// General Public License for more details.
//
// You should have received a copy of the GNU General Public License along
// with this program; if not, write to the Free Software Foundation, Inc.,
// 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.
//
// Linking this library statically or dynamically with other modules is making
// a combined work based on this library. Thus, the terms and conditions of
// the GNU General Public License cover the whole combination.
//
#include "tests/testUtils.hpp"
#include "tests/net/pop3/POP3TestUtils.hpp"
#include "vmime/net/pop3/POP3Store.hpp"
#include "vmime/net/pop3/POP3SStore.hpp"
VMIME_TEST_SUITE_BEGIN(POP3StoreTest)
VMIME_TEST_LIST_BEGIN
VMIME_TEST(testCreateFromURL)
VMIME_TEST(testConnectToInvalidServer)
VMIME_TEST_LIST_END
void testCreateFromURL()
{
vmime::ref <vmime::net::session> sess
= vmime::create <vmime::net::session>();
// POP3
vmime::utility::url url("pop3://pop3.vmime.org");
vmime::ref <vmime::net::store> store = sess->getStore(url);
VASSERT_TRUE("pop3", typeid(*store) == typeid(vmime::net::pop3::POP3Store));
// POP3S
vmime::utility::url url2("pop3s://pop3s.vmime.org");
vmime::ref <vmime::net::store> store2 = sess->getStore(url2);
VASSERT_TRUE("pop3s", typeid(*store2) == typeid(vmime::net::pop3::POP3SStore));
}
void testConnectToInvalidServer()
{
vmime::ref <vmime::net::session> sess
= vmime::create <vmime::net::session>();
vmime::utility::url url("pop3://invalid-pop3-server");
vmime::ref <vmime::net::store> store = sess->getStore(url);
VASSERT_THROW("connect", store->connect(), vmime::exceptions::connection_error);
}
VMIME_TEST_SUITE_END