Exemplo n.º 1
0
def test_multiple_success(create_input):
    message_senddm_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], "This is the first normal message")
    assert len(dm_messages_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], 0)["messages"]) == 1
    current_time = int(time.time())
    msg = message_sendlaterdm_v1(create_input[0][1]["token"], create_input[1][0]["dm_id"], "Hey there, I'm from the past!", current_time + 2)
    assert type(msg) == dict
    assert type(msg["message_id"]) == int
    msg = message_sendlaterdm_v1(create_input[0][2]["token"], create_input[1][0]["dm_id"], "Hey, I'm from the distant past!", current_time + 4)
    assert type(msg) == dict
    assert type(msg["message_id"]) == int
    msg = message_sendlaterdm_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], "Hey there, I'm from the past past!!", current_time + 3)
    assert type(msg) == dict
    assert type(msg["message_id"]) == int
    message_senddm_v1(create_input[0][2]["token"], create_input[1][0]["dm_id"], "This is the second normal message")

    # Make sure delayed message has not been sent yet
    assert len(dm_messages_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], 0)["messages"]) == 2

    # Wait 2.5 seconds and check again; first delayed message should be there
    time.sleep(2.5)
    msgs = dm_messages_v1(create_input[0][1]["token"], create_input[1][0]["dm_id"], 0)["messages"]
    assert len(msgs) == 3
    assert msgs[0]["message"] == "Hey there, I'm from the past!"
    assert msgs[0]["time_created"] == current_time + 2
    assert msgs[1]["message"] == "This is the second normal message"
    assert msgs[1]["time_created"] == current_time
    assert msgs[2]["message"] == "This is the first normal message"
    assert msgs[2]["time_created"] == current_time

    # Wait 1 second; second delayed message should be there
    time.sleep(1)
    msgs = dm_messages_v1(create_input[0][1]["token"], create_input[1][0]["dm_id"], 0)["messages"]
    assert len(msgs) == 4
    assert msgs[0]["message"] == "Hey there, I'm from the past past!!"
    assert msgs[0]["time_created"] == current_time + 3
    assert msgs[1]["message"] == "Hey there, I'm from the past!"
    assert msgs[1]["time_created"] == current_time + 2
    assert msgs[2]["message"] == "This is the second normal message"
    assert msgs[2]["time_created"] == current_time
    assert msgs[3]["message"] == "This is the first normal message"
    assert msgs[3]["time_created"] == current_time

    # Wait 1 more second; final delayed message should be there
    time.sleep(1)
    msgs = dm_messages_v1(create_input[0][1]["token"], create_input[1][0]["dm_id"], 0)["messages"]
    assert len(msgs) == 5
    assert msgs[0]["message"] == "Hey, I'm from the distant past!"
    assert msgs[0]["time_created"] == current_time + 4
    assert msgs[1]["message"] == "Hey there, I'm from the past past!!"
    assert msgs[1]["time_created"] == current_time + 3
    assert msgs[2]["message"] == "Hey there, I'm from the past!"
    assert msgs[2]["time_created"] == current_time + 2
    assert msgs[3]["message"] == "This is the second normal message"
    assert msgs[3]["time_created"] == current_time
    assert msgs[4]["message"] == "This is the first normal message"
    assert msgs[4]["time_created"] == current_time
def test_time_past(reg_user, message_text):
    clear_v2()
    user_token = reg_user(0)['token']
    auth_user_id_receiver = reg_user(1)['auth_user_id']
    dm_id = dm_create_v1(user_token, [auth_user_id_receiver])['dm_id']
    message = message_text(0)

    dt = datetime.now(timezone.utc) - timedelta(hours=0, minutes=50)
    time_sent = dt.replace(tzinfo=timezone.utc).timestamp()

    with pytest.raises(InputError):
        message_sendlaterdm_v1(user_token, dm_id, message, time_sent)
Exemplo n.º 3
0
def test_tag_sendlaterdm():
    clear_v1()
    user1 = auth_register_v2("*****@*****.**", "finalpassword", "Eric",
                             "Zheng")
    user2 = auth_register_v2("*****@*****.**", "validpassword", "Josh",
                             "Hatton")
    dm1 = dm_create_v1(user1['token'], [user2['auth_user_id']])
    msg1str = "@joshhatton sup"
    current_time = int(time.time())
    message_sendlaterdm_v1(user1['token'], dm1['dm_id'], msg1str,
                           current_time + 2)
    assert len(notifications_get_v1(user2['token'])['notifications']) == 1
    time.sleep(3)
    assert len(notifications_get_v1(user2['token'])['notifications']) == 2
