pages_domains_controller_spec.rb 3.69 KB
Newer Older
1 2 3
require 'spec_helper'

describe Projects::PagesDomainsController do
4
  let(:user) { create(:user) }
5
  let(:project) { create(:project) }
6
  let!(:pages_domain) { create(:pages_domain, project: project) }
7 8 9 10 11 12 13 14

  let(:request_params) do
    {
      namespace_id: project.namespace,
      project_id: project
    }
  end

15 16 17 18
  let(:pages_domain_params) do
    build(:pages_domain, :with_certificate, :with_key, domain: 'my.otherdomain.com').slice(:key, :certificate, :domain)
  end

19
  before do
20
    allow(Gitlab.config.pages).to receive(:enabled).and_return(true)
21
    sign_in(user)
22
    project.add_master(user)
23 24 25 26 27 28
  end

  describe 'GET show' do
    it "displays the 'show' page" do
      get(:show, request_params.merge(id: pages_domain.domain))

29
      expect(response).to have_gitlab_http_status(200)
30 31 32 33 34 35 36 37
      expect(response).to render_template('show')
    end
  end

  describe 'GET new' do
    it "displays the 'new' page" do
      get(:new, request_params)

38
      expect(response).to have_gitlab_http_status(200)
39 40 41 42 43 44 45 46 47 48
      expect(response).to render_template('new')
    end
  end

  describe 'POST create' do
    it "creates a new pages domain" do
      expect do
        post(:create, request_params.merge(pages_domain: pages_domain_params))
      end.to change { PagesDomain.count }.by(1)

49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88
      created_domain = PagesDomain.reorder(:id).last

      expect(created_domain).to be_present
      expect(response).to redirect_to(project_pages_domain_path(project, created_domain))
    end
  end

  describe 'POST verify' do
    let(:params) { request_params.merge(id: pages_domain.domain) }

    def stub_service
      service = double(:service)

      expect(VerifyPagesDomainService).to receive(:new) { service }

      service
    end

    it 'handles verification success' do
      expect(stub_service).to receive(:execute).and_return(status: :success)

      post :verify, params

      expect(response).to redirect_to project_pages_domain_path(project, pages_domain)
      expect(flash[:notice]).to eq('Successfully verified domain ownership')
    end

    it 'handles verification failure' do
      expect(stub_service).to receive(:execute).and_return(status: :failed)

      post :verify, params

      expect(response).to redirect_to project_pages_domain_path(project, pages_domain)
      expect(flash[:alert]).to eq('Failed to verify domain ownership')
    end

    it 'returns a 404 response for an unknown domain' do
      post :verify, request_params.merge(id: 'unknown-domain')

      expect(response).to have_gitlab_http_status(404)
89 90 91 92 93 94 95 96 97
    end
  end

  describe 'DELETE destroy' do
    it "deletes the pages domain" do
      expect do
        delete(:destroy, request_params.merge(id: pages_domain.domain))
      end.to change { PagesDomain.count }.by(-1)

98
      expect(response).to redirect_to(project_pages_path(project))
99 100
    end
  end
101 102 103 104 105 106 107 108 109 110

  context 'pages disabled' do
    before do
      allow(Gitlab.config.pages).to receive(:enabled).and_return(false)
    end

    describe 'GET show' do
      it 'returns 404 status' do
        get(:show, request_params.merge(id: pages_domain.domain))

111
        expect(response).to have_gitlab_http_status(404)
112 113 114 115 116 117 118
      end
    end

    describe 'GET new' do
      it 'returns 404 status' do
        get :new, request_params

119
        expect(response).to have_gitlab_http_status(404)
120 121 122 123 124 125 126
      end
    end

    describe 'POST create' do
      it "returns 404 status" do
        post(:create, request_params.merge(pages_domain: pages_domain_params))

127
        expect(response).to have_gitlab_http_status(404)
128 129 130 131 132 133 134
      end
    end

    describe 'DELETE destroy' do
      it "deletes the pages domain" do
        delete(:destroy, request_params.merge(id: pages_domain.domain))

135
        expect(response).to have_gitlab_http_status(404)
136 137 138
      end
    end
  end
139
end