Skip to content
Merged
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion essenza/templates/product/escaparate.html
Original file line number Diff line number Diff line change
Expand Up @@ -113,7 +113,7 @@
<input type="text" placeholder="Buscar...">
</div>

<form action="{% url 'logout' %}" method="post" style="margin:0;">
<form action='user/logout' method="post" style="margin:0;">
{% csrf_token %}
<button formaction="{% url 'home' %}" type="submit" class="logout-btn">Log out</button>
</form>
Expand Down
2 changes: 1 addition & 1 deletion essenza/user/forms.py
Original file line number Diff line number Diff line change
Expand Up @@ -4,7 +4,7 @@
class LoginForm(forms.Form):
email = forms.CharField(
label="Correo electrónico o usuario",
widget=forms.TextInput(attrs={"placeholder": "Introduce tu correo o usuario"})
widget=forms.TextInput(attrs={"placeholder": "Introduce tu correo electrónico"})
)
password = forms.CharField(
label="Contraseña",
Expand Down
57 changes: 57 additions & 0 deletions essenza/user/tests.py
Original file line number Diff line number Diff line change
@@ -1,3 +1,60 @@
from django.test import TestCase

# Create your tests here.
# user/tests/test_login.py
from django.test import TestCase
from django.urls import reverse
from django.contrib.auth import get_user_model
from django.conf import settings

User = get_user_model()

class LoginViewTests(TestCase):
def setUp(self):
# usuario de prueba
self.username = "user1"
self.email = "user1@example.com"
self.password = "pass1234"
self.user = User.objects.create_user(
username=self.username,
email=self.email,
password=self.password
)
self.login_url = reverse("user:login")
self.home_url = reverse("home")
self.escaparate_url = reverse("escaparate")

#1. comprueba que la pagina de login carga correctamente
def test_get_login_page_returns_200(self):
resp = self.client.get(self.login_url)
self.assertEqual(resp.status_code, 200)
self.assertContains(resp, "Iniciar sesión")
self.assertContains(resp, "ESSENZA")

#2. si email y contraseña validas redirige al escaparate
def test_login_with_valid_email_redirects_escaparate(self):
data = {"email": self.email, "password": self.password}
resp = self.client.post(self.login_url, data, follow=False)
self.assertEqual(resp.status_code, 302, resp.content)
self.assertEqual(resp["Location"], self.escaparate_url)

#3. si email y contraseña no validas muestra error
def test_login_with_invalid_passwordAndEmail_shows_error(self):
data = {"email": "wrong", "password": "wrong"}
resp = self.client.post(self.login_url, data)
self.assertEqual(resp.status_code, 200)
self.assertContains(resp, "Usuario o contraseña incorrectos")

#4. si email no es valido muestra error
def test_login_with_invalid_email_shows_error(self):
data = {"email": "wrong", "password": self.password}
resp = self.client.post(self.login_url, data)
self.assertEqual(resp.status_code, 200)
self.assertContains(resp, "Usuario o contraseña incorrectos")

#5. si contraseña no es valida muestra error
def test_login_with_invalid_password_shows_error(self):
data = {"email": self.email, "password": "wrong"}
resp = self.client.post(self.login_url, data)
self.assertEqual(resp.status_code, 200)
self.assertContains(resp, "Usuario o contraseña incorrectos")
2 changes: 2 additions & 0 deletions essenza/user/urls.py
Original file line number Diff line number Diff line change
Expand Up @@ -3,6 +3,8 @@
from django.http import HttpResponse
from user import views

app_name = "user"

urlpatterns = [
path('login/', views.LoginView.as_view(), name='login'),
path('logout/', views.LogoutView.as_view(), name='logout'),
Expand Down