Sie können nicht direkt auf das Passwort zugreifen. Das password
Attribut wird verschlüsselt. (Sehen Passwortverwaltung in Django.)
Zum Beispiel hier die Beispielausgabe des Passworts.
>>> user = User.objects.create_user(username='asdf', email='asdf@example.com', password='xxxx')
>>> user.password
'sha1$166e7$4028738f0c0df0e7ec3cec06843c35d2b5a1aae8'
Wie du sehen kannst, user.password
ist nicht xxxx
Ich habe gegeben.
Ich würde ändern create_user
So akzeptieren Sie den optionalen Kennwortparameter. Und übergeben ein Passwort beides an create_user
, und client.login
wie folgt:
def setUp(self):
"""
Initializes the test client and logs it in.
"""
password = 'secret'
self.user = create_user(password=password)
self.logged_in = self.client.login(username=self.user.username, password=password)
AKTUALISIEREN
create_user
sollte nutzen User.objects.create_user
Anstatt von User.objects.create
. Und das erstellte Benutzerobjekt sollte zurückgegeben werden:
def create_user(username=None, password=None, email=None, is_superuser=False):
if username is None:
username = "user%d" % Static.user_count
while User.objects.filter(username=username).count() != 0:
Static.user_count += 1
username = "user%d" % Static.user_count
if password is None:
password = "password"
if email is None:
email="user%d@test.com" % Static.user_count
Static.user_count += 1
user = User.objects.create_user(username=username, password=password)
# ^^^^^^^^^^^
user.is_superuser = is_superuser
user.save()
return user # <---