Ejemplo n.º 1
0
def test_telephone_bill_reduced_tariff():
    subscriber = '1132547698'

    CallRecord.objects.bulk_create([
        CallRecord(type=CallRecord.START,
                   call_id=3,
                   timestamp=tzdatetime(2018, 1, 5, 23, 2),
                   source=subscriber,
                   destination='2133445566'),
        CallRecord(type=CallRecord.END,
                   call_id=3,
                   timestamp=tzdatetime(2018, 1, 5, 23, 57)),
    ])

    bill = telephone_bill(subscriber, reference_period='201801')

    assert bill == {
        'subscriber':
        subscriber,
        'reference_period':
        '201801',
        'call_records': [
            {
                'destination': '2133445566',
                'start_date': '2018-01-05',
                'start_time': '23:02:00Z',
                'duration': '55m',
                'price': 'R$ 0,36'
            },
        ]
    }
Ejemplo n.º 2
0
def test_telephone_bill_call_finished_beginning_month_must_be_added():
    # For a given reference period, any calls that have STARTED
    # on the past month and ENDED in the current month
    # MUST be added
    subscriber = '1132547698'

    CallRecord.objects.bulk_create([
        # A few _complete_ pairs that _should_ be on the bill
        CallRecord(type=CallRecord.START,
                   call_id=1,
                   timestamp=tzdatetime(2018, 1, 30, 23, 2),
                   source=subscriber,
                   destination='21987654321'),
        CallRecord(type=CallRecord.END,
                   call_id=1,
                   timestamp=tzdatetime(2018, 2, 1, 2, 24)),
    ])

    bill = telephone_bill(subscriber, reference_period='201802')

    assert bill == {
        'subscriber':
        subscriber,
        'reference_period':
        '201802',
        'call_records': [
            {
                'destination': '21987654321',
                'start_date': '2018-01-30',
                'start_time': '23:02:00Z',
                'duration': '3h22m',
                'price': 'R$ 0,36'
            },
        ]
    }
Ejemplo n.º 3
0
def test_telephone_bill_standard_tariff():
    subscriber = '1132547698'

    CallRecord.objects.bulk_create([
        CallRecord(type=CallRecord.START,
                   call_id=1,
                   timestamp=tzdatetime(2018, 1, 1, 10, 0),
                   source=subscriber,
                   destination='21987654321'),
        CallRecord(type=CallRecord.END,
                   call_id=1,
                   timestamp=tzdatetime(2018, 1, 1, 10, 2)),
    ])

    bill = telephone_bill(subscriber, reference_period='201801')

    assert bill == {
        'subscriber':
        subscriber,
        'reference_period':
        '201801',
        'call_records': [
            {
                'destination': '21987654321',
                'start_date': '2018-01-01',
                'start_time': '10:00:00Z',
                'duration': '2m',
                'price': 'R$ 0,54'
            },
        ]
    }
Ejemplo n.º 4
0
def test_get_call_records(client):
    records = CallRecord.objects.bulk_create([
        CallRecord(type=CallRecord.START,
                   call_id=12,
                   timestamp=tzdatetime(2018, 1, 1),
                   source='2199998888',
                   destination='2199997777'),
        CallRecord(type=CallRecord.START,
                   call_id=21,
                   timestamp=tzdatetime(2018, 1, 2),
                   source='2199998888',
                   destination='2199997777'),
        CallRecord(type=CallRecord.START,
                   call_id=32,
                   timestamp=tzdatetime(2018, 1, 3),
                   source='2199998888',
                   destination='2199997777'),
        CallRecord(type=CallRecord.END,
                   call_id=21,
                   timestamp=tzdatetime(2018, 1, 4)),
        CallRecord(type=CallRecord.END,
                   call_id=32,
                   timestamp=tzdatetime(2018, 1, 5)),
    ])

    response = client.get(reverse('call_records:index'))

    assert (sorted(json.loads(response.content),
                   key=itemgetter('timestamp')) == sorted(
                       records_to_json(records), key=itemgetter('timestamp')))
Ejemplo n.º 5
0
    def post(self, request, *args, **kwargs):
        if not CallRecord.is_record_type(request.data.get('type')):
            return Response({'type': ['Only "start" or "end" are allowed']},
                            status=status.HTTP_400_BAD_REQUEST)

        try:
            return super().post(request, *args, **kwargs)
        except IntegrityError:
            return Response({'detail': 'Call record already exists'},
                            status=status.HTTP_409_CONFLICT)