Exemplo n.º 4
0
def test_message_sendlaterdm_invalid_dm_id():
    # Test if InputError is raised when given invalid dm id
    clear_v1()
    user = auth_register_v2('*****@*****.**', 'password123', 'Terry', 'Wills')
    user2 = auth_register_v2('*****@*****.**', 'password1234', 'Terry',
                             'Lurr')

    dm_create_v1(user['token'], [user2['auth_user_id']])

    time = datetime.now().replace(microsecond=0) + timedelta(0, 3)
    time_sent = time.timestamp()

    with pytest.raises(InputError):
        message_sendlaterdm_v1(user['token'], -1, 'anyone here?', time_sent)
Exemplo n.º 5
0
def test_message_sendlaterdm_invalid_token():
    # Test if AccessError is raised when given invalid token
    clear_v1()
    user = auth_register_v2('*****@*****.**', 'password1234', 'Harry', 'Lurr')
    user2 = auth_register_v2('*****@*****.**', 'password1234', 'Terry',
                             'Lurr')

    dm = dm_create_v1(user['token'], [user2['auth_user_id']])

    time = datetime.now().replace(microsecond=0) + timedelta(0, 3)
    time_sent = time.timestamp()

    with pytest.raises(AccessError):
        message_sendlaterdm_v1(-2382732, dm['dm_id'], 'Poopoo', time_sent)
Exemplo n.º 6
0
def test_message_sendlaterdm_errors(user_setup, dm_setup, channel_setup,
                                    message_setup):
    # invalid token
    with pytest.raises(AccessError):
        message_sendlater_v1(make_token(100000), 0, "hello",
                             datetime.datetime.now().timestamp() + 1)

    # DM ID is not a valid DM
    with pytest.raises(InputError):
        message_sendlaterdm_v1(make_token(2), 20, "hello",
                               datetime.datetime.now().timestamp() + 1)

    # Message is more than 1000 characters
    thousand_string = ''
    for i in range(1005):
        thousand_string += str(i)
    with pytest.raises(InputError):
        message_sendlaterdm_v1(make_token(2), 0, thousand_string,
                               datetime.datetime.now().timestamp() + 1)
    # Time sent is a time in the past
    with pytest.raises(InputError):
        message_sendlaterdm_v1(make_token(2), 0, "hello",
                               datetime.datetime.now().timestamp() - 5)

    # the authorised user is not a member of the DM they are trying to post to
    with pytest.raises(AccessError):
        message_sendlaterdm_v1(make_token(2), 1, "hello",
                               datetime.datetime.now().timestamp() + 1)
Exemplo n.º 7
0
def test_message_sendlaterdm_message_empty():
    # InputError raised if message given is empty
    clear_v1()
    user = auth_register_v2('*****@*****.**', 'pasword24323132', 'Tinker',
                            'Bell')
    user2 = auth_register_v2('*****@*****.**', 'password1234', 'Terry',
                             'Lurr')

    dm = dm_create_v1(user['token'], [user2['auth_user_id']])

    time = datetime.now().replace(microsecond=0) + timedelta(0, 3)
    time_sent = time.timestamp()

    with pytest.raises(InputError):
        message_sendlaterdm_v1(user['token'], dm['dm_id'], '', time_sent)
Exemplo n.º 8
0
def test_message_sendlaterdm_invalid_time_sent():
    # InputError raised if time sent is set to time in the past
    clear_v1()
    user = auth_register_v2('*****@*****.**', 'pasword24323132', 'Johnny',
                            'Silverfinger')
    user2 = auth_register_v2('*****@*****.**', 'password1234', 'Terry',
                             'Lurr')

    dm = dm_create_v1(user['token'], [user2['auth_user_id']])

    time = datetime.now().replace(microsecond=0) - timedelta(0, 3)
    time_sent = time.timestamp()
    with pytest.raises(InputError):
        message_sendlaterdm_v1(user['token'], dm['dm_id'], 'yo guys',
                               time_sent)
Exemplo n.º 9
0
def message_sendlaterdm():
    data = request.get_json()
    token = data["token"]
    dm_id = data["dm_id"]
    message = data["message"]
    time_sent = data["time_sent"]
    return dumps(message_sendlaterdm_v1(token, dm_id, message, time_sent))
Exemplo n.º 10
0
def test_message_sendlaterdm_user_not_in_dm():
    # Test if AccessError is raised when user tries to leave a group
    # that they are not a member of
    clear_v1()
    user_owner = auth_register_v2('*****@*****.**', 'password2321', 'Irwin',
                                  'Dundee')
    user = auth_register_v2('*****@*****.**', 'password2321232', 'Roland',
                            'Tiddle')
    dm = dm_create_v1(user_owner['token'], [])

    time = datetime.now().replace(microsecond=0) + timedelta(0, 3)
    time_sent = time.timestamp()

    with pytest.raises(AccessError):
        message_sendlaterdm_v1(user['token'], dm['dm_id'], 'can i join pls',
                               time_sent)
