# -*- coding: utf-8 -*- # Copyright 2010 - 2017 RhodeCode GmbH and the AppEnlight project authors # # Licensed under the Apache License, Version 2.0 (the "License"); # you may not use this file except in compliance with the License. # You may obtain a copy of the License at # # http://www.apache.org/licenses/LICENSE-2.0 # # Unless required by applicable law or agreed to in writing, software # distributed under the License is distributed on an "AS IS" BASIS, # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. # See the License for the specific language governing permissions and # limitations under the License. import pytest import json from webtest import TestApp @pytest.mark.usefixtures( "base_app", "with_migrations", "clean_tables", "default_application" ) class TestAPIReportsView(object): def test_no_json_payload(self, base_app): app = TestApp(base_app) url_path = "/api/reports" headers = {"x-appenlight-api-key": "xxxx"} res = app.post(url_path, {}, status=400, headers=headers) def test_wrong_json_payload(self, base_app): app = TestApp(base_app) url_path = "/api/reports" headers = {"x-appenlight-api-key": "xxxx"} res = app.post(url_path, {}, status=400, headers=headers) def test_correct_json_payload(self, base_app): import appenlight.tests.payload_examples as payload_examples app = TestApp(base_app) url_path = "/api/reports" headers = {"x-appenlight-api-key": "xxxx"} res = app.post_json( url_path, [payload_examples.PYTHON_PAYLOAD_0_5], headers=headers ) def test_json_payload_wrong_key(self, base_app): import appenlight.tests.payload_examples as payload_examples app = TestApp(base_app) url_path = "/api/reports" res = app.post( url_path, json.dumps([payload_examples.PYTHON_PAYLOAD_0_5]), status=403 ) @pytest.mark.usefixtures( "base_app", "with_migrations", "clean_tables", "default_data", "default_application" ) class TestRegistrationView(object): def test_register_empty(self, base_app): url_path = "/register" app = TestApp(base_app) resp = app.get("/") cookies = resp.headers.getall("Set-Cookie") cookie = None for name, value in [c.split("=", 1) for c in cookies]: if name == "XSRF-TOKEN": cookie = value.split(";")[0] headers = {"X-XSRF-TOKEN": cookie} res = app.post( url_path, params={"user_name": "", "user_password": "", "email": ""}, headers=headers, ) assert "This field is required." in res def test_register_proper(self, base_app): url_path = "/register" app = TestApp(base_app) resp = app.get("/") cookies = resp.headers.getall("Set-Cookie") cookie = None for name, value in [c.split("=", 1) for c in cookies]: if name == "XSRF-TOKEN": cookie = value.split(";")[0] headers = {"X-XSRF-TOKEN": cookie} res = app.post( url_path, params={ "user_name": "user_foo", "user_password": "passbar", "email": "foobar@blablabla.com", }, headers=headers, status=302, ) @pytest.mark.usefixtures( "base_app", "with_migrations", "clean_tables", "default_data", "default_application" ) class TestRegistrationAuthTokenView(object): def test_create_application_bad(self, base_app): url_path = "/applications" app = TestApp(base_app) headers = {"x-appenlight-auth-token": ""} app.post_json( url_path, params={"resource_name": "user_foo"}, headers=headers, status=403 ) def test_create_application_proper(self, base_app): url_path = "/applications" app = TestApp(base_app) headers = {"x-appenlight-auth-token": "1234"} app.post_json( url_path, params={"resource_name": "user_foo"}, headers=headers, status=200 )