Beispiel #1
0
def test_missing_signature(
    mocker: MockFixture,
    authenticator: Auth0Authenticator,
    tokens: Dict[str, str],
    sign_key: Dict[str, Any],
):
    mock_valid_time(mocker)
    with pytest.raises(Exception, match=r"Invalid signature"):
        authenticator._get_payload(tokens["noSignature"], sign_key)
Beispiel #2
0
def test_cookie_extract(flask_app: Flask, authenticator: Auth0Authenticator,
                        access_token: str):
    cookie_name = "TestCookie"
    authenticator.header_authentication = False
    authenticator.cookie_authentication = True
    authenticator.cookie_name = cookie_name
    header = dump_cookie(cookie_name, access_token)
    with flask_app.test_request_context(headers={"COOKIE": header}):
        token = authenticator._get_token()
        assert token == access_token
Beispiel #3
0
def test_no_scopes(
    mocker: MockFixture,
    flask_app: Flask,
    authenticator: Auth0Authenticator,
    access_token: str,
):
    mock_valid_time(mocker)
    with flask_app.test_request_context(
            headers={"Authorization": f"Bearer {access_token}"}):
        authenticator.with_scopes([]).authenticate()
Beispiel #4
0
def test_invalid_audience(
    mocker: MockFixture,
    authenticator: Auth0Authenticator,
    access_token: str,
    sign_key: Dict[str, Any],
):
    mock_valid_time(mocker)
    authenticator.audience = "SomeRandomAudience"
    with pytest.raises(Exception, match=r"Invalid claims"):
        authenticator._get_payload(access_token, sign_key)
Beispiel #5
0
def test_testing_accepts_expired_token(
    mocker: MockFixture,
    authenticator: Auth0Authenticator,
    access_token: str,
    sign_key: Dict[str, Any],
):
    authenticator.testing = True
    datetime_mock = mocker.patch("jose.jwt.datetime")
    datetime_mock.utcnow = Mock(return_value=datetime(2050, 1, 1))
    payload = authenticator._get_payload(access_token, sign_key)
    assert payload is not None
Beispiel #6
0
def test_expired_token(
    mocker: MockFixture,
    authenticator: Auth0Authenticator,
    access_token: str,
    sign_key: Dict[str, Any],
):
    datetime_mock = mocker.patch("jose.jwt.datetime")
    datetime_mock.utcnow = Mock(return_value=datetime(2050, 1, 1))
    authenticator.audience = "SomeRandomAudience"
    with pytest.raises(Exception, match=r"Token is expired"):
        authenticator._get_payload(access_token, sign_key)
Beispiel #7
0
def test_authenticate_ok(
    mocker: MockFixture,
    flask_app: Flask,
    authenticator: Auth0Authenticator,
    access_token: str,
):
    mock_valid_time(mocker)
    with flask_app.test_request_context(
            headers={"Authorization": f"Bearer {access_token}"}):
        authenticator.authenticate()
        assert get_access_token_claims() != {}
Beispiel #8
0
def test_missing_scopes(
    mocker: MockFixture,
    flask_app: Flask,
    authenticator: Auth0Authenticator,
    access_token: str,
):
    mock_valid_time(mocker)
    with flask_app.test_request_context(
            headers={"Authorization": f"Bearer {access_token}"}):
        with pytest.raises(errors.Forbidden):
            authenticator.with_scopes(["read:location",
                                       "write:location"]).authenticate()
Beispiel #9
0
def test_authenticate_failure(
    mocker: MockFixture,
    flask_app: Flask,
    authenticator: Auth0Authenticator,
    access_token: str,
):
    mock_valid_time(mocker)
    authenticator.audience = "SomeRandomAudience"
    with flask_app.test_request_context(
            headers={"Authorization": f"Bearer {access_token}"}):
        with pytest.raises(errors.Unauthorized):
            authenticator.authenticate()