def test_common(reg_user, message_text):
    clear_v2()
    user_token = reg_user(0)['token']
    auth_user_id_receiver = reg_user(1)['auth_user_id']
    dm_id = dm_create_v1(user_token, [auth_user_id_receiver])['dm_id']

    dt = datetime.now(timezone.utc) + timedelta(hours=0, minutes=1)
    time_sent = dt.replace(tzinfo=timezone.utc).timestamp()

    assert message_sendlaterdm_v1(user_token, dm_id, message_text(0),
                                  time_sent)['message_id'] == 0
    prev_message_id = message_senddm_v1(user_token, dm_id,
                                        message_text(1))['message_id']
    assert message_sendlaterdm_v1(
        user_token, dm_id, message_text(2),
        time_sent)['message_id'] == prev_message_id + 1
def test_sender_non_dm_member(reg_user, message_text):
    clear_v2()

    user_token = reg_user(0)['token']

    auth_user_id_receiver = reg_user(1)['auth_user_id']
    dm_id = dm_create_v1(user_token, [auth_user_id_receiver])['dm_id']

    user_token_1 = reg_user(2)['token']
    message = message_text(0)

    dt = datetime.now(timezone.utc) + timedelta(hours=9, minutes=50)
    time_sent = dt.replace(tzinfo=timezone.utc).timestamp()

    with pytest.raises(AccessError):
        message_sendlaterdm_v1(user_token_1, dm_id, message, time_sent)
Exemplo n.º 13
0
def test_message_sendlater_sendlaterdm(user_setup, dm_setup, channel_setup):
    assert message_sendlater_v1(make_token(2), 0, "Hello",
                                datetime.datetime.now().timestamp() + 1) == {
                                    "message_id": 0
                                }
    assert message_sendlater_v1(make_token(2), 0, "Hi",
                                datetime.datetime.now().timestamp() + 1) == {
                                    "message_id": 1
                                }
    assert message_sendlaterdm_v1(make_token(2), 0, "Hello",
                                  datetime.datetime.now().timestamp() + 1) == {
                                      "message_id": 2
                                  }
    assert message_sendlaterdm_v1(make_token(2), 0, "Hi",
                                  datetime.datetime.now().timestamp() + 1) == {
                                      "message_id": 3
                                  }
Exemplo n.º 14
0
def test_message_sendlaterdm_valid_case():
    clear_v1()
    user = auth_register_v2('*****@*****.**', 'pasword24323132', 'Terrence',
                            'Andrews')
    user2 = auth_register_v2('*****@*****.**', 'password1234', 'Terry',
                             'Lurr')

    dm = dm_create_v1(user['token'], [user2['auth_user_id']])
    # 3 seconds
    time = datetime.now().replace(microsecond=0) + timedelta(0, 3)
    time_sent = time.timestamp()
    # 5 seconds
    time_later = datetime.now().replace(microsecond=0) + timedelta(0, 5)
    time_sent_later = time_later.timestamp()

    def test_sent_empty(message):
        messages = search_v2(user['token'], message)
        assert messages == {'messages': []}

    # Check if messages is empty 2 seconds after the first message_sendlaterdm has been called
    timer = threading.Timer(2, test_sent_empty, args=('Hey Guys!'))
    timer.start()

    def test_sent_later_empty():
        messages = search_v2(user['token'], '2 seconds later')
        assert messages == {'messages': []}

    # Check 2nd message has been sent yet
    timer = threading.Timer(2, test_sent_later_empty)
    timer.start()

    msg = message_sendlaterdm_v1(user['token'], dm['dm_id'], "Hey Guys!",
                                 time_sent)
    msg_search = search_v2(user['token'], 'Hey Guys!')
    assert msg_search['messages'][0]['message_id'] == msg['message_id']
    assert msg_search['messages'][0]['time_created'] == time_sent

    # Second message sent
    msg_later = message_sendlaterdm_v1(user['token'], dm['dm_id'],
                                       "2 seconds later", time_sent_later)
    msg_search = search_v2(user['token'], '2 seconds later')
    assert msg_search['messages'][0]['message_id'] == msg_later['message_id']
    assert msg_search['messages'][0]['time_created'] == time_sent_later
