Skip to content
Snippets Groups Projects
test_outputport.py 2.45 KiB
Newer Older
  • Learn to ignore specific revisions
  • """
    B-ASIC test suite for OutputPort.
    """
    from b_asic import OutputPort, InputPort, Signal
    import pytest
    
    @pytest.fixture
    def output_port():
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
        return OutputPort(None, 0)
    
    
    @pytest.fixture
    def input_port():
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
        return InputPort(None, 0)
    
    
    @pytest.fixture
    def list_of_input_ports():
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
        return [InputPort(None, i) for i in range(0, 3)]
    
    
    class TestConnect:
        def test_multiple_ports(self, output_port, list_of_input_ports):
            """Can multiple ports connect to an output port?"""
            for port in list_of_input_ports:
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
                port.connect(output_port)
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
            assert output_port.signal_count == len(list_of_input_ports)
    
    
        def test_same_port(self, output_port, list_of_input_ports):
            """Check error handing."""
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
            list_of_input_ports[0].connect(output_port)
            with pytest.raises(Exception):
                list_of_input_ports[0].connect(output_port)
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
            assert output_port.signal_count == 1
    
    
    class TestAddSignal:
        def test_dangling(self, output_port):
            s = Signal()
            output_port.add_signal(s)
    
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
            assert output_port.signal_count == 1
            assert output_port.signals == [s]
    
    
    class TestDisconnect:
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
        def test_others_clear(self, output_port, list_of_input_ports):
    
            """Can multiple ports disconnect from OutputPort?"""
            for port in list_of_input_ports:
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
                port.connect(output_port)
    
    
            for port in list_of_input_ports:
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
                port.clear()
    
            assert output_port.signal_count == 3
            assert all(s.dangling() for s in output_port.signals)
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
        def test_self_clear(self, output_port, list_of_input_ports):
            """Can an OutputPort disconnect from multiple ports?"""
            for port in list_of_input_ports:
                port.connect(output_port)
    
            output_port.clear()
    
            assert output_port.signal_count == 0
            assert output_port.signals == []
    
    
    class TestRemoveSignal:
        def test_one_signal(self, output_port, input_port):
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
            s = input_port.connect(output_port)
    
            output_port.remove_signal(s)
    
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
            assert output_port.signal_count == 0
    
            assert output_port.signals == []
    
        def test_multiple_signals(self, output_port, list_of_input_ports):
            """Can multiple signals disconnect from OutputPort?"""
            sigs = []
    
            for port in list_of_input_ports:
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
                sigs.append(port.connect(output_port))
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
            for s in sigs:
                output_port.remove_signal(s)
    
    Ivar Härnqvist's avatar
    Ivar Härnqvist committed
            assert output_port.signal_count == 0
    
            assert output_port.signals == []