Ejemplo n.º 6
0
def test_telephone_bill_call_finished_next_month_must_be_excluded():
    # For a given reference period, any calls that have ENDED
    # in the next month MUST NOT be added
    subscriber = '1132547698'

    CallRecord.objects.bulk_create([
        # A few _complete_ pairs that _should_ be on the bill
        CallRecord(type=CallRecord.START,
                   call_id=1,
                   timestamp=tzdatetime(2018, 1, 30, 23, 2),
                   source=subscriber,
                   destination='21987654321'),
        CallRecord(type=CallRecord.END,
                   call_id=1,
                   timestamp=tzdatetime(2018, 2, 1, 2, 24)),
    ])

    bill = telephone_bill(subscriber, reference_period='201801')

    assert bill == {
        'subscriber': subscriber,
        'reference_period': '201801',
        'call_records': []
    }
Ejemplo n.º 7
0
def test_get_telephone_bill_no_reference_period_uses_last_month():
    subscriber = '1132547698'

    CallRecord.objects.bulk_create([
        # Since these are too old (bill is supposed to infer 201802),
        # they SHOULD NOT be added to the bill
        CallRecord(type=CallRecord.START,
                   call_id=11,
                   timestamp=tzdatetime(2018, 1, 1, 10, 0),
                   source=subscriber,
                   destination='21987654321'),
        CallRecord(type=CallRecord.END,
                   call_id=11,
                   timestamp=tzdatetime(2018, 1, 1, 10, 2)),
        CallRecord(type=CallRecord.START,
                   call_id=12,
                   timestamp=tzdatetime(2018, 1, 2, 7, 35),
                   source=subscriber,
                   destination='2133445566'),
        CallRecord(type=CallRecord.END,
                   call_id=12,
                   timestamp=tzdatetime(2018, 1, 2, 8, 2)),

        # These are pairs from the previous month
        CallRecord(type=CallRecord.START,
                   call_id=1,
                   timestamp=tzdatetime(2018, 2, 1, 10, 0),
                   source=subscriber,
                   destination='21987654321'),
        CallRecord(type=CallRecord.END,
                   call_id=1,
                   timestamp=tzdatetime(2018, 2, 1, 10, 2)),
        CallRecord(type=CallRecord.START,
                   call_id=2,
                   timestamp=tzdatetime(2018, 2, 2, 7, 35),
                   source=subscriber,
                   destination='2133445566'),
        CallRecord(type=CallRecord.END,
                   call_id=2,
                   timestamp=tzdatetime(2018, 2, 2, 8, 2)),
        CallRecord(type=CallRecord.START,
                   call_id=3,
                   timestamp=tzdatetime(2018, 2, 5, 23, 2),
                   source=subscriber,
                   destination='2133445566'),
        CallRecord(type=CallRecord.END,
                   call_id=3,
                   timestamp=tzdatetime(2018, 2, 5, 23, 57)),

        # These belong to the current month and SHOULD NOT be added as well
        CallRecord(type=CallRecord.START,
                   call_id=22,
                   timestamp=tzdatetime(2018, 3, 2, 7, 35),
                   source=subscriber,
                   destination='2133445566'),
        CallRecord(type=CallRecord.END,
                   call_id=22,
                   timestamp=tzdatetime(2018, 3, 2, 8, 2)),
        CallRecord(type=CallRecord.START,
                   call_id=23,
                   timestamp=tzdatetime(2018, 3, 5, 23, 2),
                   source=subscriber,
                   destination='2133445566'),
        CallRecord(type=CallRecord.END,
                   call_id=23,
                   timestamp=tzdatetime(2018, 3, 5, 23, 57)),
    ])

    bill = telephone_bill(subscriber, reference_period=None)

    assert bill == {
        'subscriber':
        subscriber,
        'reference_period':
        '201802',
        'call_records': [
            {
                'destination': '21987654321',
                'start_date': '2018-02-01',
                'start_time': '10:00:00Z',
                'duration': '2m',
                'price': 'R$ 0,54'
            },
            {
                'destination': '2133445566',
                'start_date': '2018-02-02',
                'start_time': '07:35:00Z',
                'duration': '27m',
                'price': 'R$ 2,79'
            },

            # This one is on reduced tariff
            {
                'destination': '2133445566',
                'start_date': '2018-02-05',
                'start_time': '23:02:00Z',
                'duration': '55m',
                'price': 'R$ 0,36'
            },
        ]
    }
