示例#1
0
def test_auth_user_malformed_token_1(client, db):
    access_token = "Bearer mF_9.B5f-4.1JqM"
    response = get_user(client, access_token)
    assert response.status_code == HTTPStatus.UNAUTHORIZED
    assert "message" in response.json and response.json[
        "message"] == INVALID_TOKEN
    assert "WWW-Authenticate" in response.headers
    assert response.headers["WWW-Authenticate"] == WWW_AUTH_INVALID_TOKEN
示例#2
0
def test_auth_user(client, db):
    register_user(client)
    response = login_user(client)
    assert "access_token" in response.json
    access_token = response.json["access_token"]
    response = get_user(client, access_token)
    assert response.status_code == HTTPStatus.OK
    assert "email" in response.json and response.json["email"] == EMAIL
    assert "admin" in response.json and not response.json["admin"]
示例#3
0
def test_auth_user_malformed_token_2(client, db):
    access_token = ("eyJ0eXAiOiJKV1QiLCJqbGciOiJIUzI1NiJ9"
                    ".eyJleHAiOjE1NTMwMTk0MzIsImlhdCI6MTU1MzAxODUyNywic3ViI"
                    "joiNTcwZWI3M2ItYqRiNC00Yzg2LWIzNWQtMzkwYjQ3ZDk5YmY2In0"
                    ".mbRr2TJQjUJUGHqswG64DojYh_tkH7-auTJppuzN82g")
    response = get_user(client, access_token)
    assert response.status_code == HTTPStatus.UNAUTHORIZED
    assert "message" in response.json and response.json[
        "message"] == INVALID_TOKEN
    assert "WWW-Authenticate" in response.headers
    assert response.headers["WWW-Authenticate"] == WWW_AUTH_INVALID_TOKEN
示例#4
0
def test_auth_user_expired_token(client, db):
    register_user(client)
    response = login_user(client)
    assert "access_token" in response.json
    access_token = response.json["access_token"]
    time.sleep(6)
    response = get_user(client, access_token)
    assert response.status_code == HTTPStatus.UNAUTHORIZED
    assert "message" in response.json and response.json[
        "message"] == TOKEN_EXPIRED
    assert "WWW-Authenticate" in response.headers
    assert response.headers["WWW-Authenticate"] == WWW_AUTH_EXPIRED_TOKEN
示例#5
0
def test_auth_user_token_blacklisted(client, db):
    register_user(client)
    response = login_user(client)
    assert "access_token" in response.json
    access_token = response.json["access_token"]
    response = logout_user(client, access_token)
    assert response.status_code == HTTPStatus.OK
    response = get_user(client, access_token)
    assert response.status_code == HTTPStatus.UNAUTHORIZED
    assert "message" in response.json and response.json[
        "message"] == TOKEN_BLACKLISTED
    assert "WWW-Authenticate" in response.headers
    assert response.headers["WWW-Authenticate"] == WWW_AUTH_BLACKLISTED_TOKEN
示例#6
0
    def test_authuser_status_valid_user_expired_token(self, client, db):
        """ AuthUserStatus endpoint should return 401 and message for expired token.  """
        user = dict(user_name="great_user",
                    email="*****@*****.**",
                    password="******")
        register_user(client, **user)
        response = login_user(client, **user)

        assert "access_token" in response.json
        access_token = response.json["access_token"]

        sleep(6)

        response = get_user(client, access_token)
        assert response.status_code == 401
示例#7
0
    def test_authuser_status_valid_user(self, client, db):
        """ AuthUserStatus endpoint should return 200 and user data for logged in user.  """
        user = dict(user_name="great_user",
                    email="*****@*****.**",
                    password="******")
        register_user(client, **user)
        response = login_user(client, **user)

        assert "access_token" in response.json
        access_token = response.json["access_token"]

        response = get_user(client, access_token)
        assert response.status_code == 200
        assert "email" in response.json and response.json["email"] == user[
            "email"]
        assert "is_admin" in response.json and not response.json["is_admin"]