Exemplo n.º 15
0
def message_sendlaterdm():
    parameters = request.get_json()
    token = parameters['token']
    dm_id = parameters['dm_id']
    message = parameters['message']
    time_sent = parameters['time_sent']
    output = message_sendlaterdm_v1(token, dm_id, message, time_sent)
    message_id = output['message_id']
    standup_thread = threading.Thread(target=sendlaterdm_handler, args=[message_id, time_sent])
    standup_thread.start()
    return dumps(output)
Exemplo n.º 16
0
def message_sendlaterdm():
    info = request.get_json()
    token = info["token"]
    dm_id = info["dm_id"]
    message = info["message"]
    time_sent = info["time_sent"]

    message_sendlaterdm = message_sendlaterdm_v1(token, dm_id, message,
                                                 time_sent)

    return dumps(message_sendlaterdm)
Exemplo n.º 17
0
def test_success_no_delay(create_input):
    assert dm_messages_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], 0)["messages"] == []
    current_time = int(time.time())
    msg = message_sendlaterdm_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], "Hey there!", current_time)
    assert type(msg) == dict
    assert type(msg["message_id"]) == int

    # Message should have been sent already
    msgs = dm_messages_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], 0)["messages"]
    assert len(msgs) == 1
    assert msgs[0]["message"] == "Hey there!"
    assert msgs[0]["time_created"] == current_time
Exemplo n.º 18
0
def test_simple_success(create_input):
    assert dm_messages_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], 0)["messages"] == []
    current_time = int(time.time())
    msg = message_sendlaterdm_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], "Hey there!", current_time + 2)
    assert type(msg) == dict
    assert type(msg["message_id"]) == int

    # Make sure message has not been sent yet
    assert dm_messages_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], 0)["messages"] == []

    # Wait 2.5 seconds and check again; message should be there
    time.sleep(2.5)
    msgs = dm_messages_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], 0)["messages"]
    assert len(msgs) == 1
    assert msgs[0]["message"] == "Hey there!"
    assert msgs[0]["time_created"] == current_time + 2
Exemplo n.º 19
0
def test_mixed_success(create_input):
    current_time = int(time.time())
    message_senddm_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], "This is the first normal message")
    assert len(dm_messages_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], 0)["messages"]) == 1
    msg = message_sendlaterdm_v1(create_input[0][1]["token"], create_input[1][0]["dm_id"], "Hey there, I'm from the past!", current_time + 2)
    assert type(msg) == dict
    assert type(msg["message_id"]) == int
    message_senddm_v1(create_input[0][2]["token"], create_input[1][0]["dm_id"], "This is the second normal message")

    # Make sure delayed message has not been sent yet
    msgs = dm_messages_v1(create_input[0][0]["token"], create_input[1][0]["dm_id"], 0)["messages"]
    assert len(msgs) == 2

    # Wait 2.5 seconds and check again; delayed message should be there
    time.sleep(2.5)
    msgs = dm_messages_v1(create_input[0][1]["token"], create_input[1][0]["dm_id"], 0)["messages"]
    assert len(msgs) == 3
    assert msgs[0]["message"] == "Hey there, I'm from the past!"
    assert msgs[0]["time_created"] == current_time + 2
    assert msgs[1]["message"] == "This is the second normal message"
    assert msgs[1]["time_created"] == current_time
    assert msgs[2]["message"] == "This is the first normal message"
    assert msgs[2]["time_created"] == current_time
Exemplo n.º 20
0
def test_invalid_token(create_input):
    with pytest.raises(AccessError):
        message_sendlaterdm_v1(123, create_input[1][1]["dm_id"], "I don't exist :(((", int(time.time()) + 2)
Exemplo n.º 21
0
def test_not_member(create_input):
    with pytest.raises(AccessError):
        message_sendlaterdm_v1(create_input[0][4]["token"], create_input[1][0]["dm_id"], "I'm not in this dm :(", int(time.time()) + 2)
Exemplo n.º 22
0
def test_time_sent_past(create_input):
    with pytest.raises(InputError):
        message_sendlaterdm_v1(create_input[0][1]["token"], create_input[1][1]["dm_id"], "Hey from the future!", int(time.time()) - 20)
Exemplo n.º 23
0
def test_message_too_long(create_input):
    msg = 'x' * 1001
    with pytest.raises(InputError):
        message_sendlaterdm_v1(create_input[0][1]["token"], create_input[1][1]["dm_id"], msg, int(time.time()) + 2)
Exemplo n.º 24
0
def test_invalid_dm(create_input):
    with pytest.raises(InputError):
        message_sendlaterdm_v1(create_input[0][0]["token"], 123, "This message won't be sent", int(time.time()) + 2)