diff options
author | GitLab Bot <gitlab-bot@gitlab.com> | 2020-06-18 14:18:50 +0300 |
---|---|---|
committer | GitLab Bot <gitlab-bot@gitlab.com> | 2020-06-18 14:18:50 +0300 |
commit | 8c7f4e9d5f36cff46365a7f8c4b9c21578c1e781 (patch) | |
tree | a77e7fe7a93de11213032ed4ab1f33a3db51b738 /spec/models/group_import_state_spec.rb | |
parent | 00b35af3db1abfe813a778f643dad221aad51fca (diff) |
Add latest changes from gitlab-org/gitlab@13-1-stable-ee
Diffstat (limited to 'spec/models/group_import_state_spec.rb')
-rw-r--r-- | spec/models/group_import_state_spec.rb | 72 |
1 files changed, 72 insertions, 0 deletions
diff --git a/spec/models/group_import_state_spec.rb b/spec/models/group_import_state_spec.rb new file mode 100644 index 00000000000..9d9cb1e8391 --- /dev/null +++ b/spec/models/group_import_state_spec.rb @@ -0,0 +1,72 @@ +# frozen_string_literal: true + +require 'spec_helper' + +describe GroupImportState do + describe 'validations' do + let_it_be(:group) { create(:group) } + + it { is_expected.to validate_presence_of(:group) } + it { is_expected.to validate_presence_of(:status) } + + it 'can be created without a jid' do + import_state = build(:group_import_state, :created, group: group, jid: nil) + + expect(import_state).to be_valid + end + + it 'cannot be started without a jid' do + import_state = build(:group_import_state, :started, group: group, jid: nil) + + expect(import_state).not_to be_valid + expect(import_state.errors[:jid]).to include "can't be blank" + end + + it 'cannot be finished without a jid' do + import_state = build(:group_import_state, :finished, group: group, jid: nil) + + expect(import_state).not_to be_valid + expect(import_state.errors[:jid]).to include "can't be blank" + end + + it 'can fail without a jid' do + import_state = build(:group_import_state, :failed, group: group, jid: nil) + + expect(import_state).to be_valid + end + end + + describe '#in_progress?' do + context "when the import is 'created'" do + it "returns true" do + group_import_state = build(:group_import_state, :created) + + expect(group_import_state.in_progress?).to eq true + end + end + + context "when the import is 'started'" do + it "returns true" do + group_import_state = build(:group_import_state, :started) + + expect(group_import_state.in_progress?).to eq true + end + end + + context "when the import is 'finished'" do + it "returns false" do + group_import_state = build(:group_import_state, :finished) + + expect(group_import_state.in_progress?).to eq false + end + end + + context "when the import is 'failed'" do + it "returns false" do + group_import_state = build(:group_import_state, :failed) + + expect(group_import_state.in_progress?).to eq false + end + end + end +end |