personal_access_tokens_spec.rb 2.4 KB
Newer Older
1 2
require 'spec_helper'

3
describe 'Profile > Personal Access Tokens', feature: true, js: true do
4 5 6 7 8 9 10 11 12 13 14 15
  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)

16
      active_personal_access_tokens = find(".table.active-personal-access-tokens").native['innerHTML']
17 18 19 20 21
      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
22 23 24 25 26

      # Set date to 1st of next month
      find("a[title='Next']").click
      click_on "1"

27 28
      expect {click_on "Add Personal Access Token"}.to change { PersonalAccessToken.count }.by(1)

29
      active_personal_access_tokens = find(".table.active-personal-access-tokens").native['innerHTML']
30
      expect(active_personal_access_tokens).to match(PersonalAccessToken.last.name)
31
      expect(active_personal_access_tokens).to match(Date.today.next_month.at_beginning_of_month.to_s)
32 33 34 35 36 37 38 39 40 41
      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"

42
      inactive_personal_access_tokens = find(".table.inactive-personal-access-tokens").native['innerHTML']
43 44 45 46 47 48 49 50
      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

51
      inactive_personal_access_tokens = find(".table.inactive-personal-access-tokens").native['innerHTML']
52 53 54 55 56
      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