Ejemplo n.º 8
0
def test_telephone_bill_within_reference_period():
    subscriber = '1132547698'

    CallRecord.objects.bulk_create([
        # A few incomplete pairs that _should_ be ignored
        CallRecord(type=CallRecord.START,
                   call_id=0,
                   timestamp=tzdatetime(2018, 1, 1, 3, 0),
                   source=subscriber,
                   destination='21987654321'),
        CallRecord(type=CallRecord.END,
                   call_id=20,
                   timestamp=tzdatetime(2018, 1, 17, 3, 5)),

        # A few _complete_ pairs that _should_ be on the bill
        CallRecord(type=CallRecord.START,
                   call_id=1,
                   timestamp=tzdatetime(2018, 1, 1, 10, 0),
                   source=subscriber,
                   destination='21987654321'),
        CallRecord(type=CallRecord.END,
                   call_id=1,
                   timestamp=tzdatetime(2018, 1, 1, 10, 2)),
        CallRecord(type=CallRecord.START,
                   call_id=2,
                   timestamp=tzdatetime(2018, 1, 2, 7, 35),
                   source=subscriber,
                   destination='2133445566'),
        CallRecord(type=CallRecord.END,
                   call_id=2,
                   timestamp=tzdatetime(2018, 1, 2, 8, 2)),
        CallRecord(type=CallRecord.START,
                   call_id=3,
                   timestamp=tzdatetime(2018, 1, 5, 23, 2),
                   source=subscriber,
                   destination='2133445566'),
        CallRecord(type=CallRecord.END,
                   call_id=3,
                   timestamp=tzdatetime(2018, 1, 5, 23, 57)),

        # A few call records that belong to another source
        # that also _should_ be ignored
        CallRecord(type=CallRecord.START,
                   call_id=17,
                   timestamp=tzdatetime(2018, 1, 5, 23, 2),
                   source='2798765432',
                   destination='2133445566'),
        CallRecord(type=CallRecord.END,
                   call_id=17,
                   timestamp=tzdatetime(2018, 1, 5, 23, 57)),
        CallRecord(type=CallRecord.START,
                   call_id=18,
                   timestamp=tzdatetime(2018, 1, 6, 17, 27),
                   source='2798765432',
                   destination='2133445566'),
        CallRecord(type=CallRecord.END,
                   call_id=29,
                   timestamp=tzdatetime(2018, 1, 21, 20, 20)),
    ])

    bill = telephone_bill(subscriber, reference_period='201801')

    assert bill == {
        'subscriber':
        subscriber,
        'reference_period':
        '201801',
        'call_records': [
            {
                'destination': '21987654321',
                'start_date': '2018-01-01',
                'start_time': '10:00:00Z',
                'duration': '2m',
                'price': 'R$ 0,54'
            },
            {
                'destination': '2133445566',
                'start_date': '2018-01-02',
                'start_time': '07:35:00Z',
                'duration': '27m',
                'price': 'R$ 2,79'
            },

            # This one is on reduced tariff
            {
                'destination': '2133445566',
                'start_date': '2018-01-05',
                'start_time': '23:02:00Z',
                'duration': '55m',
                'price': 'R$ 0,36'
            },
        ]
    }
Ejemplo n.º 9
0
def test_get_telephone_bill(client, reference_period):
    subscriber = '1198761234'
    CallRecord.objects.bulk_create([
        CallRecord(type=CallRecord.START,
                   call_id=12,
                   timestamp=tzdatetime(2018, 1, 1, 10),
                   source=subscriber,
                   destination='2199997777'),
        CallRecord(type=CallRecord.END,
                   call_id=12,
                   timestamp=tzdatetime(2018, 1, 1, 11)),
        CallRecord(type=CallRecord.START,
                   call_id=21,
                   timestamp=tzdatetime(2018, 1, 2, 11),
                   source=subscriber,
                   destination='2199997777'),
        CallRecord(type=CallRecord.END,
                   call_id=21,
                   timestamp=tzdatetime(2018, 1, 2, 12)),
        CallRecord(type=CallRecord.START,
                   call_id=32,
                   timestamp=tzdatetime(2018, 1, 3, 12),
                   source=subscriber,
                   destination='2199997777'),
        CallRecord(type=CallRecord.END,
                   call_id=32,
                   timestamp=tzdatetime(2018, 1, 3, 14)),
    ])

    response = client.get(reverse('call_records:telephone_bill'),
                          data={
                              'subscriber': subscriber,
                              'reference_period': '201801'
                          })

    assert response.status_code == status.HTTP_200_OK
    assert json.loads(response.content) == {
        'subscriber':
        subscriber,
        'reference_period':
        '201801',
        'call_records': [{
            'destination': '2199997777',
            'duration': '1h',
            'price': 'R$ 5,76',
            'start_date': '2018-01-01',
            'start_time': '10:00:00Z'
        }, {
            'destination': '2199997777',
            'duration': '1h',
            'price': 'R$ 5,76',
            'start_date': '2018-01-02',
            'start_time': '11:00:00Z'
        }, {
            'destination': '2199997777',
            'duration': '2h',
            'price': 'R$ 11,16',
            'start_date': '2018-01-03',
            'start_time': '12:00:00Z'
        }]
    }