Feature: User has access restricted access to domains

  @need-registered-user-john
  Scenario: User john has admin access
    When I visit "https://login.example.com:8080?rd=https://home.example.com:8080/"
    And I login with user "john" and password "password"
    And I use "REGISTERED" as TOTP token handle
    And I click on "Sign in"
    And I'm redirected to "https://home.example.com:8080/"
    Then I have access to "https://public.example.com:8080/secret.html"
    And I have access to "https://dev.example.com:8080/groups/admin/secret.html"
    And I have access to "https://dev.example.com:8080/groups/dev/secret.html"
    And I have access to "https://dev.example.com:8080/users/john/secret.html"
    And I have access to "https://dev.example.com:8080/users/harry/secret.html"
    And I have access to "https://dev.example.com:8080/users/bob/secret.html"
    And I have access to "https://admin.example.com:8080/secret.html"
    And I have access to "https://mx1.mail.example.com:8080/secret.html"
    And I have access to "https://single_factor.example.com:8080/secret.html"
    And I have no access to "https://mx2.mail.example.com:8080/secret.html"

  @need-registered-user-bob
  Scenario: User bob has restricted access
    When I visit "https://login.example.com:8080?rd=https://home.example.com:8080/"
    And I login with user "bob" and password "password"
    And I use "REGISTERED" as TOTP token handle
    And I click on "Sign in"
    And I'm redirected to "https://home.example.com:8080/"
    Then I have access to "https://public.example.com:8080/secret.html"
    And I have no access to "https://dev.example.com:8080/groups/admin/secret.html"
    And I have access to "https://dev.example.com:8080/groups/dev/secret.html"
    And I have no access to "https://dev.example.com:8080/users/john/secret.html"
    And I have no access to "https://dev.example.com:8080/users/harry/secret.html"
    And I have access to "https://dev.example.com:8080/users/bob/secret.html"
    And I have no access to "https://admin.example.com:8080/secret.html"
    And I have access to "https://mx1.mail.example.com:8080/secret.html"
    And I have access to "https://single_factor.example.com:8080/secret.html"
    And I have access to "https://mx2.mail.example.com:8080/secret.html"

  @need-registered-user-harry
  Scenario: User harry has restricted access
    When I visit "https://login.example.com:8080?rd=https://home.example.com:8080/"
    And I login with user "harry" and password "password"
    And I use "REGISTERED" as TOTP token handle
    And I click on "Sign in"
    And I'm redirected to "https://home.example.com:8080/"
    Then I have access to "https://public.example.com:8080/secret.html"
    And I have no access to "https://dev.example.com:8080/groups/admin/secret.html"
    And I have no access to "https://dev.example.com:8080/groups/dev/secret.html"
    And I have no access to "https://dev.example.com:8080/users/john/secret.html"
    And I have access to "https://dev.example.com:8080/users/harry/secret.html"
    And I have no access to "https://dev.example.com:8080/users/bob/secret.html"
    And I have no access to "https://admin.example.com:8080/secret.html"
    And I have no access to "https://mx1.mail.example.com:8080/secret.html"
    And I have access to "https://single_factor.example.com:8080/secret.html"
    And I have no access to "https://mx2.mail.example.com:8080/secret.html"