repositories_spec.rb 5.86 KB
Newer Older
1
require 'spec_helper'
2
require 'mime/types'
3

Jeroen van Baarsen's avatar
Jeroen van Baarsen committed
4
describe API::API, api: true  do
5 6
  include ApiHelpers
  before(:each) { enable_observers }
7
  after(:each) {disable_observers}
8 9

  let(:user) { create(:user) }
10
  let(:user2) { create(:user) }
Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
11
  let!(:project) { create(:project, creator_id: user.id) }
12 13
  let!(:master) { create(:users_project, user: user, project: project, project_access: UsersProject::MASTER) }
  let!(:guest) { create(:users_project, user: user2, project: project, project_access: UsersProject::GUEST) }
14 15 16 17 18 19 20 21 22 23 24 25

  before { project.team << [user, :reporter] }

  describe "GET /projects/:id/repository/tags" do
    it "should return an array of project tags" do
      get api("/projects/#{project.id}/repository/tags", user)
      response.status.should == 200
      json_response.should be_an Array
      json_response.first['name'].should == project.repo.tags.sort_by(&:name).reverse.first.name
    end
  end

26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48
  describe "GET /projects/:id/repository/tree" do
    context "authorized user" do
      before { project.team << [user2, :reporter] }

      it "should return project commits" do
        get api("/projects/#{project.id}/repository/tree", user)
        response.status.should == 200

        json_response.should be_an Array
        json_response.first['name'].should == 'app'
        json_response.first['type'].should == 'tree'
        json_response.first['mode'].should == '040000'
      end
    end

    context "unauthorized user" do
      it "should not return project commits" do
        get api("/projects/#{project.id}/repository/tree")
        response.status.should == 401
      end
    end
  end

49
  describe "GET /projects/:id/repository/blobs/:sha" do
50
    it "should get the raw file contents" do
51
      get api("/projects/#{project.id}/repository/blobs/master?filepath=README.md", user)
52 53 54 55
      response.status.should == 200
    end

    it "should return 404 for invalid branch_name" do
56
      get api("/projects/#{project.id}/repository/blobs/invalid_branch_name?filepath=README.md", user)
57 58 59 60
      response.status.should == 404
    end

    it "should return 404 for invalid file" do
61
      get api("/projects/#{project.id}/repository/blobs/master?filepath=README.invalid", user)
62 63 64 65
      response.status.should == 404
    end

    it "should return a 400 error if filepath is missing" do
66
      get api("/projects/#{project.id}/repository/blobs/master", user)
67 68 69
      response.status.should == 400
    end
  end
70 71 72 73 74 75 76 77

  describe "GET /projects/:id/repository/commits/:sha/blob" do
    it "should get the raw file contents" do
      get api("/projects/#{project.id}/repository/commits/master/blob?filepath=README.md", user)
      response.status.should == 200
    end
  end

78 79 80 81 82 83 84
  describe "GET /projects/:id/repository/raw_blobs/:sha" do
    it "should get the raw file contents" do
      get api("/projects/#{project.id}/repository/raw_blobs/d1aff2896d99d7acc4d9780fbb716b113c45ecf7", user)
      response.status.should == 200
    end
  end

85
  describe "GET /projects/:id/repository/archive(.:format)?:sha" do
86 87
    it "should get the archive" do
      get api("/projects/#{project.id}/repository/archive", user)
88
      repo_name = project.repository.name.gsub("\.git", "")
89
      response.status.should == 200
90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106 107
      response.headers['Content-Disposition'].should =~ /filename\=\"#{repo_name}\-[^\.]+\.tar.gz\"/
      response.content_type.should == MIME::Types.type_for('file.tar.gz').first.content_type
    end

    it "should get the archive.zip" do
      get api("/projects/#{project.id}/repository/archive.zip", user)
      repo_name = project.repository.name.gsub("\.git", "")
      response.status.should == 200
      response.headers['Content-Disposition'].should =~ /filename\=\"#{repo_name}\-[^\.]+\.zip\"/
      response.content_type.should == MIME::Types.type_for('file.zip').first.content_type
    end

    it "should get the archive.tar.bz2" do
      get api("/projects/#{project.id}/repository/archive.tar.bz2", user)
      repo_name = project.repository.name.gsub("\.git", "")
      response.status.should == 200
      response.headers['Content-Disposition'].should =~ /filename\=\"#{repo_name}\-[^\.]+\.tar.bz2\"/
      response.content_type.should == MIME::Types.type_for('file.tar.bz2').first.content_type
108 109 110 111 112 113 114
    end

    it "should return 404 for invalid sha" do
      get api("/projects/#{project.id}/repository/archive/?sha=xxx", user)
      response.status.should == 404
    end
  end
115 116

  describe 'GET /GET /projects/:id/repository/compare' do
117
    it "should compare branches" do
118 119
      get api("/projects/#{project.id}/repository/compare", user), from: 'master', to: 'simple_merge_request'
      response.status.should == 200
120 121
      json_response['commits'].should be_present
      json_response['diffs'].should be_present
122 123
    end

124 125 126 127 128 129 130 131
    it "should compare tags" do
      get api("/projects/#{project.id}/repository/compare", user), from: 'v1.0.1', to: 'v1.0.2'
      response.status.should == 200
      json_response['commits'].should be_present
      json_response['diffs'].should be_present
    end

    it "should compare commits" do
132 133
      get api("/projects/#{project.id}/repository/compare", user), from: 'b1e6a9dbf1c85', to: '1e689bfba395'
      response.status.should == 200
134 135 136
      json_response['commits'].should be_empty
      json_response['diffs'].should be_empty
      json_response['compare_same_ref'].should be_false
137 138
    end

139
    it "should compare commits in reverse order" do
140 141
      get api("/projects/#{project.id}/repository/compare", user), from: '1e689bfba395', to: 'b1e6a9dbf1c85'
      response.status.should == 200
142 143 144 145 146 147 148 149 150 151
      json_response['commits'].should be_present
      json_response['diffs'].should be_present
    end

    it "should compare same refs" do
      get api("/projects/#{project.id}/repository/compare", user), from: 'master', to: 'master'
      response.status.should == 200
      json_response['commits'].should be_empty
      json_response['diffs'].should be_empty
      json_response['compare_same_ref'].should be_true
152 153
    end
  end
154
end