1234567891011121314151617181920212223242526272829303132333435363738394041424344454647484950515253 |
- from django.db.models import F
- from sentry.models import AuthProvider, Organization
- from sentry.testutils.cases import AcceptanceTestCase
- from sentry.testutils.silo import no_silo_test
- # When we want to set this stable=True, we'll need to configure regions in order for invites to work.
- # See the accept_organization_invite.py#get_invite_state logic
- @no_silo_test(stable=True)
- class AcceptOrganizationInviteTest(AcceptanceTestCase):
- def setUp(self):
- super().setUp()
- self.user = self.create_user("foo@example.com")
- self.org = self.create_organization(name="Rowdy Tiger", owner=None)
- self.team = self.create_team(organization=self.org, name="Mariachi Band")
- self.member = self.create_member(
- user=None,
- email="bar@example.com",
- organization=self.org,
- role="owner",
- teams=[self.team],
- )
- def test_invite_simple(self):
- self.login_as(self.user)
- self.browser.get(self.member.get_invite_link().split("/", 3)[-1])
- self.browser.wait_until('[data-test-id="accept-invite"]')
- assert self.browser.element_exists('[data-test-id="join-organization"]')
- def test_invite_not_authenticated(self):
- self.browser.get(self.member.get_invite_link().split("/", 3)[-1])
- self.browser.wait_until('[data-test-id="accept-invite"]')
- assert self.browser.element_exists('[data-test-id="create-account"]')
- def test_invite_2fa_enforced_org(self):
- self.org.update(flags=F("flags").bitor(Organization.flags.require_2fa))
- self.browser.get(self.member.get_invite_link().split("/", 3)[-1])
- self.browser.wait_until('[data-test-id="accept-invite"]')
- assert not self.browser.element_exists_by_test_id("2fa-warning")
- self.login_as(self.user)
- self.org.update(flags=F("flags").bitor(Organization.flags.require_2fa))
- self.browser.get(self.member.get_invite_link().split("/", 3)[-1])
- self.browser.wait_until('[data-test-id="accept-invite"]')
- assert self.browser.element_exists_by_test_id("2fa-warning")
- def test_invite_sso_org(self):
- AuthProvider.objects.create(organization_id=self.org.id, provider="google")
- self.browser.get(self.member.get_invite_link().split("/", 3)[-1])
- self.browser.wait_until('[data-test-id="accept-invite"]')
- assert self.browser.element_exists_by_test_id("action-info-sso")
- assert self.browser.element_exists('[data-test-id="sso-login"]')
|