Non è possibile accedere direttamente alla password. Il password
L'attributo è crittografato. (Vedere Gestione della password in Django.)
Ad esempio, ecco output di esempio di password.
>>> user = User.objects.create_user(username='asdf', email='asdf@example.com', password='xxxx')
>>> user.password
'sha1$166e7$4028738f0c0df0e7ec3cec06843c35d2b5a1aae8'
Come potete vedere, user.password
non è xxxx
Ho dato.
Modificherei create_user
Per accettare il parametro della password opzionale. E passare una password entrambi a create_user
, e client.login
come segue:
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)
AGGIORNARE
create_user
dovrebbe usare User.objects.create_user
invece di User.objects.create
. E l'oggetto utente creato deve essere restituito:
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 # <---