user_searches_for_code_spec.rb 4.1 KB
Newer Older
1 2
# frozen_string_literal: true

3 4 5 6 7 8 9 10
require 'spec_helper'

describe 'User searches for code' do
  let(:user) { create(:user) }
  let(:project) { create(:project, :repository, namespace: user.namespace) }

  context 'when signed in' do
    before do
11
      project.add_maintainer(user)
12 13 14 15 16 17
      sign_in(user)
    end

    it 'finds a file' do
      visit(project_path(project))

18
      submit_search('application.js')
M
Markus Koller 已提交
19
      select_search_scope('Code')
20

M
Markus Koller 已提交
21
      expect(page).to have_selector('.results', text: 'application.js')
22 23 24 25 26 27 28
      expect(page).to have_selector('.file-content .code')
      expect(page).to have_selector("span.line[lang='javascript']")
    end

    context 'when on a project page', :js do
      before do
        visit(search_path)
29
        find('.js-search-project-dropdown').click
30 31

        page.within('.project-filter') do
32
          click_link(project.full_name)
33
        end
34
      end
35

36 37 38
      include_examples 'top right search form'

      it 'finds code' do
39
        fill_in('dashboard_search', with: 'rspec')
40
        find('.btn-search').click
41

M
Markus Koller 已提交
42
        expect(page).to have_selector('.results', text: 'Update capybara, rspec-rails, poltergeist to recent versions')
43
      end
44 45 46 47 48 49 50 51

      it 'search mutiple words with refs switching' do
        expected_result = 'Use `snake_case` for naming files'
        search = 'for naming files'

        fill_in('dashboard_search', with: search)
        find('.btn-search').click

M
Markus Koller 已提交
52
        expect(page).to have_selector('.results', text: expected_result)
53 54 55 56

        find('.js-project-refs-dropdown').click
        find('.dropdown-page-one .dropdown-content').click_link('v1.0.0')

M
Markus Koller 已提交
57
        expect(page).to have_selector('.results', text: expected_result)
58 59 60

        expect(find_field('dashboard_search').value).to eq(search)
      end
61
    end
62 63 64 65 66 67

    context 'search code within refs', :js do
      let(:ref_name) { 'v1.0.0' }

      before do
        visit(project_tree_path(project, ref_name))
M
Markus Koller 已提交
68 69 70

        submit_search('gitlab-grack')
        select_search_scope('Code')
71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89
      end

      it 'shows ref switcher in code result summary' do
        expect(find('.js-project-refs-dropdown')).to have_text(ref_name)
      end
      it 'persists branch name across search' do
        find('.btn-search').click
        expect(find('.js-project-refs-dropdown')).to have_text(ref_name)
      end

      #  this example is use to test the desgine that the refs is not
      #  only repersent the branch as well as the tags.
      it 'ref swither list all the branchs and tags' do
        find('.js-project-refs-dropdown').click
        expect(find('.dropdown-page-one .dropdown-content')).to have_link('sha-starting-with-large-number')
        expect(find('.dropdown-page-one .dropdown-content')).to have_link('v1.0.0')
      end

      it 'search result changes when refs switched' do
M
Markus Koller 已提交
90 91
        expect(find('.results')).not_to have_content('path = gitlab-grack')

92 93
        find('.js-project-refs-dropdown').click
        find('.dropdown-page-one .dropdown-content').click_link('master')
M
Markus Koller 已提交
94 95

        expect(page).to have_selector('.results', text: 'path = gitlab-grack')
96
      end
97 98 99 100 101 102 103

      it 'persist refs over browser tabs' do
        ref = 'feature'
        find('.js-project-refs-dropdown').click
        link = find_link(ref)[:href]
        expect(link.include?("repository_ref=" + ref)).to be(true)
      end
104 105 106 107 108
    end

    it 'no ref switcher shown in issue result summary', :js do
      issue = create(:issue, title: 'test', project: project)
      visit(project_tree_path(project))
M
Markus Koller 已提交
109 110 111 112

      submit_search('test')
      select_search_scope('Code')

113
      expect(page).to have_selector('.js-project-refs-dropdown')
M
Markus Koller 已提交
114 115 116 117

      select_search_scope('Issues')

      expect(find(:css, '.results')).to have_link(issue.title)
118 119
      expect(page).not_to have_selector('.js-project-refs-dropdown')
    end
120 121 122 123 124 125 126 127 128 129
  end

  context 'when signed out' do
    let(:project) { create(:project, :public, :repository) }

    before do
      visit(project_path(project))
    end

    it 'finds code' do
130
      submit_search('rspec')
M
Markus Koller 已提交
131
      select_search_scope('Code')
132

M
Markus Koller 已提交
133
      expect(page).to have_selector('.results', text: 'Update capybara, rspec-rails, poltergeist to recent versions')
134 135 136
    end
  end
end