This repository has been archived by the owner on Feb 8, 2018. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 308
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Showing
3 changed files
with
122 additions
and
0 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,3 @@ | ||
-- participants.has_verified_identity | ||
|
||
ALTER TABLE participants ADD COLUMN has_verified_identity bool NOT NULL DEFAULT false; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -2,11 +2,13 @@ | |
|
||
from cryptography.fernet import InvalidToken | ||
from gratipay.testing import Harness | ||
from gratipay.models.participant import Participant | ||
from gratipay.models.participant.mixins import identity, Identity | ||
from gratipay.models.participant.mixins.identity import _validate_info, rekey | ||
from gratipay.models.participant.mixins.identity import ParticipantIdentityInfoInvalid | ||
from gratipay.models.participant.mixins.identity import ParticipantIdentitySchemaUnknown | ||
from gratipay.security.crypto import EncryptingPacker, Fernet | ||
from postgres.orm import ReadOnly | ||
from psycopg2 import IntegrityError | ||
from pytest import raises | ||
|
||
|
@@ -250,6 +252,97 @@ def test_ci_still_logs_an_event_when_noop(self): | |
self.assert_events(self.crusher.id, [None], [self.TT], ['clear identity']) | ||
|
||
|
||
# hvi - has_verified_identity | ||
|
||
def test_hvi_defaults_to_false(self): | ||
assert self.crusher.has_verified_identity is False | ||
|
||
def test_hvi_is_read_only(self): | ||
with raises(ReadOnly): | ||
self.crusher.has_verified_identity = True | ||
|
||
def test_hvi_becomes_true_when_an_identity_is_verified(self): | ||
self.crusher.store_identity_info(self.TT, 'nothing-enforced', {}) | ||
self.crusher.set_identity_verification(self.TT, True) | ||
assert self.crusher.has_verified_identity | ||
assert Participant.from_username('crusher').has_verified_identity | ||
|
||
def test_hvi_becomes_false_when_the_identity_is_unverified(self): | ||
self.crusher.store_identity_info(self.TT, 'nothing-enforced', {}) | ||
self.crusher.set_identity_verification(self.TT, True) | ||
self.crusher.set_identity_verification(self.TT, False) | ||
assert not self.crusher.has_verified_identity | ||
assert not Participant.from_username('crusher').has_verified_identity | ||
|
||
def test_hvi_stays_true_when_a_secondary_identity_is_verified(self): | ||
self.crusher.store_identity_info(self.US, 'nothing-enforced', {}) | ||
self.crusher.set_identity_verification(self.US, True) | ||
self.crusher.store_identity_info(self.TT, 'nothing-enforced', {}) | ||
self.crusher.set_identity_verification(self.TT, True) | ||
assert self.crusher.has_verified_identity | ||
assert Participant.from_username('crusher').has_verified_identity | ||
|
||
def test_hvi_stays_true_when_the_secondary_identity_is_unverified(self): | ||
self.crusher.store_identity_info(self.US, 'nothing-enforced', {}) | ||
self.crusher.set_identity_verification(self.US, True) | ||
self.crusher.store_identity_info(self.TT, 'nothing-enforced', {}) | ||
self.crusher.set_identity_verification(self.TT, True) | ||
self.crusher.set_identity_verification(self.TT, False) | ||
assert self.crusher.has_verified_identity | ||
assert Participant.from_username('crusher').has_verified_identity | ||
|
||
def test_hvi_goes_back_to_false_when_both_are_unverified(self): | ||
self.crusher.store_identity_info(self.US, 'nothing-enforced', {}) | ||
self.crusher.store_identity_info(self.TT, 'nothing-enforced', {}) | ||
self.crusher.set_identity_verification(self.TT, True) | ||
self.crusher.set_identity_verification(self.US, True) | ||
self.crusher.set_identity_verification(self.TT, False) | ||
self.crusher.set_identity_verification(self.US, False) | ||
assert not self.crusher.has_verified_identity | ||
assert not Participant.from_username('crusher').has_verified_identity | ||
|
||
def test_hvi_changes_are_scoped_to_a_participant(self): | ||
self.crusher.store_identity_info(self.US, 'nothing-enforced', {}) | ||
|
||
bruiser = self.make_participant('bruiser', email_address='[email protected]') | ||
bruiser.store_identity_info(self.US, 'nothing-enforced', {}) | ||
|
||
self.crusher.set_identity_verification(self.US, True) | ||
|
||
assert self.crusher.has_verified_identity | ||
assert Participant.from_username('crusher').has_verified_identity | ||
assert not bruiser.has_verified_identity | ||
assert not Participant.from_username('bruiser').has_verified_identity | ||
|
||
def test_hvi_resets_when_identity_is_cleared(self): | ||
self.crusher.store_identity_info(self.TT, 'nothing-enforced', {}) | ||
self.crusher.set_identity_verification(self.TT, True) | ||
self.crusher.clear_identity(self.TT) | ||
assert not self.crusher.has_verified_identity | ||
assert not Participant.from_username('crusher').has_verified_identity | ||
|
||
def test_hvi_doesnt_reset_when_penultimate_identity_is_cleared(self): | ||
self.crusher.store_identity_info(self.US, 'nothing-enforced', {}) | ||
self.crusher.set_identity_verification(self.US, True) | ||
self.crusher.store_identity_info(self.TT, 'nothing-enforced', {}) | ||
self.crusher.set_identity_verification(self.TT, True) | ||
self.crusher.set_identity_verification(self.TT, False) | ||
self.crusher.clear_identity(self.TT) | ||
assert self.crusher.has_verified_identity | ||
assert Participant.from_username('crusher').has_verified_identity | ||
|
||
def test_hvi_does_reset_when_both_identities_are_cleared(self): | ||
self.crusher.store_identity_info(self.US, 'nothing-enforced', {}) | ||
self.crusher.store_identity_info(self.TT, 'nothing-enforced', {}) | ||
self.crusher.set_identity_verification(self.US, True) | ||
self.crusher.set_identity_verification(self.TT, True) | ||
self.crusher.set_identity_verification(self.TT, False) | ||
self.crusher.set_identity_verification(self.US, False) | ||
self.crusher.clear_identity(self.TT) | ||
assert not self.crusher.has_verified_identity | ||
assert not Participant.from_username('crusher').has_verified_identity | ||
|
||
|
||
# fine - fail_if_no_email | ||
|
||
def test_fine_fails_if_no_email(self): | ||
|