summaryrefslogtreecommitdiff
path: root/spec/requests/api/commits_spec.rb
blob: 99cdbc37c314c9146c3a4738c6b2484cf958339c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
require 'spec_helper'

describe API::API, 'Commits' do
  include ApiHelpers

  let(:project) { FactoryGirl.create(:project) }
  let(:commit) { FactoryGirl.create(:commit, project: project) }

  let(:options) {
    {
      project_token: project.token,
      project_id: project.id
    }
  }

  describe "GET /commits" do
    before { commit }

    it "should return commits per project" do
      get api("/commits"), options

      expect(response.status).to eq 200
      expect(json_response.count).to eq 1
      expect(json_response.first["project_id"]).to eq project.id
      expect(json_response.first["sha"]).to eq commit.sha
    end
  end

  describe "POST /commits" do
    let(:data) {
      {
        "before" => "95790bf891e76fee5e1747ab589903a6a1f80f22",
        "after" => "da1560886d4f094c3e6c9ef40349f7d38b5d27d7",
        "ref" => "refs/heads/master",
        "commits" => [
          {
            "id" => "b6568db1bc1dcd7f8b4d5a946b0b91f9dacd7327",
            "message" => "Update Catalan translation to e38cb41.",
            "timestamp" => "2011-12-12T14:27:31+02:00",
            "url" => "http://localhost/diaspora/commits/b6568db1bc1dcd7f8b4d5a946b0b91f9dacd7327",
            "author" => {
              "name" => "Jordi Mallach",
              "email" => "jordi@softcatala.org",
            }
          }
        ],
        ci_yaml_file: gitlab_ci_yaml
      }
    }

    it "should create a build" do
      post api("/commits"), options.merge(data: data)

      expect(response.status).to eq 201
      expect(json_response['sha']).to eq "da1560886d4f094c3e6c9ef40349f7d38b5d27d7"
    end

    it "should return 400 error if no data passed" do
      post api("/commits"), options

      expect(response.status).to eq 400
      expect(json_response['message']).to eq "400 (Bad request) \"data\" not given"
    end
  end
end