# Copyright (c) 2014 The Chromium OS Authors. All rights reserved.
# Use of this source code is governed by a BSD-style license that can be
# found in the LICENSE file.
class FakeHost(object):
"""A fake implementation of a lansim.host.Host object.
This class replaces the real Host class and should be used for unit testing.
"""
def __init__(self, ip_addr):
self.ip_addr = ip_addr
# List of FakeSocket objects returned by socket()
self._sockets = []
def socket(self, family, sock_type):
"""Creates a new FakeSocket and returns it.
@param family: The socket family, for example AF_INET.
@param sock_type: The socket type, for example SOCK_DGRAM.
@return: a FakeSocket object.
"""
sock = FakeSocket(self, family, sock_type)
self._sockets.append(sock)
return sock
class FakeSocket(object):
"""A fake socket interface implementation.
This class implements a fake socket object as returned by the Host.socket()
method.
"""
def __init__(self, host, family, sock_type):
self._host = host
self._family = family
self._sock_type = sock_type
self._bound = False
def listen(self, ip_addr, port, recv_callback):
"""Bind and listen on the ip_addr:port.
The fake implementation only stores these value as members of the
FakeSocket to allow the test inspect those values.
@param ip_addr: Local destination ip_addr.
@param port: Local destination port number.
@param recv_callback: A callback function that accepts three
arguments, the received string, the sender IPv4 address and the
sender port number.
"""
self._bound = True
self._bind_ip_addr = ip_addr
self._bind_port = port
self._bind_recv_callback = recv_callback