access_spec.rb revision fff4fdff482b9349911ce6365e9ac85b86a1fd5f
require 'spec_helper'
describe 'Repository Access' do
context 'fetching repositories' do
let(:user) { create :user }
let!(:repository_pub_r) { create :repository, user: user,
access: 'public_r' }
let!(:repository_pub_rw) { create :repository, user: user,
access: 'public_rw' }
let!(:repository_priv_r) { create :repository, user: user,
access: 'private_r' }
let!(:repository_priv_rw) { create :repository, user: user,
access: 'private_rw' }
%w(_r _rw).each do |access_modifier|
it "should fetch the public#{access_modifier} repository" do
expect(Repository.pub.map(&:access).
include?("public#{access_modifier}")).to be_truthy
end
it "should not fetch the private#{access_modifier} repository" do
expect(Repository.pub.map(&:access).
include?("private#{access_modifier}")).to be_falsy
end
end
end
context 'private repository' do
let(:ontology_version) { create :ontology_version }
let(:repository) { ontology_version.repository }
before do
repository.access = 'private_rw'
repository.save
end
context 'without access token' do
it 'should not have a token yet' do
expect(repository.access_tokens).to be_empty
end
end
context 'after generate_access_token' do
let!(:access_token) { repository.generate_access_token }
it 'should generate a token' do
expect(repository.access_tokens).not_to be_empty
end
it 'should associate with the generated token' do
expect(repository.access_tokens.first).to eq(access_token)
end
it 'should save the token' do
expect(repository.access_tokens.first.persisted?).to be_truthy
end
end
end
end