Home | History | Annotate | Download | only in websockets
      1 // Copyright 2013 The Chromium Authors. All rights reserved.
      2 // Use of this source code is governed by a BSD-style license that can be
      3 // found in the LICENSE file.
      4 
      5 #ifndef NET_WEBSOCKETS_WEBSOCKET_TEST_UTIL_H_
      6 #define NET_WEBSOCKETS_WEBSOCKET_TEST_UTIL_H_
      7 
      8 #include <string>
      9 
     10 #include "base/basictypes.h"
     11 #include "base/memory/scoped_ptr.h"
     12 #include "net/url_request/url_request_test_util.h"
     13 #include "net/websockets/websocket_stream.h"
     14 
     15 class GURL;
     16 
     17 namespace base {
     18 class Timer;
     19 }  // namespace base
     20 
     21 namespace url {
     22 class Origin;
     23 }  // namespace url
     24 
     25 namespace net {
     26 
     27 class BoundNetLog;
     28 class DeterministicMockClientSocketFactory;
     29 class DeterministicSocketData;
     30 class URLRequestContext;
     31 class WebSocketHandshakeStreamCreateHelper;
     32 struct SSLSocketDataProvider;
     33 
     34 class LinearCongruentialGenerator {
     35  public:
     36   explicit LinearCongruentialGenerator(uint32 seed);
     37   uint32 Generate();
     38 
     39  private:
     40   uint64 current_;
     41 };
     42 
     43 // Alternate version of WebSocketStream::CreateAndConnectStream() for testing
     44 // use only. The differences are the use of a |create_helper| argument in place
     45 // of |requested_subprotocols| and taking |timer| as the handshake timeout
     46 // timer. Implemented in websocket_stream.cc.
     47 NET_EXPORT_PRIVATE extern scoped_ptr<WebSocketStreamRequest>
     48     CreateAndConnectStreamForTesting(
     49         const GURL& socket_url,
     50         scoped_ptr<WebSocketHandshakeStreamCreateHelper> create_helper,
     51         const url::Origin& origin,
     52         URLRequestContext* url_request_context,
     53         const BoundNetLog& net_log,
     54         scoped_ptr<WebSocketStream::ConnectDelegate> connect_delegate,
     55         scoped_ptr<base::Timer> timer);
     56 
     57 // Generates a standard WebSocket handshake request. The challenge key used is
     58 // "dGhlIHNhbXBsZSBub25jZQ==". Each header in |extra_headers| must be terminated
     59 // with "\r\n".
     60 extern std::string WebSocketStandardRequest(const std::string& path,
     61                                             const std::string& origin,
     62                                             const std::string& extra_headers);
     63 
     64 // A response with the appropriate accept header to match the above challenge
     65 // key. Each header in |extra_headers| must be terminated with "\r\n".
     66 extern std::string WebSocketStandardResponse(const std::string& extra_headers);
     67 
     68 // This class provides a convenient way to construct a
     69 // DeterministicMockClientSocketFactory for WebSocket tests.
     70 class WebSocketDeterministicMockClientSocketFactoryMaker {
     71  public:
     72   WebSocketDeterministicMockClientSocketFactoryMaker();
     73   ~WebSocketDeterministicMockClientSocketFactoryMaker();
     74 
     75   // Tell the factory to create a socket which expects |expect_written| to be
     76   // written, and responds with |return_to_read|. The test will fail if the
     77   // expected text is not written, or all the bytes are not read. This adds data
     78   // for a new mock-socket using AddRawExpections(), and so can be called
     79   // multiple times to queue up multiple mock sockets, but usually in those
     80   // cases the lower-level AddRawExpections() interface is more appropriate.
     81   void SetExpectations(const std::string& expect_written,
     82                        const std::string& return_to_read);
     83 
     84   // A low-level interface to permit arbitrary expectations to be added. The
     85   // mock sockets will be created in the same order that they were added.
     86   void AddRawExpectations(scoped_ptr<DeterministicSocketData> socket_data);
     87 
     88   // Allow an SSL socket data provider to be added. You must also supply a mock
     89   // transport socket for it to use. If the mock SSL handshake fails then the
     90   // mock transport socket will connect but have nothing read or written. If the
     91   // mock handshake succeeds then the data from the underlying transport socket
     92   // will be passed through unchanged (without encryption).
     93   void AddSSLSocketDataProvider(
     94       scoped_ptr<SSLSocketDataProvider> ssl_socket_data);
     95 
     96   // Call to get a pointer to the factory, which remains owned by this object.
     97   DeterministicMockClientSocketFactory* factory();
     98 
     99  private:
    100   struct Detail;
    101   scoped_ptr<Detail> detail_;
    102 
    103   DISALLOW_COPY_AND_ASSIGN(WebSocketDeterministicMockClientSocketFactoryMaker);
    104 };
    105 
    106 // This class encapsulates the details of creating a
    107 // TestURLRequestContext that returns mock ClientSocketHandles that do what is
    108 // required by the tests.
    109 struct WebSocketTestURLRequestContextHost {
    110  public:
    111   WebSocketTestURLRequestContextHost();
    112   ~WebSocketTestURLRequestContextHost();
    113 
    114   void SetExpectations(const std::string& expect_written,
    115                        const std::string& return_to_read) {
    116     maker_.SetExpectations(expect_written, return_to_read);
    117   }
    118 
    119   void AddRawExpectations(scoped_ptr<DeterministicSocketData> socket_data);
    120 
    121   // Allow an SSL socket data provider to be added.
    122   void AddSSLSocketDataProvider(
    123       scoped_ptr<SSLSocketDataProvider> ssl_socket_data);
    124 
    125   // Call after calling one of SetExpections() or AddRawExpectations(). The
    126   // returned pointer remains owned by this object.
    127   TestURLRequestContext* GetURLRequestContext();
    128 
    129  private:
    130   WebSocketDeterministicMockClientSocketFactoryMaker maker_;
    131   TestURLRequestContext url_request_context_;
    132   TestNetworkDelegate network_delegate_;
    133   bool url_request_context_initialized_;
    134 
    135   DISALLOW_COPY_AND_ASSIGN(WebSocketTestURLRequestContextHost);
    136 };
    137 
    138 }  // namespace net
    139 
    140 #endif  // NET_WEBSOCKETS_WEBSOCKET_TEST_UTIL_H_
    141