diff options
author | Dmitriy Zaporozhets <dzaporozhets@gitlab.com> | 2015-03-17 19:49:38 +0300 |
---|---|---|
committer | Dmitriy Zaporozhets <dzaporozhets@gitlab.com> | 2015-03-17 19:49:38 +0300 |
commit | bfc8ded120b5a0dac4a1ee56b5f4b1b714ebf113 (patch) | |
tree | d3d9c977b2917de4676812d016d2c2044680d6ab /spec | |
parent | 9162e34bb078be9f4fb35b7e43f89c926dc3bcd8 (diff) | |
parent | 7d2b34bd61df9722ac2461e87ce595228eecef21 (diff) |
Merge branch 'last-deploy-key' into 'master'
Delete deploy key when last connection to a project is destroyed.
Addresses #1959.
See merge request !1710
Diffstat (limited to 'spec')
-rw-r--r-- | spec/models/deploy_keys_project_spec.rb | 33 |
1 files changed, 33 insertions, 0 deletions
diff --git a/spec/models/deploy_keys_project_spec.rb b/spec/models/deploy_keys_project_spec.rb index aacd9bf38bf..f351aab9238 100644 --- a/spec/models/deploy_keys_project_spec.rb +++ b/spec/models/deploy_keys_project_spec.rb @@ -21,4 +21,37 @@ describe DeployKeysProject do it { is_expected.to validate_presence_of(:project_id) } it { is_expected.to validate_presence_of(:deploy_key_id) } end + + describe "Destroying" do + let(:project) { create(:project) } + subject { create(:deploy_keys_project, project: project) } + let(:deploy_key) { subject.deploy_key } + + context "when the deploy key is only used by this project" do + it "destroys the deploy key" do + subject.destroy + + expect { + deploy_key.reload + }.to raise_error(ActiveRecord::RecordNotFound) + end + end + + context "when the deploy key is used by more than one project" do + + let!(:other_project) { create(:project) } + + before do + other_project.deploy_keys << deploy_key + end + + it "doesn't destroy the deploy key" do + subject.destroy + + expect { + deploy_key.reload + }.not_to raise_error(ActiveRecord::RecordNotFound) + end + end + end end |