An error occurred fetching the project authors.
  1. 27 Jul, 2017 4 commits
  2. 17 Jul, 2017 1 commit
    • Lin Jen-Shin's avatar
      Use RequestStoreWrap for Commit#author · aada5273
      Lin Jen-Shin authored
      We also try to use instance variable to cache the result if
      RequestStore is not available, so we could keep the same logic,
      using the same cache key. Also introduce a way to specify method
      specific cache key
      aada5273
  3. 14 Jun, 2017 1 commit
  4. 09 Jun, 2017 2 commits
  5. 13 May, 2017 1 commit
  6. 12 May, 2017 1 commit
  7. 11 May, 2017 1 commit
  8. 07 May, 2017 1 commit
  9. 02 May, 2017 1 commit
  10. 11 Apr, 2017 1 commit
  11. 16 Mar, 2017 1 commit
  12. 15 Mar, 2017 1 commit
  13. 26 Jan, 2017 1 commit
  14. 24 Jan, 2017 1 commit
  15. 19 Jan, 2017 1 commit
  16. 15 Dec, 2016 2 commits
  17. 14 Dec, 2016 1 commit
  18. 09 Dec, 2016 1 commit
  19. 02 Dec, 2016 1 commit
  20. 01 Dec, 2016 1 commit
    • Yorick Peterse's avatar
      Pass commit data to ProcessCommitWorker · 6b4d3356
      Yorick Peterse authored
      By passing commit data to this worker we remove the need for querying
      the Git repository for every job. This in turn reduces the time spent
      processing each job.
      
      The migration included migrates jobs from the old format to the new
      format. For this to work properly it requires downtime as otherwise
      workers may start producing errors until they're using a newer version
      of the worker code.
      6b4d3356
  21. 24 Nov, 2016 1 commit
  22. 23 Nov, 2016 1 commit
  23. 21 Nov, 2016 1 commit
  24. 07 Nov, 2016 1 commit
  25. 03 Nov, 2016 2 commits
  26. 27 Oct, 2016 1 commit
  27. 11 Oct, 2016 1 commit
  28. 02 Aug, 2016 1 commit
  29. 27 Jul, 2016 1 commit
  30. 26 Jul, 2016 1 commit
  31. 21 Jun, 2016 1 commit
    • Alejandro Rodríguez's avatar
      Optimize Banzai::Filter::RelativeLinkFilter · ca696175
      Alejandro Rodríguez authored
          A lot of git operations were being repeated, for example, to build a url
          you would ask if the path was a Tree, which would call a recursive routine
          in Gitlab::Git::Tree#where, then ask if the path was a Blob, which would
          call a recursive routine at Gitlab::Git::Blob#find, making reference to
          the same git objects several times. Now we call Rugged::Tree#path, which
          allows us to determine the type of the path in one pass.
      
          Some other minor improvement added, like saving commonly used references
          instead of calculating them each time.
      ca696175
  32. 03 Jun, 2016 2 commits
  33. 01 Jun, 2016 1 commit
    • Yorick Peterse's avatar
      Refactor Participable · 580d2501
      Yorick Peterse authored
      There are several changes to this module:
      
      1. The use of an explicit stack in Participable#participants
      2. Proc behaviour has been changed
      3. Batch permissions checking
      
      == Explicit Stack
      
      Participable#participants no longer uses recursion to process "self" and
      all child objects, instead it uses an Array and processes objects in
      breadth-first order. This allows us to for example create a single
      Gitlab::ReferenceExtractor instance and pass this to any Procs. Re-using
      a ReferenceExtractor removes the need for running potentially many SQL
      queries every time a Proc is called on a new object.
      
      == Proc Behaviour Changed
      
      Previously a Proc in Participable was expected to return an Array of
      User instances. This has been changed and instead it's now expected that
      a Proc modifies the Gitlab::ReferenceExtractor passed to it. The return
      value of the Proc is ignored.
      
      == Permissions Checking
      
      The method Participable#participants uses
      Ability.users_that_can_read_project to check if the returned users have
      access to the project of "self" _without_ running multiple SQL queries
      for every user.
      580d2501