diff options
| author | Kamil Trzciński <ayufan@ayufan.eu> | 2017-05-06 17:17:02 +0000 | 
|---|---|---|
| committer | Kamil Trzciński <ayufan@ayufan.eu> | 2017-05-06 17:17:02 +0000 | 
| commit | 6ad3814e1b31bfacfae7a2aabb4e4607b12ca66f (patch) | |
| tree | b6024ca475dea081d9f38e4b14a2709d17af3a50 /spec/serializers | |
| parent | 2e6201b13197d03eafecd18d967ba7d55f664e19 (diff) | |
| parent | fc121cca5ba87abd24afbc8da2f76e14e386e4c8 (diff) | |
| download | gitlab-ce-6ad3814e1b31bfacfae7a2aabb4e4607b12ca66f.tar.gz | |
Merge branch 'feature/gb/manual-actions-protected-branches-permissions' into 'master'
Check access to a branch when user triggers manual action
Closes #20261
See merge request !10494
Diffstat (limited to 'spec/serializers')
| -rw-r--r-- | spec/serializers/build_action_entity_spec.rb | 3 | ||||
| -rw-r--r-- | spec/serializers/build_entity_spec.rb | 28 | 
2 files changed, 28 insertions, 3 deletions
| diff --git a/spec/serializers/build_action_entity_spec.rb b/spec/serializers/build_action_entity_spec.rb index 54ac17447b1..059deba5416 100644 --- a/spec/serializers/build_action_entity_spec.rb +++ b/spec/serializers/build_action_entity_spec.rb @@ -2,9 +2,10 @@ require 'spec_helper'  describe BuildActionEntity do    let(:build) { create(:ci_build, name: 'test_build') } +  let(:request) { double('request') }    let(:entity) do -    described_class.new(build, request: double) +    described_class.new(build, request: spy('request'))    end    describe '#as_json' do diff --git a/spec/serializers/build_entity_spec.rb b/spec/serializers/build_entity_spec.rb index f76a5cf72d1..897a28b7305 100644 --- a/spec/serializers/build_entity_spec.rb +++ b/spec/serializers/build_entity_spec.rb @@ -41,13 +41,37 @@ describe BuildEntity do      it 'does not contain path to play action' do        expect(subject).not_to include(:play_path)      end + +    it 'is not a playable job' do +      expect(subject[:playable]).to be false +    end    end    context 'when build is a manual action' do      let(:build) { create(:ci_build, :manual) } -    it 'contains path to play action' do -      expect(subject).to include(:play_path) +    context 'when user is allowed to trigger action' do +      before do +        build.project.add_master(user) +      end + +      it 'contains path to play action' do +        expect(subject).to include(:play_path) +      end + +      it 'is a playable action' do +        expect(subject[:playable]).to be true +      end +    end + +    context 'when user is not allowed to trigger action' do +      it 'does not contain path to play action' do +        expect(subject).not_to include(:play_path) +      end + +      it 'is not a playable action' do +        expect(subject[:playable]).to be false +      end      end    end  end | 
