BigW Consortium Gitlab

  1. 13 Feb, 2017 1 commit
  2. 07 Feb, 2017 1 commit
  3. 06 Feb, 2017 1 commit
  4. 03 Feb, 2017 1 commit
  5. 26 Jan, 2017 2 commits
  6. 15 Jan, 2017 1 commit
  7. 06 Jan, 2017 1 commit
  8. 04 Jan, 2017 1 commit
  9. 20 Dec, 2016 4 commits
  10. 13 Dec, 2016 1 commit
  11. 09 Dec, 2016 1 commit
  12. 08 Dec, 2016 1 commit
  13. 07 Dec, 2016 2 commits
  14. 06 Dec, 2016 2 commits
  15. 05 Dec, 2016 1 commit
  16. 28 Nov, 2016 2 commits
  17. 21 Nov, 2016 3 commits
    • Refactor cache refreshing/expiring · ffb9b3ef
      Yorick Peterse authored
      This refactors repository caching so it's possible to selectively
      refresh certain caches, instead of just expiring and refreshing
      everything.
      
      To allow this the various methods that were cached (e.g. "tag_count" and
      "readme") use a similar pattern that makes expiring and refreshing
      their data much easier.
      
      In this new setup caches are refreshed as follows:
      
      1. After a commit (but before running ProjectCacheWorker) we expire some
         basic caches such as the commit count and repository size.
      
      2. ProjectCacheWorker will recalculate the commit count, repository
         size, then refresh a specific set of caches based on the list of
         files changed in a push payload.
      
      This requires a bunch of changes to the various methods that may be
      cached. For one, data should not be cached if a branch used or the
      entire repository does not exist. To prevent all these methods from
      handling this manually this is taken care of in
      Repository#cache_method_output. Some methods still manually check for
      the existence of a repository but this result is also cached.
      
      With selective flushing implemented ProjectCacheWorker no longer uses an
      exclusive lease for all of its work. Instead this worker only uses a
      lease to limit the number of times the repository size is updated as
      this is a fairly expensive operation.
    • Use File.exist? to check if a repository exists · 6f393877
      Yorick Peterse authored
      Initializing Rugged objects is way too expensive just to check if a
      repository exists. Even though we cache this data once in a while we
      have to refresh this. On GitLab.com we have seen Repository#exists?
      taking up to _1 minute_ to complete in the absolute worst case, though
      usually it sits around a second or so.
      
      Using File.exist? to instead check if $GIT_DIR/refs exists is a much
      faster way of checking if a repository was initialized properly.
    • Unify detecting of special repository files · df5548e1
      Yorick Peterse authored
      This moves the logic of detecting special repository files (e.g. a
      README or a Koding configuration file) to a single class:
      Gitlab::FileDetector. Moving this logic into a single place allows this
      to be re-used more easily.
      
      This commit also changes Repository#gitlab_ci_yaml so that its cached
      similar to other data (e.g. the Koding configuration file).
  18. 18 Nov, 2016 1 commit
    • Pass correct tag target to post-receive hook when creating tag via UI · ae51774b
      Adam Niedzielski authored
      We need to handle annotated tags that are created via GitLab UI.
      Annotated tags have their own SHA. We have to pass this SHA to
      post-receive hook to mirror what happens when someone creates
      an annotated tag in their local repository and pushes it via
      command line.
      In order to obtain tag SHA we first have to create it. This is
      a bit confusing because we create the tag before executing
      pre-hooks, but there is no way to create a tag outside the
      repository. If pre-hooks fail we have to clean up after ourselves.
  19. 16 Nov, 2016 2 commits
  20. 11 Nov, 2016 1 commit
  21. 09 Nov, 2016 1 commit
  22. 08 Nov, 2016 1 commit
  23. 07 Nov, 2016 1 commit
  24. 28 Oct, 2016 2 commits
  25. 23 Oct, 2016 1 commit
    • Expire and build repository cache after project import · 4ea1973f
      Stan Hu authored
      After a project import, there's a chance that the UI checks the
      branch count before the project has been imported. This change
      causes more of the keys to be flushed after an import and forces
      a rebuild of the repository cache.
      
      Closes #13518
  26. 14 Oct, 2016 1 commit
  27. 11 Oct, 2016 1 commit
  28. 10 Oct, 2016 1 commit
  29. 09 Oct, 2016 1 commit