# 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