def test_no_exchange():
    """Test a hypothetical contest with no exchange."""
    assert parse_qso('7005 CW 2009-05-30 0002 AA1ZZZ 599 S50A 599')

    # Test transmitter ID.
    qso = parse_qso('7005 CW 2009-05-30 0002 AA1ZZZ 599 S50A 599 1')
    assert qso.t == 1
def test_cqwpx_malformed():
    """Test a CQ WPX QSO in the SINGLE category with malformed exchange."""
    # Uneven exchange.
    with pytest.raises(InvalidQSOException) as _:
        parse_qso('7005 CW 2009-05-30 0002 AA1ZZZ 599 CT 001 S50A 599 004')

    # Invalid transmitter ID when uneven.
    with pytest.raises(InvalidQSOException) as _:
        parse_qso('7005 CW 2009-05-30 0002 AA1ZZZ 599 CT 001 S50A 599 3')
def test_cqwpx_single():
    """Test a CQ WPX QSO in the SINGLE transmitter category."""
    qso = parse_qso('7005 CW 2009-05-30 0002 AA1ZZZ 599 1 S50A 599 4')
    assert qso.freq == '7005'
    assert qso.mo == 'CW'
    assert qso.date == datetime.strptime('200905300002', '%Y%m%d%H%M')
    assert qso.de_call == 'AA1ZZZ'
    assert qso.de_exch == ['599', '1']
    assert qso.dx_call == 'S50A'
    assert qso.dx_exch == ['599', '4']
    assert qso.t is None
def test_yarc_qso():
    """Test the YARC QSO Party which has multiple exchanges."""
    line = '14000 PH 2018-12-01 1640 W4Y  16 VA     W2Y        19 NY'
    qso = parse_qso(line)
    assert qso.freq == '14000'
    assert qso.mo == 'PH'
    assert qso.date == datetime.strptime('201812011640', '%Y%m%d%H%M')
    assert qso.de_call == 'W4Y'
    assert qso.de_exch == ['16', 'VA']
    assert qso.dx_call == 'W2Y'
    assert qso.dx_exch == ['19', 'NY']
    assert qso.t is None
def test_cqwpx_two():
    """Test a CQ WPX QSO in the TWO transmitter category with transmitter
    ID designation in each QSO.
    """
    line = '3799 PH 1999-03-06 0711 HC8N          ' \
           '59  001    W1AW 59  001    0'
    qso = parse_qso(line)
    assert qso.freq == '3799'
    assert qso.mo == 'PH'
    assert qso.date == datetime.strptime('199903060711', '%Y%m%d%H%M')
    assert qso.de_call == 'HC8N'
    assert qso.de_exch == ['59', '001']
    assert qso.dx_call == 'W1AW'
    assert qso.dx_exch == ['59', '001']
    assert qso.t == 0
def test_invalid_qso():
    """Test a QSO line that is far too short."""
    with pytest.raises(InvalidQSOException) as _:
        parse_qso('7005 CW 2009-05-30 1230 S50A')