tari_comms 5.4.0-pre.0

A peer-to-peer messaging system
Documentation
//  Copyright 2019 The Tari Project
//
//  Redistribution and use in source and binary forms, with or without modification, are permitted provided that the
//  following conditions are met:
//
//  1. Redistributions of source code must retain the above copyright notice, this list of conditions and the following
//  disclaimer.
//
//  2. Redistributions in binary form must reproduce the above copyright notice, this list of conditions and the
//  following disclaimer in the documentation and/or other materials provided with the distribution.
//
//  3. Neither the name of the copyright holder nor the names of its contributors may be used to endorse or promote
//  products derived from this software without specific prior written permission.
//
//  THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES,
//  INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
//  DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
//  SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
//  SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
//  WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE
//  USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.

use std::iter::repeat_with;

use multiaddr::Multiaddr;

use super::{TestFactory, TestFactoryError};
use crate::transports::MemoryTransport;

pub fn create_many(n: usize) -> NetAddressesFactory {
    NetAddressesFactory::default().with_count(n)
}

pub fn create() -> NetAddressFactory {
    NetAddressFactory::default()
}

#[derive(Default, Clone)]
pub struct NetAddressesFactory {
    count: Option<usize>,
    net_address_factory: NetAddressFactory,
}

impl NetAddressesFactory {
    factory_setter!(with_count, count, Option<usize>);

    factory_setter!(with_net_address_factory, net_address_factory, NetAddressFactory);

    fn make_one(&self) -> Multiaddr {
        self.net_address_factory.clone().build().unwrap()
    }
}

impl TestFactory for NetAddressesFactory {
    type Object = Vec<Multiaddr>;

    fn build(self) -> Result<Self::Object, TestFactoryError> {
        Ok(repeat_with(|| self.make_one()).take(self.count.unwrap_or(1)).collect())
    }
}

//---------------------------------- NetAddressFactory --------------------------------------------//

#[derive(Clone, Default)]
pub struct NetAddressFactory {
    port: Option<u16>,
    is_use_os_port: bool,
}

impl NetAddressFactory {
    factory_setter!(with_port, port, Option<u16>);

    pub fn use_os_port(mut self) -> Self {
        self.is_use_os_port = true;
        self
    }
}

impl TestFactory for NetAddressFactory {
    type Object = Multiaddr;

    fn build(self) -> Result<Self::Object, TestFactoryError> {
        let port = self.port.unwrap_or_else(|| {
            if self.is_use_os_port {
                0
            } else {
                MemoryTransport::acquire_next_memsocket_port().get()
            }
        });

        format!("/memory/{port}")
            .parse()
            .map_err(TestFactoryError::build_failed())
    }
}