Beispiel #10
0
def test_create_user_failure(
    mocker: MockFixture,
    flask_app: Flask,
    authenticator: Auth0Authenticator,
    access_token: str,
):
    @authenticator.identity_handler
    def create_user(claims: Dict[str, Any]):
        raise Exception

    mock_valid_time(mocker)
    with flask_app.test_request_context(
            headers={"Authorization": f"Bearer {access_token}"}):
        with pytest.raises(errors.Unauthorized):
            authenticator.authenticate()
Beispiel #11
0
def test_refresh_keys_failure(requests_mock: Mocker, flask_app: Flask):
    requests_mock.get(
        "https://perdu.auth0.com/.well-known/jwks.json",
        exc=requests.exceptions.ConnectTimeout,
    )
    authenticator = Auth0Authenticator(flask_app)
    assert authenticator.keys == {}
Beispiel #12
0
def test_create_user_ok(
    mocker: MockFixture,
    flask_app: Flask,
    authenticator: Auth0Authenticator,
    access_token: str,
):
    @authenticator.identity_handler
    def create_user(claims: Dict[str, Any]):
        return {"User": claims["sub"]}

    mock_valid_time(mocker)
    with flask_app.test_request_context(
            headers={"Authorization": f"Bearer {access_token}"}):
        authenticator.authenticate()
        assert (get_authenticated_user()["User"] ==
                "Tlapef2d0GHcq32k2W0PycmFL4wIxuGM@clients")
Beispiel #13
0
def test_testing_wont_refresh_keys(flask_app: Flask, requests_mock: Mocker):
    flask_app.config["AUTH0_TESTING"] = True
    auth0_endpoint_mock = requests_mock.get(
        "https://perdu.auth0.com/.well-known/jwks.json")
    Auth0Authenticator(flask_app)

    assert auth0_endpoint_mock.call_count == 0
Beispiel #14
0
def test_valid_token(
    mocker: MockFixture,
    authenticator: Auth0Authenticator,
    access_token: str,
    sign_key: Dict[str, Any],
):
    mock_valid_time(mocker)
    payload = authenticator._get_payload(access_token, sign_key)
    assert payload != {}
Beispiel #15
0
def test_testing_add_key(flask_app: Flask, requests_mock: Mocker,
                         sign_key: Dict[str, Any]):
    flask_app.config["AUTH0_TESTING"] = True
    auth0_endpoint_mock = requests_mock.get(
        "https://perdu.auth0.com/.well-known/jwks.json")
    authenticator = Auth0Authenticator(flask_app)
    assert not authenticator.keys

    authenticator.add_key(sign_key)
    assert authenticator.keys
Beispiel #16
0
def test_header_extract(flask_app: Flask, authenticator: Auth0Authenticator,
                        access_token: str):
    with flask_app.test_request_context(
            headers={"Authorization": f"Bearer {access_token}"}):
        token = authenticator._get_token()
        assert token == access_token
Beispiel #17
0
def authenticator(flask_app: Flask, requests_mock: Mocker,
                  keys: Dict[str, str]) -> Auth0Authenticator:
    requests_mock.get("https://perdu.auth0.com/.well-known/jwks.json",
                      json=keys)
    return Auth0Authenticator(flask_app)
Beispiel #18
0
def test_testing_add_invalid_key(authenticator: Auth0Authenticator, ):
    with pytest.raises(Exception, match=r"Invalid key"):
        authenticator.add_key({"test": "bad key"})
Beispiel #19
0
def test_no_token(flask_app: Flask, authenticator: Auth0Authenticator):
    with flask_app.test_request_context():
        with pytest.raises(Exception, match=r"Missing token"):
            authenticator._get_token()
Beispiel #20
0
def test_missing_authentication(flask_app: Flask):
    with pytest.raises(
            Exception,
            match=r"Must specify at least one method of authentication"):
        flask_app.config["AUTH0_HEADER_AUTHENTICATION"] = False
        Auth0Authenticator(flask_app)