diff options
| -rw-r--r-- | Swiften/IDN/ICUConverter.cpp | 157 | ||||
| -rw-r--r-- | Swiften/IDN/ICUConverter.h | 71 | ||||
| -rw-r--r-- | Swiften/IDN/IDNA.cpp | 61 | ||||
| -rw-r--r-- | Swiften/IDN/SConscript | 8 | ||||
| -rw-r--r-- | Swiften/IDN/StringPrep.cpp | 146 | ||||
| -rw-r--r-- | Swiften/IDN/UnitTest/IDNATest.cpp | 35 | ||||
| -rw-r--r-- | Swiften/IDN/UnitTest/IDNConverterTest.cpp | 56 | ||||
| -rw-r--r-- | Swiften/IDN/UnitTest/StringPrepTest.cpp | 34 | 
8 files changed, 226 insertions, 342 deletions
diff --git a/Swiften/IDN/ICUConverter.cpp b/Swiften/IDN/ICUConverter.cpp new file mode 100644 index 0000000..18ff231 --- /dev/null +++ b/Swiften/IDN/ICUConverter.cpp @@ -0,0 +1,157 @@ +/* + * Copyright (c) 2012-2013 Remko Tronçon + * Licensed under the GNU General Public License v3. + * See Documentation/Licenses/GPLv3.txt for more information. + */ + +#include <Swiften/IDN/ICUConverter.h> + +#pragma GCC diagnostic ignored "-Wold-style-cast" +#pragma clang diagnostic ignored "-Wheader-hygiene" +#include <unicode/uidna.h> +#include <unicode/usprep.h> +#include <unicode/ucnv.h> +#include <unicode/ustring.h> + + #include <boost/numeric/conversion/cast.hpp> + +using namespace Swift; +using boost::numeric_cast; + +namespace { +	typedef std::vector<UChar, SafeAllocator<UChar> > ICUString; + +	const char* toConstCharArray(const std::string& input) { +		return input.c_str(); +	} + +	const char* toConstCharArray(const std::vector<unsigned char, SafeAllocator<unsigned char> >& input) { +		return reinterpret_cast<const char*>(vecptr(input)); +	} + +	template<typename T> +	ICUString convertToICUString(const T& s) { +		ICUString result; +		result.resize(s.size()); +		UErrorCode status = U_ZERO_ERROR; +		int32_t icuResultLength = numeric_cast<int32_t>(result.size()); +		u_strFromUTF8Lenient(vecptr(result), numeric_cast<int32_t>(result.size()), &icuResultLength, toConstCharArray(s), numeric_cast<int32_t>(s.size()), &status); +		if (status == U_BUFFER_OVERFLOW_ERROR) { +			status = U_ZERO_ERROR; +			result.resize(numeric_cast<size_t>(icuResultLength)); +			u_strFromUTF8Lenient(vecptr(result), numeric_cast<int32_t>(result.size()), &icuResultLength, toConstCharArray(s), numeric_cast<int32_t>(s.size()), &status); +		} +		if (U_FAILURE(status)) { +			return ICUString(); +		} +		result.resize(numeric_cast<size_t>(icuResultLength)); +		return result; +	} + +	std::vector<char, SafeAllocator<char> > convertToArray(const ICUString& input) { +		std::vector<char, SafeAllocator<char> > result; +		result.resize(input.size()); +		UErrorCode status = U_ZERO_ERROR; +		int32_t inputLength = numeric_cast<int32_t>(result.size()); +		u_strToUTF8(vecptr(result), numeric_cast<int32_t>(result.size()), &inputLength, vecptr(input), numeric_cast<int32_t>(input.size()), &status); +		if (status == U_BUFFER_OVERFLOW_ERROR) { +			status = U_ZERO_ERROR; +			result.resize(numeric_cast<size_t>(inputLength)); +			u_strToUTF8(vecptr(result), numeric_cast<int32_t>(result.size()), &inputLength, vecptr(input), numeric_cast<int32_t>(input.size()), &status); +		} +		if (U_FAILURE(status)) { +			return std::vector<char, SafeAllocator<char> >(); +		} + +		result.resize(numeric_cast<size_t>(inputLength) + 1); +		result[result.size() - 1] = '\0'; +		return result; +	} + +	std::string convertToString(const ICUString& input) { +		return std::string(vecptr(convertToArray(input))); +	} + +	UStringPrepProfileType getICUProfileType(IDNConverter::StringPrepProfile profile) { +		switch(profile) { +			case IDNConverter::NamePrep: return USPREP_RFC3491_NAMEPREP; +			case IDNConverter::XMPPNodePrep: return USPREP_RFC3920_NODEPREP; +			case IDNConverter::XMPPResourcePrep: return USPREP_RFC3920_RESOURCEPREP; +			case IDNConverter::SASLPrep: return USPREP_RFC4013_SASLPREP; +		} +		assert(false); +		return USPREP_RFC3491_NAMEPREP; +	} + +	template<typename StringType> +	std::vector<char, SafeAllocator<char> > getStringPreparedDetail(const StringType& s, IDNConverter::StringPrepProfile profile) { +		UErrorCode status = U_ZERO_ERROR; + +		boost::shared_ptr<UStringPrepProfile> icuProfile(usprep_openByType(getICUProfileType(profile), &status), usprep_close); +		assert(U_SUCCESS(status)); + +		ICUString icuInput = convertToICUString(s); +		ICUString icuResult; +		UParseError parseError; +		icuResult.resize(icuInput.size()); +		int32_t icuResultLength = usprep_prepare(icuProfile.get(), vecptr(icuInput), numeric_cast<int32_t>(icuInput.size()), vecptr(icuResult), numeric_cast<int32_t>(icuResult.size()), USPREP_ALLOW_UNASSIGNED, &parseError, &status);  +		icuResult.resize(numeric_cast<size_t>(icuResultLength)); +		if (status == U_BUFFER_OVERFLOW_ERROR) { +			status = U_ZERO_ERROR; +			icuResult.resize(numeric_cast<size_t>(icuResultLength)); +			icuResultLength = usprep_prepare(icuProfile.get(), vecptr(icuInput), numeric_cast<int32_t>(icuInput.size()), vecptr(icuResult), numeric_cast<int32_t>(icuResult.size()), USPREP_ALLOW_UNASSIGNED, &parseError, &status);  +			icuResult.resize(numeric_cast<size_t>(icuResultLength)); +		} +		if (U_FAILURE(status)) { +			return std::vector<char, SafeAllocator<char> >(); +		} +		icuResult.resize(numeric_cast<size_t>(icuResultLength)); + +		return convertToArray(icuResult); +	} +} + +namespace Swift { + +std::string ICUConverter::getStringPrepared(const std::string& s, StringPrepProfile profile) { +	if (s.empty()) { +		return ""; +	} +	std::vector<char, SafeAllocator<char> > preparedData = getStringPreparedDetail(s, profile); +	if (preparedData.empty()) { +		throw std::exception(); +	} +	return std::string(vecptr(preparedData)); +} + +SafeByteArray ICUConverter::getStringPrepared(const SafeByteArray& s, StringPrepProfile profile) { +	if (s.empty()) { +		return SafeByteArray(); +	} +	std::vector<char, SafeAllocator<char> > preparedData = getStringPreparedDetail(s, profile); +	if (preparedData.empty()) { +		throw std::exception(); +	} +	return createSafeByteArray(reinterpret_cast<const char*>(vecptr(preparedData))); +} + +std::string ICUConverter::getIDNAEncoded(const std::string& domain) { +	UErrorCode status = U_ZERO_ERROR; +	ICUString icuInput = convertToICUString(domain); +	ICUString icuResult; +	icuResult.resize(icuInput.size()); +	UParseError parseError; +	int32_t icuResultLength = uidna_IDNToASCII(vecptr(icuInput), numeric_cast<int32_t>(icuInput.size()), vecptr(icuResult), numeric_cast<int32_t>(icuResult.size()), UIDNA_DEFAULT, &parseError, &status); +	if (status == U_BUFFER_OVERFLOW_ERROR) { +		status = U_ZERO_ERROR; +		icuResult.resize(numeric_cast<size_t>(icuResultLength)); +		icuResultLength = uidna_IDNToASCII(vecptr(icuInput), numeric_cast<int32_t>(icuInput.size()), vecptr(icuResult), numeric_cast<int32_t>(icuResult.size()), UIDNA_DEFAULT, &parseError, &status); +	} +	if (U_FAILURE(status)) { +		return domain; +	} +	icuResult.resize(numeric_cast<size_t>(icuResultLength)); +	return convertToString(icuResult); +} + +} diff --git a/Swiften/IDN/ICUConverter.h b/Swiften/IDN/ICUConverter.h index c476b54..8ba9bb5 100644 --- a/Swiften/IDN/ICUConverter.h +++ b/Swiften/IDN/ICUConverter.h @@ -1,77 +1,22 @@  /* - * Copyright (c) 2012 Remko Tronçon + * Copyright (c) 2012-2013 Remko Tronçon   * Licensed under the GNU General Public License v3.   * See Documentation/Licenses/GPLv3.txt for more information.   */  #pragma once -#pragma GCC diagnostic ignored "-Wold-style-cast" - -#include <unicode/ustring.h> -#include <cassert>  #include <string> -#include <vector> -#include <Swiften/Base/ByteArray.h> -#include <Swiften/Base/SafeByteArray.h> +#include <Swiften/Base/API.h> +#include <Swiften/Base/Override.h> +#include <Swiften/IDN/IDNConverter.h>  namespace Swift { - -	class ICUConverter { +	class SWIFTEN_API ICUConverter : public IDNConverter {  		public: -			typedef std::vector<UChar, SafeAllocator<UChar> > ICUString; - -			template<typename T> -			ICUString convertToICUString(const T& s) { -				ICUString result; -				result.resize(s.size()); -				UErrorCode status = U_ZERO_ERROR; -				int icuResultLength = result.size(); -				u_strFromUTF8Lenient(vecptr(result), result.size(), &icuResultLength, toConstCharArray(s), s.size(), &status); -				if (status == U_BUFFER_OVERFLOW_ERROR) { -					status = U_ZERO_ERROR; -					result.resize(icuResultLength); -					u_strFromUTF8Lenient(vecptr(result), result.size(), &icuResultLength, toConstCharArray(s), s.size(), &status); -				} -				if (U_FAILURE(status)) { -					return ICUString(); -				} -				result.resize(icuResultLength); -				return result; -			} - -			std::string convertToString(const ICUString& input) { -				return std::string(vecptr(convertToArray(input))); -			} +			virtual std::string getStringPrepared(const std::string& s, StringPrepProfile profile) SWIFTEN_OVERRIDE; +			virtual SafeByteArray getStringPrepared(const SafeByteArray& s, StringPrepProfile profile) SWIFTEN_OVERRIDE; -			std::vector<char, SafeAllocator<char> > convertToArray(const ICUString& input) { -				std::vector<char, SafeAllocator<char> > result; -				result.resize(input.size()); -				UErrorCode status = U_ZERO_ERROR; -				int inputLength = result.size(); -				u_strToUTF8(vecptr(result), result.size(), &inputLength, vecptr(input), input.size(), &status); -				if (status == U_BUFFER_OVERFLOW_ERROR) { -					status = U_ZERO_ERROR; -					result.resize(inputLength); -					u_strToUTF8(vecptr(result), result.size(), &inputLength, vecptr(input), input.size(), &status); -				} -				if (U_FAILURE(status)) { -					return std::vector<char, SafeAllocator<char> >(); -				} - -				result.resize(inputLength + 1); -				result[result.size() - 1] = '\0'; -				return result; -			} - -		private: -			static const char* toConstCharArray(const std::string& input) { -				return input.c_str(); -			} - -			static const char* toConstCharArray(const std::vector<unsigned char, SafeAllocator<unsigned char> >& input) { -				return reinterpret_cast<const char*>(vecptr(input)); -			} +			virtual std::string getIDNAEncoded(const std::string& s) SWIFTEN_OVERRIDE;  	}; -  } diff --git a/Swiften/IDN/IDNA.cpp b/Swiften/IDN/IDNA.cpp deleted file mode 100644 index f2ac8fb..0000000 --- a/Swiften/IDN/IDNA.cpp +++ /dev/null @@ -1,61 +0,0 @@ -/* - * Copyright (c) 2010-2012 Remko Tronçon - * Licensed under the GNU General Public License v3. - * See Documentation/Licenses/GPLv3.txt for more information. - */ - -#include <Swiften/IDN/IDNA.h> - -#include <vector> -#include <cstdlib> -#if defined(HAVE_ICU) -#pragma GCC diagnostic ignored "-Wold-style-cast" -#include <Swiften/IDN/ICUConverter.h> -#include <unicode/uidna.h> -#elif defined(HAVE_LIBIDN) -#include <stringprep.h> -#include <idna.h> -#endif -#include <Swiften/Base/ByteArray.h> -#include <boost/shared_ptr.hpp> - -namespace Swift { - -std::string IDNA::getEncoded(const std::string& domain) { -#if defined(HAVE_ICU) -	UErrorCode status = U_ZERO_ERROR; -	ICUConverter converter; - -	ICUConverter::ICUString icuInput = converter.convertToICUString(domain); -	ICUConverter::ICUString icuResult; -	icuResult.resize(icuInput.size()); -	UParseError parseError; -	int icuResultLength = uidna_IDNToASCII(vecptr(icuInput), icuInput.size(), vecptr(icuResult), icuResult.size(), UIDNA_DEFAULT, &parseError, &status); -	if (status == U_BUFFER_OVERFLOW_ERROR) { -		status = U_ZERO_ERROR; -		icuResult.resize(icuResultLength); -		icuResultLength = uidna_IDNToASCII(vecptr(icuInput), icuInput.size(), vecptr(icuResult), icuResult.size(), UIDNA_DEFAULT, &parseError, &status); -	} -	if (U_FAILURE(status)) { -		return domain; -	} -	icuResult.resize(icuResultLength); - -	return converter.convertToString(icuResult); - -#elif defined(HAVE_LIBIDN) - - -	char* output; -	if (idna_to_ascii_8z(domain.c_str(), &output, 0) == IDNA_SUCCESS) { -		std::string result(output); -		free(output); -		return result; -	} -	else { -		return domain; -	} -#endif -} - -} diff --git a/Swiften/IDN/SConscript b/Swiften/IDN/SConscript index 1011563..4f540cd 100644 --- a/Swiften/IDN/SConscript +++ b/Swiften/IDN/SConscript @@ -16,8 +16,10 @@ objects += myenv.SwiftenObject(["PlatformIDNConverter.cpp"])  swiften_env.Append(SWIFTEN_OBJECTS = [objects]) -#env.Append(UNITTEST_OBJECTS = myenv.SwiftenObject([ -#			File("UnitTest/IDNATest.cpp"), -#]) +test_env = myenv.Clone() +test_env.UseFlags(swiften_env["CPPUNIT_FLAGS"]) +env.Append(UNITTEST_OBJECTS = test_env.SwiftenObject([ +			File("UnitTest/IDNConverterTest.cpp"), +])) diff --git a/Swiften/IDN/StringPrep.cpp b/Swiften/IDN/StringPrep.cpp deleted file mode 100644 index a0d067e..0000000 --- a/Swiften/IDN/StringPrep.cpp +++ /dev/null @@ -1,146 +0,0 @@ -/* - * Copyright (c) 2010-2012 Remko Tronçon - * Licensed under the GNU General Public License v3. - * See Documentation/Licenses/GPLv3.txt for more information. - */ - -#include <Swiften/IDN/StringPrep.h> - -#if defined(HAVE_ICU) -#pragma GCC diagnostic ignored "-Wold-style-cast" -#include <Swiften/IDN/ICUConverter.h> -#include <unicode/usprep.h> -#include <unicode/ucnv.h> -#elif defined(HAVE_LIBIDN) -extern "C" { -	#include <stringprep.h> -} -#endif - -#include <vector> -#include <cassert> -#include <Swiften/Base/SafeAllocator.h> -#include <boost/shared_ptr.hpp> - -using namespace Swift; - -#if defined(HAVE_ICU) - -namespace { -	static UStringPrepProfileType getICUProfileType(StringPrep::Profile profile) { -		switch(profile) { -			case StringPrep::NamePrep: return USPREP_RFC3491_NAMEPREP; -			case StringPrep::XMPPNodePrep: return USPREP_RFC3920_NODEPREP; -			case StringPrep::XMPPResourcePrep: return USPREP_RFC3920_RESOURCEPREP; -			case StringPrep::SASLPrep: return USPREP_RFC4013_SASLPREP; -		} -		assert(false); -		return USPREP_RFC3491_NAMEPREP; -	} - -	template<typename StringType> -	std::vector<char, SafeAllocator<char> > getStringPrepared(const StringType& s, StringPrep::Profile profile) { -		UErrorCode status = U_ZERO_ERROR; -		ICUConverter converter; - -		boost::shared_ptr<UStringPrepProfile> icuProfile(usprep_openByType(getICUProfileType(profile), &status), usprep_close); -		assert(U_SUCCESS(status)); - -		ICUConverter::ICUString icuInput = converter.convertToICUString(s); -		ICUConverter::ICUString icuResult; -		UParseError parseError; -		icuResult.resize(icuInput.size()); -		int icuResultLength = usprep_prepare(icuProfile.get(), vecptr(icuInput), icuInput.size(), vecptr(icuResult), icuResult.size(), USPREP_ALLOW_UNASSIGNED, &parseError, &status); icuResult.resize(icuResultLength); -		if (status == U_BUFFER_OVERFLOW_ERROR) { -			status = U_ZERO_ERROR; -			icuResult.resize(icuResultLength); -			icuResultLength = usprep_prepare(icuProfile.get(), vecptr(icuInput), icuInput.size(), vecptr(icuResult), icuResult.size(), USPREP_ALLOW_UNASSIGNED, &parseError, &status); icuResult.resize(icuResultLength); -		} -		if (U_FAILURE(status)) { -			return std::vector<char, SafeAllocator<char> >(); -		} -		icuResult.resize(icuResultLength); - -		return converter.convertToArray(icuResult); -	} -} - -namespace Swift { - -std::string StringPrep::getPrepared(const std::string& s, Profile profile) { -	if (s.empty()) { -		return ""; -	} -	std::vector<char, SafeAllocator<char> > preparedData = getStringPrepared(s, profile); -	if (preparedData.empty()) { -		throw std::exception(); -	} -	return std::string(vecptr(preparedData)); -} - -SafeByteArray StringPrep::getPrepared(const SafeByteArray& s, Profile profile) { -	if (s.empty()) { -		return SafeByteArray(); -	} -	std::vector<char, SafeAllocator<char> > preparedData = getStringPrepared(s, profile); -	if (preparedData.empty()) { -		throw std::exception(); -	} -	return createSafeByteArray(reinterpret_cast<const char*>(vecptr(preparedData))); -} - -} - -//////////////////////////////////////////////////////////////////////////////// - -#elif defined(HAVE_LIBIDN) - -namespace { -	static const int MAX_STRINGPREP_SIZE = 1024; - -	const Stringprep_profile* getLibIDNProfile(StringPrep::Profile profile) { -		switch(profile) { -			case StringPrep::NamePrep: return stringprep_nameprep; -			case StringPrep::XMPPNodePrep: return stringprep_xmpp_nodeprep; -			case StringPrep::XMPPResourcePrep: return stringprep_xmpp_resourceprep; -			case StringPrep::SASLPrep: return stringprep_saslprep; -		} -		assert(false); -		return 0; -	} - -	template<typename StringType, typename ContainerType> -	ContainerType getStringPrepared(const StringType& s, StringPrep::Profile profile) { -		ContainerType input(s.begin(), s.end()); -		input.resize(MAX_STRINGPREP_SIZE); -		if (stringprep(&input[0], MAX_STRINGPREP_SIZE, static_cast<Stringprep_profile_flags>(0), getLibIDNProfile(profile)) == 0) { -			return input; -		} -		else { -			return ContainerType(); -		} -	} -} - -namespace Swift { - -std::string StringPrep::getPrepared(const std::string& s, Profile profile) { -	std::vector<char> preparedData = getStringPrepared< std::string, std::vector<char> >(s, profile); -	if (preparedData.empty()) { -		throw std::exception(); -	} -	return std::string(vecptr(preparedData)); -} - -SafeByteArray StringPrep::getPrepared(const SafeByteArray& s, Profile profile) { -	std::vector<char, SafeAllocator<char> > preparedData = getStringPrepared<SafeByteArray, std::vector<char, SafeAllocator<char> > >(s, profile); -	if (preparedData.empty()) { -		throw std::exception(); -	} -	return createSafeByteArray(reinterpret_cast<const char*>(vecptr(preparedData))); -} - -} - -#endif - diff --git a/Swiften/IDN/UnitTest/IDNATest.cpp b/Swiften/IDN/UnitTest/IDNATest.cpp deleted file mode 100644 index 09e79c8..0000000 --- a/Swiften/IDN/UnitTest/IDNATest.cpp +++ /dev/null @@ -1,35 +0,0 @@ -/* - * Copyright (c) 2012 Remko Tronçon - * Licensed under the GNU General Public License v3. - * See Documentation/Licenses/GPLv3.txt for more information. - */ - -#include <cppunit/extensions/HelperMacros.h> -#include <cppunit/extensions/TestFactoryRegistry.h> - -#include <Swiften/IDN/IDNA.h> - -using namespace Swift; - -class IDNATest : public CppUnit::TestFixture { -		CPPUNIT_TEST_SUITE(IDNATest); -		CPPUNIT_TEST(testGetEncoded); -		CPPUNIT_TEST(testGetEncoded_International); -		CPPUNIT_TEST_SUITE_END(); - -	public: -		void testGetEncoded() { -			std::string result = IDNA::getEncoded("www.swift.im"); - -			CPPUNIT_ASSERT_EQUAL(std::string("www.swift.im"), result); -		} - -		void testGetEncoded_International() { -			std::string result = IDNA::getEncoded("www.tron\xc3\x87on.com"); - -			CPPUNIT_ASSERT_EQUAL(std::string("www.xn--tronon-zua.com"), result); -		} -}; - -CPPUNIT_TEST_SUITE_REGISTRATION(IDNATest); - diff --git a/Swiften/IDN/UnitTest/IDNConverterTest.cpp b/Swiften/IDN/UnitTest/IDNConverterTest.cpp new file mode 100644 index 0000000..285cf4b --- /dev/null +++ b/Swiften/IDN/UnitTest/IDNConverterTest.cpp @@ -0,0 +1,56 @@ +/* + * Copyright (c) 2010 Remko Tronçon + * Licensed under the GNU General Public License v3. + * See Documentation/Licenses/GPLv3.txt for more information. + */ + +#include <cppunit/extensions/HelperMacros.h> +#include <cppunit/extensions/TestFactoryRegistry.h> + +#include <boost/shared_ptr.hpp> +#include <Swiften/IDN/IDNConverter.h> +#include <Swiften/IDN/PlatformIDNConverter.h> + +using namespace Swift; + +class IDNConverterTest : public CppUnit::TestFixture { +		CPPUNIT_TEST_SUITE(IDNConverterTest); +		CPPUNIT_TEST(testStringPrep); +		CPPUNIT_TEST(testStringPrep_Empty); +		CPPUNIT_TEST(testGetEncoded); +		CPPUNIT_TEST(testGetEncoded_International); +		CPPUNIT_TEST_SUITE_END(); + +	public: +		void setUp() { +			testling = boost::shared_ptr<IDNConverter>(PlatformIDNConverter::create()); +		} + +		void testStringPrep() { +			std::string result = testling->getStringPrepared("tron\xc3\x87on", IDNConverter::NamePrep); + +			CPPUNIT_ASSERT_EQUAL(std::string("tron\xc3\xa7on"), result); +		} + +		void testStringPrep_Empty() { +			CPPUNIT_ASSERT_EQUAL(std::string(""), testling->getStringPrepared("", IDNConverter::NamePrep)); +			CPPUNIT_ASSERT_EQUAL(std::string(""), testling->getStringPrepared("", IDNConverter::XMPPNodePrep)); +			CPPUNIT_ASSERT_EQUAL(std::string(""), testling->getStringPrepared("", IDNConverter::XMPPResourcePrep)); +		} + +		void testGetEncoded() { +			std::string result = testling->getIDNAEncoded("www.swift.im"); +			CPPUNIT_ASSERT_EQUAL(std::string("www.swift.im"), result); +		} + +		void testGetEncoded_International() { +			std::string result = testling->getIDNAEncoded("www.tron\xc3\x87on.com"); +			CPPUNIT_ASSERT_EQUAL(std::string("www.xn--tronon-zua.com"), result);  +		} + + +	private: +		boost::shared_ptr<IDNConverter> testling; +}; + +CPPUNIT_TEST_SUITE_REGISTRATION(IDNConverterTest); diff --git a/Swiften/IDN/UnitTest/StringPrepTest.cpp b/Swiften/IDN/UnitTest/StringPrepTest.cpp deleted file mode 100644 index beab01e..0000000 --- a/Swiften/IDN/UnitTest/StringPrepTest.cpp +++ /dev/null @@ -1,34 +0,0 @@ -/* - * Copyright (c) 2010 Remko Tronçon - * Licensed under the GNU General Public License v3. - * See Documentation/Licenses/GPLv3.txt for more information. - */ - -#include <cppunit/extensions/HelperMacros.h> -#include <cppunit/extensions/TestFactoryRegistry.h> - -#include "Swiften/IDN/StringPrep.h" - -using namespace Swift; - -class StringPrepTest : public CppUnit::TestFixture { -		CPPUNIT_TEST_SUITE(StringPrepTest); -		CPPUNIT_TEST(testStringPrep); -		CPPUNIT_TEST(testStringPrep_Empty); -		CPPUNIT_TEST_SUITE_END(); - -	public: -		void testStringPrep() { -			std::string result = StringPrep::getPrepared("tron\xc3\x87on", StringPrep::NamePrep); - -			CPPUNIT_ASSERT_EQUAL(std::string("tron\xc3\xa7on"), result); -		} - -		void testStringPrep_Empty() { -			CPPUNIT_ASSERT_EQUAL(std::string(""), StringPrep::getPrepared("", StringPrep::NamePrep)); -			CPPUNIT_ASSERT_EQUAL(std::string(""), StringPrep::getPrepared("", StringPrep::XMPPNodePrep)); -			CPPUNIT_ASSERT_EQUAL(std::string(""), StringPrep::getPrepared("", StringPrep::XMPPResourcePrep)); -		} -}; - -CPPUNIT_TEST_SUITE_REGISTRATION(StringPrepTest);  | 
 Swift