проблемы тестирования django - PullRequest
2 голосов
/ 10 июля 2011

Это мое мнение, которое я хочу проверить.

def logIn(request):
    """
    This method will log in user using  username or email
    """
    if request.method == 'POST':
        form = LogInForm(request.POST)
        if form.is_valid():
            user = authenticate(username=form.cleaned_data['name'],password=form.cleaned_data['password'])
            if user:
                login(request,user)
                return redirect('uindex')
            else:
                error = "Nie prawidlowy login lub haslo.Upewnij sie ze wpisales prawidlowe dane"
    else:
        form = LogInForm(auto_id=False)
    return render_to_response('login.html',locals(),context_instance=RequestContext(request))

А вот и тест

class LoginTest(unittest.TestCase):
    def setUp(self):
        self.client  = Client()
    def test_response_for_get(self):
        response =  self.client.get(reverse('logIn'))
        self.assertEqual(response.status_code, 200)
    def test_login_with_username(self):
        """
        Test if user can login wit username and password
        """
        user_name = 'test'
        user_email = 'test@test.com'
        user_password = 'zaq12wsx'
        u =  User.objects.create_user(user_name,user_email,user_password)
        response = self.client.post(reverse('logIn'),data={'name':user_name,'password':user_password},follow=True)
        self.assertEquals(response.request.user.username,user_name)
        u.delete()

И когда я запускаю этот тест, у меня возникает ошибка test_login_with_username:

AttributeError: 'dict' object has no attribute 'user'

Когда я использую в представлениях request.user.username в работает нормально без ошибок, это просто не проходит в тестах.Заранее спасибо за любую помощь в редактировании: Хорошо, я заменяю сломанную часть на

self.assertEquals(302, response.status_code)

Но теперь этот тест перерыв, и еще один.

AssertionError: 302 != 200

Вот мой код для представления, которое сейчас не выполняется.Я хочу, чтобы адрес электронной почты и имя пользователя были уникальными.

def register(request):
    """
    Function to register new user.
    This function will have to care for email uniqueness,and login
    """
    if request.method == 'POST':
        error=[]
        form = RegisterForm(request.POST)
        if form.is_valid():
            username = form.cleaned_data['username']
            email = form.cleaned_data['email']
            if  form.cleaned_data['password'] ==  form.cleaned_data['password_confirmation']:
                password = form.cleaned_data['password']
                if len(User.objects.filter(username=username)) == 0 and len(User.objects.filter(email=email)) == 0:
                    #email and username are bouth unique
                    u = User()
                    u.username = username
                    u.set_password(password)
                    u.email = email
                    u.is_active = False
                    u.is_superuser = False
                    u.is_active = True
                    u.save()
                    return render_to_response('success_register.html',locals(),context_instance=RequestContext(request))
                else:
                    if len(User.objects.filter(username=username)) > 0:
                        error.append("Podany login jest juz zajety")
                    if len(User.objects.filter(email=email)) > 0:
                        error.append("Podany email jest juz zajety")
            else:
                error.append("Hasla nie pasuja do siebie")
        #return render_to_response('register.html',locals(),context_instance=RequestContext(request))
    else:
        form = RegisterForm(auto_id=False)
    return render_to_response('register.html',locals(),context_instance=RequestContext(request))

А вот тест, который изначально работал, но теперь он не работает

def test_user_register_with_unique_data_and_permission(self):
        """
        Will try to register user which provided for sure unique credentials
        And also make sure that profile will be automatically created for him, and also that he he have valid privileges
        """
        user_name = 'test'
        user_email = 'test@test.com'
        password = 'zaq12wsx'
        response = self.client.post(reverse('register'),{'username': user_name,'email':user_email,
        'password':password,'password_confirmation':password},follow=True)
        #check if code is 200
        self.assertEqual(response.status_code, 200)
        u = User.objects.get(username=user_name,email = user_email)
        self.assertTrue(u,"User after creation coudn't be fetched")
        self.assertFalse(u.is_staff,msg="User after registration belong to staff")
        self.assertFalse(u.is_superuser,msg="User after registration is superuser")
        p = UserProfile.objects.get(user__username__iexact = user_name)
        self.assertTrue(p,"After user creation coudn't fetch user profile")
        self.assertEqual(len(response.context['error']),0,msg = 'We shoudnt get error during valid registration')
        u.delete()
        p.delete()

Конец ошибки:

AssertionError: We shoudnt get error during valid registration

Если я отключаю проверку входа, все в порядке.Как этот тест может сломать другой?И почему проверка логина не проходит.Я пробую это на веб-сайте, и он отлично работает.

Ответы [ 2 ]

4 голосов
/ 10 июля 2011

Документация для объекта ответа, возвращаемого тестовым клиентом, говорит об атрибуте запроса:

запрос

Запрос данных , который стимулировал ответ.

Это подсказывает мне одну из двух вещей. Либо это просто данные запроса, либо это объект запроса, каким он был до обработки запроса. В любом случае вы не ожидаете, что он будет содержать зарегистрированного пользователя.

Еще один способ написать свой тест об успешном завершении входа в систему - добавить follow=False к вызову client.post и проверить код ответа:

self.assertEquals(302, response.status_code)

Это проверяет, что перенаправление произошло.

2 голосов
/ 10 июля 2011

response.request - это не объект HttpRequest в ожидаемом вами виде. Это словарь данных, который стимулировал почтовый запрос. У него нет атрибута пользователя, поэтому AttributeError

Вы можете переписать свой тест на:

  1. используйте класс RequestFactory, представленный в Django 1.3, и вызывайте logIn в своем тесте напрямую вместо использования client.post.
  2. осмотрите client.session после публикации, чтобы проверить, вошел ли пользователь в систему.

Почему один провальный тест может сломать другой

Когда вы редактировали вопрос, вы спрашивали

Как этот тест может сломать другой?

Ошибка test_login_with_username до достижения u.delete, поэтому созданный в этом тесте пользователь не был удален. Это вызвало test_user_register_with_unique_data_and_permission, потому что пользователь test уже существовал.

Если вы используете класс django.test.TestCase, база данных будет сбрасываться между каждым тестом, поэтому это не будет проблемой.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...