BigW Consortium Gitlab

permissions_spec.rb 3 KB
require 'spec_helper'

describe Gitlab::CycleAnalytics::Permissions do
  let(:project) { create(:empty_project, public_builds: false) }
  let(:user) { create(:user) }

  subject { described_class.get(user: user, project: project) }

  context 'user with no relation to the project' do
    it 'has no permissions to issue stage' do
      expect(subject[:issue]).to eq(false)
    end

    it 'has no permissions to test stage' do
      expect(subject[:test]).to eq(false)
    end

    it 'has no permissions to staging stage' do
      expect(subject[:staging]).to eq(false)
    end

    it 'has no permissions to production stage' do
      expect(subject[:production]).to eq(false)
    end

    it 'has no permissions to code stage' do
      expect(subject[:code]).to eq(false)
    end

    it 'has no permissions to review stage' do
      expect(subject[:review]).to eq(false)
    end

    it 'has no permissions to plan stage' do
      expect(subject[:plan]).to eq(false)
    end
  end

  context 'user is master' do
    before do
      project.team << [user, :master]
    end

    it 'has permissions to issue stage' do
      expect(subject[:issue]).to eq(true)
    end

    it 'has permissions to test stage' do
      expect(subject[:test]).to eq(true)
    end

    it 'has permissions to staging stage' do
      expect(subject[:staging]).to eq(true)
    end

    it 'has permissions to production stage' do
      expect(subject[:production]).to eq(true)
    end

    it 'has permissions to code stage' do
      expect(subject[:code]).to eq(true)
    end

    it 'has permissions to review stage' do
      expect(subject[:review]).to eq(true)
    end

    it 'has permissions to plan stage' do
      expect(subject[:plan]).to eq(true)
    end
  end

  context 'user has no build permissions' do
    before do
      project.team << [user, :guest]
    end

    it 'has permissions to issue stage' do
      expect(subject[:issue]).to eq(true)
    end

    it 'has no permissions to test stage' do
      expect(subject[:test]).to eq(false)
    end

    it 'has no permissions to staging stage' do
      expect(subject[:staging]).to eq(false)
    end
  end

  context 'user has no merge request permissions' do
    before do
      project.team << [user, :guest]
    end

    it 'has permissions to issue stage' do
      expect(subject[:issue]).to eq(true)
    end

    it 'has no permissions to code stage' do
      expect(subject[:code]).to eq(false)
    end

    it 'has no permissions to review stage' do
      expect(subject[:review]).to eq(false)
    end
  end

  context 'user has no issue permissions' do
    before do
      project.team << [user, :developer]
      project.project_feature.update_attribute(:issues_access_level, ProjectFeature::DISABLED)
    end

    it 'has permissions to code stage' do
      expect(subject[:code]).to eq(true)
    end

    it 'has no permissions to issue stage' do
      expect(subject[:issue]).to eq(false)
    end

    it 'has no permissions to production stage' do
      expect(subject[:production]).to eq(false)
    end
  end
end