diff options
Diffstat (limited to 'spec/models/project_spec.rb')
-rw-r--r-- | spec/models/project_spec.rb | 360 |
1 files changed, 0 insertions, 360 deletions
diff --git a/spec/models/project_spec.rb b/spec/models/project_spec.rb deleted file mode 100644 index 879a63dd9f9..00000000000 --- a/spec/models/project_spec.rb +++ /dev/null @@ -1,360 +0,0 @@ -# == Schema Information -# -# Table name: projects -# -# id :integer not null, primary key -# name :string(255) -# path :string(255) -# description :text -# created_at :datetime -# updated_at :datetime -# creator_id :integer -# issues_enabled :boolean default(TRUE), not null -# wall_enabled :boolean default(TRUE), not null -# merge_requests_enabled :boolean default(TRUE), not null -# wiki_enabled :boolean default(TRUE), not null -# namespace_id :integer -# issues_tracker :string(255) default("gitlab"), not null -# issues_tracker_id :string(255) -# snippets_enabled :boolean default(TRUE), not null -# last_activity_at :datetime -# import_url :string(255) -# visibility_level :integer default(0), not null -# archived :boolean default(FALSE), not null -# import_status :string(255) -# repository_size :float default(0.0) -# star_count :integer default(0), not null -# import_type :string(255) -# import_source :string(255) -# avatar :string(255) -# - -require 'spec_helper' - -describe Project do - describe 'Associations' do - it { is_expected.to belong_to(:group) } - it { is_expected.to belong_to(:namespace) } - it { is_expected.to belong_to(:creator).class_name('User') } - it { is_expected.to have_many(:users) } - it { is_expected.to have_many(:events).dependent(:destroy) } - it { is_expected.to have_many(:merge_requests).dependent(:destroy) } - it { is_expected.to have_many(:issues).dependent(:destroy) } - it { is_expected.to have_many(:milestones).dependent(:destroy) } - it { is_expected.to have_many(:project_members).dependent(:destroy) } - it { is_expected.to have_many(:notes).dependent(:destroy) } - it { is_expected.to have_many(:snippets).class_name('ProjectSnippet').dependent(:destroy) } - it { is_expected.to have_many(:deploy_keys_projects).dependent(:destroy) } - it { is_expected.to have_many(:deploy_keys) } - it { is_expected.to have_many(:hooks).dependent(:destroy) } - it { is_expected.to have_many(:protected_branches).dependent(:destroy) } - it { is_expected.to have_one(:forked_project_link).dependent(:destroy) } - it { is_expected.to have_one(:slack_service).dependent(:destroy) } - it { is_expected.to have_one(:pushover_service).dependent(:destroy) } - it { is_expected.to have_one(:asana_service).dependent(:destroy) } - end - - describe 'Mass assignment' do - end - - describe 'Validation' do - let!(:project) { create(:project) } - - it { is_expected.to validate_presence_of(:name) } - it { is_expected.to validate_uniqueness_of(:name).scoped_to(:namespace_id) } - it { is_expected.to ensure_length_of(:name).is_within(0..255) } - - it { is_expected.to validate_presence_of(:path) } - it { is_expected.to validate_uniqueness_of(:path).scoped_to(:namespace_id) } - it { is_expected.to ensure_length_of(:path).is_within(0..255) } - it { is_expected.to ensure_length_of(:description).is_within(0..2000) } - it { is_expected.to validate_presence_of(:creator) } - it { is_expected.to ensure_length_of(:issues_tracker_id).is_within(0..255) } - it { is_expected.to validate_presence_of(:namespace) } - - it 'should not allow new projects beyond user limits' do - project2 = build(:project) - allow(project2).to receive(:creator).and_return(double(can_create_project?: false, projects_limit: 0).as_null_object) - expect(project2).not_to be_valid - expect(project2.errors[:limit_reached].first).to match(/Your project limit is 0/) - end - end - - describe 'Respond to' do - it { is_expected.to respond_to(:url_to_repo) } - it { is_expected.to respond_to(:repo_exists?) } - it { is_expected.to respond_to(:satellite) } - it { is_expected.to respond_to(:update_merge_requests) } - it { is_expected.to respond_to(:execute_hooks) } - it { is_expected.to respond_to(:name_with_namespace) } - it { is_expected.to respond_to(:owner) } - it { is_expected.to respond_to(:path_with_namespace) } - end - - it 'should return valid url to repo' do - project = Project.new(path: 'somewhere') - expect(project.url_to_repo).to eq(Gitlab.config.gitlab_shell.ssh_path_prefix + 'somewhere.git') - end - - it 'returns the full web URL for this repo' do - project = Project.new(path: 'somewhere') - expect(project.web_url).to eq("#{Gitlab.config.gitlab.url}/somewhere") - end - - it 'returns the web URL without the protocol for this repo' do - project = Project.new(path: 'somewhere') - expect(project.web_url_without_protocol).to eq("#{Gitlab.config.gitlab.url.split('://')[1]}/somewhere") - end - - describe 'last_activity methods' do - let(:project) { create(:project) } - let(:last_event) { double(created_at: Time.now) } - - describe 'last_activity' do - it 'should alias last_activity to last_event' do - project.stub(last_event: last_event) - expect(project.last_activity).to eq(last_event) - end - end - - describe 'last_activity_date' do - it 'returns the creation date of the project\'s last event if present' do - last_activity_event = create(:event, project: project) - expect(project.last_activity_at.to_i).to eq(last_event.created_at.to_i) - end - - it 'returns the project\'s last update date if it has no events' do - expect(project.last_activity_date).to eq(project.updated_at) - end - end - end - - describe :update_merge_requests do - let(:project) { create(:project) } - let(:merge_request) { create(:merge_request, source_project: project, target_project: project) } - let(:key) { create(:key, user_id: project.owner.id) } - let(:prev_commit_id) { merge_request.commits.last.id } - let(:commit_id) { merge_request.commits.first.id } - - it 'should close merge request if last commit from source branch was pushed to target branch' do - project.update_merge_requests(prev_commit_id, commit_id, "refs/heads/#{merge_request.target_branch}", key.user) - merge_request.reload - expect(merge_request.merged?).to be_truthy - end - - it 'should update merge request commits with new one if pushed to source branch' do - project.update_merge_requests(prev_commit_id, commit_id, "refs/heads/#{merge_request.source_branch}", key.user) - merge_request.reload - expect(merge_request.last_commit.id).to eq(commit_id) - end - end - - describe :find_with_namespace do - context 'with namespace' do - before do - @group = create :group, name: 'gitlab' - @project = create(:project, name: 'gitlabhq', namespace: @group) - end - - it { expect(Project.find_with_namespace('gitlab/gitlabhq')).to eq(@project) } - it { expect(Project.find_with_namespace('gitlab-ci')).to be_nil } - end - end - - describe :to_param do - context 'with namespace' do - before do - @group = create :group, name: 'gitlab' - @project = create(:project, name: 'gitlabhq', namespace: @group) - end - - it { expect(@project.to_param).to eq('gitlabhq') } - end - end - - describe :repository do - let(:project) { create(:project) } - - it 'should return valid repo' do - expect(project.repository).to be_kind_of(Repository) - end - end - - describe :issue_exists? do - let(:project) { create(:project) } - let(:existed_issue) { create(:issue, project: project) } - let(:not_existed_issue) { create(:issue) } - let(:ext_project) { create(:redmine_project) } - - it 'should be true or if used internal tracker and issue exists' do - expect(project.issue_exists?(existed_issue.iid)).to be_truthy - end - - it 'should be false or if used internal tracker and issue not exists' do - expect(project.issue_exists?(not_existed_issue.iid)).to be_falsey - end - - it 'should always be true if used other tracker' do - expect(ext_project.issue_exists?(rand(100))).to be_truthy - end - end - - describe :default_issues_tracker? do - let(:project) { create(:project) } - let(:ext_project) { create(:redmine_project) } - - it "should be true if used internal tracker" do - expect(project.default_issues_tracker?).to be_truthy - end - - it "should be false if used other tracker" do - expect(ext_project.default_issues_tracker?).to be_falsey - end - end - - describe :can_have_issues_tracker_id? do - let(:project) { create(:project) } - let(:ext_project) { create(:redmine_project) } - - it 'should be true for projects with external issues tracker if issues enabled' do - expect(ext_project.can_have_issues_tracker_id?).to be_truthy - end - - it 'should be false for projects with internal issue tracker if issues enabled' do - expect(project.can_have_issues_tracker_id?).to be_falsey - end - - it 'should be always false if issues disabled' do - project.issues_enabled = false - ext_project.issues_enabled = false - - expect(project.can_have_issues_tracker_id?).to be_falsey - expect(ext_project.can_have_issues_tracker_id?).to be_falsey - end - end - - describe :open_branches do - let(:project) { create(:project) } - - before do - project.protected_branches.create(name: 'master') - end - - it { expect(project.open_branches.map(&:name)).to include('feature') } - it { expect(project.open_branches.map(&:name)).not_to include('master') } - end - - describe '#star_count' do - it 'counts stars from multiple users' do - user1 = create :user - user2 = create :user - project = create :project, :public - - expect(project.star_count).to eq(0) - - user1.toggle_star(project) - expect(project.reload.star_count).to eq(1) - - user2.toggle_star(project) - project.reload - expect(project.reload.star_count).to eq(2) - - user1.toggle_star(project) - project.reload - expect(project.reload.star_count).to eq(1) - - user2.toggle_star(project) - project.reload - expect(project.reload.star_count).to eq(0) - end - - it 'counts stars on the right project' do - user = create :user - project1 = create :project, :public - project2 = create :project, :public - - expect(project1.star_count).to eq(0) - expect(project2.star_count).to eq(0) - - user.toggle_star(project1) - project1.reload - project2.reload - expect(project1.star_count).to eq(1) - expect(project2.star_count).to eq(0) - - user.toggle_star(project1) - project1.reload - project2.reload - expect(project1.star_count).to eq(0) - expect(project2.star_count).to eq(0) - - user.toggle_star(project2) - project1.reload - project2.reload - expect(project1.star_count).to eq(0) - expect(project2.star_count).to eq(1) - - user.toggle_star(project2) - project1.reload - project2.reload - expect(project1.star_count).to eq(0) - expect(project2.star_count).to eq(0) - end - - it 'is decremented when an upvoter account is deleted' do - user = create :user - project = create :project, :public - user.toggle_star(project) - project.reload - expect(project.star_count).to eq(1) - user.destroy - project.reload - expect(project.star_count).to eq(0) - end - end - - describe :avatar_type do - let(:project) { create(:project) } - - it 'should be true if avatar is image' do - project.update_attribute(:avatar, 'uploads/avatar.png') - expect(project.avatar_type).to be_truthy - end - - it 'should be false if avatar is html page' do - project.update_attribute(:avatar, 'uploads/avatar.html') - expect(project.avatar_type).to eq(['only images allowed']) - end - end - - describe :avatar_url do - subject { project.avatar_url } - - let(:project) { create(:project) } - - context 'When avatar file is uploaded' do - before do - project.update_columns(avatar: 'uploads/avatar.png') - allow(project.avatar).to receive(:present?) { true } - end - - let(:avatar_path) do - "/uploads/project/avatar/#{project.id}/uploads/avatar.png" - end - - it { should eq "http://localhost#{avatar_path}" } - end - - context 'When avatar file in git' do - before do - allow(project).to receive(:avatar_in_git) { true } - end - - let(:avatar_path) do - "/#{project.namespace.name}/#{project.path}/avatar" - end - - it { should eq "http://localhost#{avatar_path}" } - end - end -end |