diff options
| -rw-r--r-- | app/helpers/issuables_helper.rb | 12 | ||||
| -rw-r--r-- | app/models/repository.rb | 17 | ||||
| -rw-r--r-- | changelogs/unreleased/cache-issuable-template-names.yml | 5 | ||||
| -rw-r--r-- | lib/gitlab/file_detector.rb | 2 | ||||
| -rw-r--r-- | spec/lib/gitlab/file_detector_spec.rb | 8 | ||||
| -rw-r--r-- | spec/models/repository_spec.rb | 4 | 
6 files changed, 35 insertions, 13 deletions
| diff --git a/app/helpers/issuables_helper.rb b/app/helpers/issuables_helper.rb index 7713fb0b9f8..baa2d6e375e 100644 --- a/app/helpers/issuables_helper.rb +++ b/app/helpers/issuables_helper.rb @@ -314,20 +314,12 @@ module IssuablesHelper      @issuable_templates ||=        case issuable        when Issue -        issue_template_names +        ref_project.repository.issue_template_names        when MergeRequest -        merge_request_template_names +        ref_project.repository.merge_request_template_names        end    end -  def merge_request_template_names -    @merge_request_templates ||= Gitlab::Template::MergeRequestTemplate.dropdown_names(ref_project) -  end - -  def issue_template_names -    @issue_templates ||= Gitlab::Template::IssueTemplate.dropdown_names(ref_project) -  end -    def selected_template(issuable)      params[:issuable_template] if issuable_templates(issuable).any? { |template| template[:name] == params[:issuable_template] }    end diff --git a/app/models/repository.rb b/app/models/repository.rb index d725c65081d..bf526ca1762 100644 --- a/app/models/repository.rb +++ b/app/models/repository.rb @@ -34,7 +34,8 @@ class Repository    CACHED_METHODS = %i(size commit_count rendered_readme contribution_guide                        changelog license_blob license_key gitignore koding_yml                        gitlab_ci_yml branch_names tag_names branch_count -                      tag_count avatar exists? empty? root_ref has_visible_content?).freeze +                      tag_count avatar exists? empty? root_ref has_visible_content? +                      issue_template_names merge_request_template_names).freeze    # Methods that use cache_method but only memoize the value    MEMOIZED_CACHED_METHODS = %i(license empty_repo?).freeze @@ -50,7 +51,9 @@ class Repository      gitignore: :gitignore,      koding: :koding_yml,      gitlab_ci: :gitlab_ci_yml, -    avatar: :avatar +    avatar: :avatar, +    issue_template: :issue_template_names, +    merge_request_template: :merge_request_template_names    }.freeze    # Wraps around the given method and caches its output in Redis and an instance @@ -535,6 +538,16 @@ class Repository    end    cache_method :avatar +  def issue_template_names +    Gitlab::Template::IssueTemplate.dropdown_names(project) +  end +  cache_method :issue_template_names, fallback: [] + +  def merge_request_template_names +    Gitlab::Template::MergeRequestTemplate.dropdown_names(project) +  end +  cache_method :merge_request_template_names, fallback: [] +    def readme      if readme = tree(:head)&.readme        ReadmeBlob.new(readme, self) diff --git a/changelogs/unreleased/cache-issuable-template-names.yml b/changelogs/unreleased/cache-issuable-template-names.yml new file mode 100644 index 00000000000..858fdff2db2 --- /dev/null +++ b/changelogs/unreleased/cache-issuable-template-names.yml @@ -0,0 +1,5 @@ +--- +title: Cache issue and MR template names in Redis +merge_request: +author: +type: other diff --git a/lib/gitlab/file_detector.rb b/lib/gitlab/file_detector.rb index 1fa1399c531..0e9ef4f897c 100644 --- a/lib/gitlab/file_detector.rb +++ b/lib/gitlab/file_detector.rb @@ -12,6 +12,8 @@ module Gitlab        contributing: /\Acontributing[^\/]*\z/i,        version: 'version',        avatar: /\Alogo\.(png|jpg|gif)\z/, +      issue_template: /\A\.gitlab\/issue_templates\/[^\/]+\.md\z/, +      merge_request_template: /\A\.gitlab\/merge_request_templates\/[^\/]+\.md\z/,        # Configuration files        gitignore: '.gitignore', diff --git a/spec/lib/gitlab/file_detector_spec.rb b/spec/lib/gitlab/file_detector_spec.rb index b5ac07c94fa..8e524f9b05a 100644 --- a/spec/lib/gitlab/file_detector_spec.rb +++ b/spec/lib/gitlab/file_detector_spec.rb @@ -56,6 +56,14 @@ describe Gitlab::FileDetector do        end      end +    it 'returns the type of an issue template' do +      expect(described_class.type_of('.gitlab/issue_templates/foo.md')).to eq(:issue_template) +    end + +    it 'returns the type of a merge request template' do +      expect(described_class.type_of('.gitlab/merge_request_templates/foo.md')).to eq(:merge_request_template) +    end +      it 'returns nil for an unknown file' do        expect(described_class.type_of('foo.txt')).to be_nil      end diff --git a/spec/models/repository_spec.rb b/spec/models/repository_spec.rb index 5d78aed5b4f..f44693a71bb 100644 --- a/spec/models/repository_spec.rb +++ b/spec/models/repository_spec.rb @@ -1509,7 +1509,9 @@ describe Repository do          :gitignore,          :koding,          :gitlab_ci, -        :avatar +        :avatar, +        :issue_template, +        :merge_request_template        ])        repository.after_change_head | 
