]> git.saurik.com Git - wxWidgets.git/blobdiff - tests/net/socket.cpp
insert missing iclude file
[wxWidgets.git] / tests / net / socket.cpp
index e571a566bfa446e3ee230ffa6a43ae28ebf7771a..c0eb7e8fe945e733f47be547b4b4bdc4080f039a 100644 (file)
@@ -26,6 +26,8 @@
 #if wxUSE_SOCKETS
 
 #include "wx/socket.h"
+#include "wx/url.h"
+#include "wx/sstream.h"
 #include "wx/evtloop.h"
 #include <memory>
 
@@ -48,7 +50,8 @@ private:
         CPPUNIT_TEST( ReadNormal ); \
         CPPUNIT_TEST( ReadBlock ); \
         CPPUNIT_TEST( ReadNowait ); \
-        CPPUNIT_TEST( ReadWaitall )
+        CPPUNIT_TEST( ReadWaitall ); \
+        CPPUNIT_TEST( UrlTest )
 
     CPPUNIT_TEST_SUITE( SocketTestCase );
         ALL_SOCKET_TESTS();
@@ -95,6 +98,8 @@ private:
     void ReadNowait();
     void ReadWaitall();
 
+    void UrlTest();
+
     static bool ms_useLoop;
 
     DECLARE_NO_COPY_CLASS(SocketTestCase)
@@ -233,4 +238,20 @@ void SocketTestCase::ReadWaitall()
     CPPUNIT_ASSERT_EQUAL( WXSIZEOF(buf), sock->LastCount() );
 }
 
+void SocketTestCase::UrlTest()
+{
+    if ( gs_serverHost.empty() )
+        return;
+
+    SocketTestEventLoop loop(ms_useLoop);
+
+    wxURL url("http://" + gs_serverHost);
+
+    const std::auto_ptr<wxInputStream> in(url.GetInputStream());
+    CPPUNIT_ASSERT( in.get() );
+
+    wxStringOutputStream out;
+    CPPUNIT_ASSERT_EQUAL( wxSTREAM_EOF, in->Read(out).GetLastError() );
+}
+
 #endif // wxUSE_SOCKETS