forks_spec.rb 1.34 KB
Newer Older
1 2
require 'spec_helper'

Dmitriy Zaporozhets's avatar
Dmitriy Zaporozhets committed
3
describe Ci::API::API do
4 5
  include ApiHelpers

6
  let(:project) { FactoryGirl.create(:ci_project) }
Valery Sizov's avatar
Valery Sizov committed
7
  let(:private_token) { create(:user).private_token }
8

Valery Sizov's avatar
Valery Sizov committed
9
  let(:options) do
10 11
    {
      private_token: private_token,
Valery Sizov's avatar
Valery Sizov committed
12
      url: GitlabCi.config.gitlab_ci.url
13
    }
Valery Sizov's avatar
Valery Sizov committed
14
  end
15

Valery Sizov's avatar
Valery Sizov committed
16
  before do
17
    stub_gitlab_calls
Valery Sizov's avatar
Valery Sizov committed
18
  end
19 20 21


  describe "POST /forks" do
Valery Sizov's avatar
Valery Sizov committed
22
    let(:project_info) do
23 24 25 26
      {
        project_id: project.gitlab_id,
        project_token: project.token,
        data: {
Valery Sizov's avatar
Valery Sizov committed
27
          id:                  create(:empty_project).id,
28 29 30 31 32 33
          name_with_namespace: "Gitlab.org / Underscore",
          path_with_namespace: "gitlab-org/underscore",
          default_branch:      "master",
          ssh_url_to_repo:     "git@example.com:gitlab-org/underscore"
        }
      }
Valery Sizov's avatar
Valery Sizov committed
34
    end
35 36 37 38 39 40 41

    context "with valid info" do
      before do
        options.merge!(project_info)
      end

      it "should create a project with valid data" do
Valery Sizov's avatar
Valery Sizov committed
42
        post ci_api("/forks"), options
43 44
        expect(response.status).to eq(201)
        expect(json_response['name']).to eq("Gitlab.org / Underscore")
45 46 47 48 49 50 51 52 53
      end
    end

    context "with invalid project info" do
      before do
        options.merge!({})
      end

      it "should error with invalid data" do
Valery Sizov's avatar
Valery Sizov committed
54
        post ci_api("/forks"), options
55
        expect(response.status).to eq(400)
56 57 58 59
      end
    end
  end
end