Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/spec
diff options
context:
space:
mode:
authorDmitriy Zaporozhets <dzaporozhets@gitlab.com>2015-03-17 19:49:38 +0300
committerDmitriy Zaporozhets <dzaporozhets@gitlab.com>2015-03-17 19:49:38 +0300
commitbfc8ded120b5a0dac4a1ee56b5f4b1b714ebf113 (patch)
treed3d9c977b2917de4676812d016d2c2044680d6ab /spec
parent9162e34bb078be9f4fb35b7e43f89c926dc3bcd8 (diff)
parent7d2b34bd61df9722ac2461e87ce595228eecef21 (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.rb33
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