Использование базовой аутентификации HTTP-доступа в среде тестирования Django

для некоторых из моих представлений Django я создал декоратор, который выполняет базовую аутентификацию HTTP-доступа. Однако, при написании тестов в Django, мне потребовалось время, чтобы понять, как проверить подлинность вида. Вот как я это сделал. Надеюсь, кто-нибудь найдет это полезным.

5 ответов


вот как я это сделал:

from django.test import Client
import base64
auth_headers = {
    'HTTP_AUTHORIZATION': 'Basic ' + base64.b64encode('username:password'),
}
c = Client()
response = c.get('/my-protected-url/', **auth_headers)

Примечание: вам также нужно будет создать пользователя.


в вашем Django TestCase вы можете обновить клиентские значения по умолчанию, чтобы содержать учетные данные http basic auth.

import base64
from django.test import TestCase

class TestMyStuff(TestCase):

    def setUp(self):
        credentials = base64.b64encode('username:password')
        self.client.defaults['HTTP_AUTHORIZATION'] = 'Basic ' + credentials

предполагая, что у меня есть форма входа, я использую следующий метод для входа через тестовую структуру:

    client = Client()
    client.post('/login/', {'username': 'john.smith', 'password': 'secret'})

Я тогда несу client вокруг в моих других тестах, так как он уже аутентифицирован. Каков ваш вопрос к этому сообщению?


для python3 вы можете base64-кодировать свой username:password строку:

base64.b64encode(b'username:password')

Это возвращает байты, поэтому вам нужно перенести его в строку ASCII с .decode('ascii'):

пример:

import base64

from django.test import TestCase


def test_authorized(self):
    headers = {
        'HTTP_AUTHORIZATION': 'Basic ' + base64.b64encode(b'username:password').decode("ascii")
    }
    response = self.client.get('/', **headers)
    self.assertEqual(response.status_code, 200)

другой способ сделать это-обойти клиент Django() и вместо этого использовать запросы.

class MyTest(TestCase):
    def setUp(self):
        AUTH = requests.auth.HTTPBasicAuth("username", "password")

    def some_test(self):
        resp = requests.get(BASE_URL + 'endpoint/', auth=AUTH)
        self.assertEqual(resp.status_code, 200)