summaryrefslogtreecommitdiff
path: root/spec/features/profiles/personal_access_tokens_spec.rb
blob: ce972776ffe059a63e3d2a34234ec0cd2595722b (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
require 'spec_helper'

describe 'Profile > Personal Access Tokens', feature: true do
  let(:user) { create(:user) }

  before do
    login_as(user)
  end

  describe "token creation" do
    it "allows creation of a token with an optional expiry date" do
      visit profile_personal_access_tokens_path
      fill_in "Name", with: FFaker::Product.brand
      expect {click_on "Add Personal Access Token"}.to change { PersonalAccessToken.count }.by(1)

      active_personal_access_tokens = find(".table.active-personal-access-tokens").native.inner_html
      expect(active_personal_access_tokens).to match(PersonalAccessToken.last.name)
      expect(active_personal_access_tokens).to match("Never")
      expect(active_personal_access_tokens).to match(PersonalAccessToken.last.token)

      fill_in "Name", with: FFaker::Product.brand
      fill_in "Expires at", with: 5.days.from_now
      expect {click_on "Add Personal Access Token"}.to change { PersonalAccessToken.count }.by(1)

      active_personal_access_tokens = find(".table.active-personal-access-tokens").native.inner_html
      expect(active_personal_access_tokens).to match(PersonalAccessToken.last.name)
      expect(active_personal_access_tokens).to match(5.days.from_now.to_date.to_s)
      expect(active_personal_access_tokens).to match(PersonalAccessToken.last.token)
    end
  end

  describe "inactive tokens" do
    it "allows revocation of an active token" do
      personal_access_token = create(:personal_access_token, user: user)
      visit profile_personal_access_tokens_path
      click_on "Revoke"

      inactive_personal_access_tokens = find(".table.inactive-personal-access-tokens").native.inner_html
      expect(inactive_personal_access_tokens).to match(personal_access_token.name)
      expect(inactive_personal_access_tokens).to match(personal_access_token.token)
    end

    it "moves expired tokens to the 'inactive' section" do
      personal_access_token = create(:personal_access_token, expires_at: 5.days.ago, user: user)
      visit profile_personal_access_tokens_path

      inactive_personal_access_tokens = find(".table.inactive-personal-access-tokens").native.inner_html
      expect(inactive_personal_access_tokens).to match(personal_access_token.name)
      expect(inactive_personal_access_tokens).to match(personal_access_token.token)
    end
  end
end