Welcome to mirror list, hosted at ThFree Co, Russian Federation.

gitlab.com/gitlab-org/gitlab-foss.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
path: root/config
AgeCommit message (Collapse)Author
2017-01-25Merge branch 'refresh-authorizations-fork-join' into 'master' Douwe Maan
Fix race conditions for AuthorizedProjectsWorker Closes #26194 and #26310 See merge request !8701
2017-01-25Merge branch 'dz-fix-group-canonical-route' into 'master' Dmitriy Zaporozhets
Fix 500 error for Group#web_url method if nested group See merge request !8743
2017-01-25Fix race conditions for AuthorizedProjectsWorkerYorick Peterse
There were two cases that could be problematic: 1. Because sometimes AuthorizedProjectsWorker would be scheduled in a transaction it was possible for a job to run/complete before a COMMIT; resulting in it either producing an error, or producing no new data. 2. When scheduling jobs the code would not wait until completion. This could lead to a user creating a project and then immediately trying to push to it. Usually this will work fine, but given enough load it might take a few seconds before a user has access. The first one is problematic, the second one is mostly just annoying (but annoying enough to warrant a solution). This commit changes two things to deal with this: 1. Sidekiq scheduling now takes places after a COMMIT, this is ensured by scheduling using Rails' after_commit hook instead of doing so in an arbitrary method. 2. When scheduling jobs the calling thread now waits for all jobs to complete. Solution 2 requires tracking of job completions. Sidekiq provides a way to find a job by its ID, but this involves scanning over the entire queue; something that is very in-efficient for large queues. As such a more efficient solution is necessary. There are two main Gems that can do this in a more efficient manner: * sidekiq-status * sidekiq_status No, this is not a joke. Both Gems do a similar thing (but slightly different), and the only difference in their name is a dash vs an underscore. Both Gems however provide far more than just checking if a job has been completed, and both have their problems. sidekiq-status does not appear to be actively maintained, with the last release being in 2015. It also has some issues during testing as API calls are not stubbed in any way. sidekiq_status on the other hand does not appear to be very popular, and introduces a similar amount of code. Because of this I opted to write a simple home grown solution. After all, all we need is storing a job ID somewhere so we can efficiently look it up; we don't need extra web UIs (as provided by sidekiq-status) or complex APIs to update progress, etc. This is where Gitlab::SidekiqStatus comes in handy. This namespace contains some code used for tracking, removing, and looking up job IDs; all without having to scan over an entire queue. Data is removed explicitly, but also expires automatically just in case. Using this API we can now schedule jobs in a fork-join like manner: we schedule the jobs in Sidekiq, process them in parallel, then wait for completion. By using Sidekiq we can leverage all the benefits such as being able to scale across multiple cores and hosts, retrying failed jobs, etc. The one downside is that we need to make sure we can deal with unexpected increases in job processing timings. To deal with this the class Gitlab::JobWaiter (used for waiting for jobs to complete) will only wait a number of seconds (30 by default). Once this timeout is reached it will simply return. For GitLab.com almost all AuthorizedProjectWorker jobs complete in seconds, only very rarely do we spike to job timings of around a minute. These in turn seem to be the result of external factors (e.g. deploys), in which case a user is most likely not able to use the system anyway. In short, this new solution should ensure that jobs are processed properly and that in almost all cases a user has access to their resources whenever they need to have access.
2017-01-24Fix 500 error for Group#web_url method if nested groupDmitriy Zaporozhets
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
2017-01-24Add metric initializer specSean McGivern
An empty file in one of the instrumented directories will cause the app to fail to start when metrics are enabled. Metrics aren't enabled by default in development or test. We could handle the empty file case explicitly, but a file could still not define the constant it is expected to, so instead run the initializer manually in a spec and check that it succeeds.
2017-01-20Merge branch '26138-combine-webhooks-and-services-settings-pages' into 'master' Rémy Coutable
Moved the webhooks and services gear options to a single one called integrations See merge request !8380
2017-01-19Merge branch 'feature/gitaly-feature-flag' into 'master' Robert Speicher
Gitaly feature flag See merge request !8440
2017-01-19Moved the webhooks and services gear options to a single one called integrationsJose Ivan Vargas
2017-01-18Pass Gitaly resource path to gitlab-workhorse if Gitaly is enabledAhmad Sherif
2017-01-18Merge branch 'backport-time-tracking-ce' into 'master' Douwe Maan
Backport timetracking to CE See merge request !8195
2017-01-17Merge branch '24915_merge_slash_command' into 'master' Sean McGivern
Support `/merge` slash command for MRs Closes #24915 See merge request !7746
2017-01-15Backport timetracking frontend to CE.Bryce Johnson
2017-01-15change how pagination component is loadedRegis
2017-01-11refresh merge widget after using /merge commandJarka Kadlecova
2017-01-10Add basic searchClement Ho
2017-01-09Merge branch 'master' into auto-pipelines-vueRegis
2017-01-09Merge branch 'track_last_used_date_of_ssh_keys' into 'master' Sean McGivern
Record and show last used date of SSH Keys See merge request !8113
2017-01-08Record and show last used date of SSH KeysVincent Wong
Addresses: Issue #13810 1. Adds a last_used_at attribute to the Key table/model 2. Update a key's last_used_at whenever it gets used 3. Display how long ago an ssh key was last used
2017-01-06Merge branch '25985-combine-members-and-groups-settings-pages' into 'master' Alfredo Sumaran
Moved the members and groups to single option called members Closes #25985 See merge request !8281
2017-01-05Merge branch 'master' into auto-pipelines-vueFilipa Lacerda
* master: (35 commits) Adds back removed class in merge request pipelines table Fix dropdown icon alignment Simplify HTML of mini pipeline graph and dropdown Creates individual html for dropdown Adds simplified CSS for the new dropdown Removes old CSS Improves dropdown item in Chrome, Firefox and Safari Use SCSS variables for colors. Fix scss linter errors Adds animation when the stage is hovered. Adds back tooltip on dropdown toggle Fixes broken tests additional css changes to get more into direction of mockups Adds CHANGELOG entry Removes unneeded `window` declaration Decreases font-size on login page Ensure internal Gitlab::Git references use the namespace Absorb gitlab_git Fix review comments. Add spec for note edit and fix one commented spec. Review fixes. Use gl.utils.isInViewport and improve gl.utils.animateToElement. Make sure elements share the same scope Hide edit warning element when form reverted. Remove unnecessary styling came from merge conflicts. Fix single note edit form specs. Separate edit form in Changes and Discussions tab. Fix warning styling for responsive design. Fix task list for single edit note widget changes. Fix notes spec. ...
2017-01-05Merge branch 'monkey-patch-comment' into 'master' Rémy Coutable
Explain why we have this monkey-patch See merge request !8329
2017-01-03Moved the members (project_members)option to a single controller called membersJose Ivan Vargas
This controller is going to contain both the project members and groups options for the settings gear. Generated the route and modified the routing to point to the new members setting path
2017-01-03fix pipelines/index.html.haml merge conflictRegis
2016-12-30Merged the 'groups' and 'projects' tabs when viewing user profilesJames Gregory
2016-12-28Fix 500 error when visit group from admin area if group name contains dotDmitriy Zaporozhets
Signed-off-by: Dmitriy Zaporozhets <dmitriy.zaporozhets@gmail.com>
2016-12-27Explain why there is a monkey-patchJacob Vosmaer
2016-12-26Merge branch 'feature/more-storage-statistics' into 'master' Sean McGivern
Add more storage statistics See merge request !7754
2016-12-24merge master and fix application.rb conflictRegis
2016-12-23Merge branch 'permit-uploadedfile-scalar' into 'master' Rémy Coutable
Monkey-patch StrongParameters for ::UploadedFile Closes gitlab-ee#1451 See merge request !8299
2016-12-23Monkey-patch StrongParameters for ::UploadedFileJacob Vosmaer
2016-12-22Merge branch '25896-fix-404-katax-fonts' into 'master' Alfredo Sumaran
Resolve "KaTeX fonts 404 on gitlab.com" Closes #25896 See merge request !8228
2016-12-22Merge branch '23638-remove-builds-tab' into 'master' Kamil Trzciński
Resolve "Remove Builds tab from Merge Requests and Commits" Closes #23638 See merge request !7763
2016-12-22Add KaTeX fonts to assets paths and precompileHiroyuki Sato
2016-12-21Merge branch 'backport-mr-widget-ci-js' into 'master' Alfredo Sumaran
Backport moving MR widget CI JS out of script tag See merge request !8200
2016-12-21Remove unneeded bundle refs.Bryce Johnson
2016-12-21Add more storage statisticsMarkus Koller
This adds counters for build artifacts and LFS objects, and moves the preexisting repository_size and commit_count from the projects table into a new project_statistics table. The counters are displayed in the administration area for projects and groups, and also available through the API for admins (on */all) and normal users (on */owned) The statistics are updated through ProjectCacheWorker, which can now do more granular updates with the new :statistics argument.
2016-12-21Merge branch 'zj-mattermost-slash-config' into 'master' Kamil Trzciński
Mattermost slash auto config Closes #24769 See merge request !8070
2016-12-21Backport moving MR widget CI JS out of script tag.Bryce Johnson
2016-12-21Merge branch 'authentiq-id-oauth-support' into 'master' Rémy Coutable
Added support for Authentiq OAuth provider See merge request !8038
2016-12-21Changes after reviewFilipa Lacerda
Fix broken test Remove spinach tests for the builds tab
2016-12-21Remove builds tab from commitFilipa Lacerda
Remove unused file Fix commit link
2016-12-21Removes builds tab from merge requestFilipa Lacerda
Fix specs
2016-12-21Merge branch 'master' into auto-pipelines-vueGrzegorz Bizon
* master: (367 commits) Set “Remove branch” button to default size remove unused helper method reduce common code even further to satisfy rake flay remove button class size alteration from revert and cherry pick links factor out common code to satisfy rake flay homogenize revert and cherry-pick button styles generated by commits_helper apply margin on alert banners only when there is one or more alerts Rename MattermostNotificationService back to MattermostService Rename SlackNotificationService back to SlackService Fix stage and pipeline specs and rubocop offenses Added QueryRecorder to test N+1 fix on Milestone#show Use gitlab-workhorse 1.2.1 Make 'unmarked as WIP' message more consistent Improve specs for Files API Allow unauthenticated access to Repositories Files API GET endpoints Add isolated view spec for pipeline stage partial Move test for HTML stage endpoint to controller specs Fix sizing of avatar circles; add border Fix broken test Fix broken test Changes after review ... Conflicts: app/assets/stylesheets/pages/pipelines.scss app/controllers/projects/pipelines_controller.rb app/views/projects/pipelines/index.html.haml spec/features/projects/pipelines/pipelines_spec.rb
2016-12-21Added support for Authentiq oauth providerAlex
2016-12-21Merge branch '19703-direct-link-pipelines' into 'master' Grzegorz Bizon
Resolve "Direct link from pipeline list to builds" ## What does this MR do? - Adds a dropdown with builds in the mini pipeline graph in the pipelines table - Unnest a lot of CSS related with pipelines in order to make it reusable ## Screenshots ![Screen_Shot_2016-12-15_at_14.45.41](/uploads/ca1c61842a422a34383e029d668034b7/Screen_Shot_2016-12-15_at_14.45.41.png) ![Screen_Shot_2016-12-15_at_14.45.49](/uploads/952e3277143639ce4ad111103034faeb/Screen_Shot_2016-12-15_at_14.45.49.png) ![Screen_Shot_2016-12-15_at_14.46.02](/uploads/f7369a124b1c3c0db4194de2cb637ef0/Screen_Shot_2016-12-15_at_14.46.02.png) ![graph_animation](/uploads/9bae036cb5acff499f992a4722943d72/graph_animation.gif) ## Does this MR meet the acceptance criteria? - [x] [Changelog entry](https://docs.gitlab.com/ce/development/changelog.html) added - [ ] [Documentation created/updated](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/doc/development/doc_styleguide.md) - [ ] API support added - Tests - [x] Added for this feature/bug - [ ] All builds are passing - [x] Conform by the [merge request performance guides](http://docs.gitlab.com/ce/development/merge_request_performance_guidelines.html) - [x] Conform by the [style guides](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/CONTRIBUTING.md#style-guides) - [x] Branch has no merge conflicts with `master` (if it does - rebase it please) - [ ] [Squashed related commits together](https://git-scm.com/book/en/Git-Tools-Rewriting-History#Squashing-Commits) ## What are the relevant issue numbers? Closes #25071 Closes #19703 See merge request !8097
2016-12-20Merge remote-tracking branch 'origin/master' into zj-mattermost-slash-configKamil Trzcinski
2016-12-20Merge branch '22348-gitea-importer' into 'master' Rémy Coutable
It adds a brand new importer for Gitea! This is a continuation of !6945 started by @bkc. Gitea aims to be 100% GitHub-compatible but there's a few differences: - Gitea is not an OAuth provider (yet): https://github.com/go-gitea/gitea/issues/27 - This means we cannot map Gitea users given an assignee ID => assignees are not set on imported issues and merge requests - No releases API for now: https://github.com/go-gitea/gitea/issues/330 - API version is `v1` (GitHub is `v3`) - The IID field for milestones is `id` compared to `number` in GitHub. - Issues, PRs, milestones, labels don't have a `url` field (the importer now fallback to `''` in that case) **Known issues:** - Comments are not imported because comments JSON always have a blank `html_url`/`issue_url`/`pull_request_url`, so the IID cannot be extracted and the issuable cannot be found... :( This is tracked in https://github.com/go-gitea/gitea/issues/401, and solved by https://github.com/gogits/gogs/pull/3624 but this needs to be submitted / merged in Gitea. This is noted in the documentation. ## Are there points in the code the reviewer needs to double check? 1. I've made `Import::GiteaController` inherit from `Import::GithubController` since both controllers should be identical in the long-term and their current differences are small. 1. I've added a base `IssuableFormatter` class from which `IssueFormatter` & `PullRequestFormatter` inherit 1. I've added shared examples for GitHub/Gitea importer classes 1. I've made `Gitlab::ImportSources` more robust and tested! :christmas_tree: 1. I've added routing specs for import routes! :christmas_tree: Closes #22348 See merge request !8116
2016-12-20Improve sourcesKamil Trzcinski
- Add proper error handling, - Use flash[:alert] and flash[:notice], - Use `resource` instead of `resources`,
2016-12-20Add terminal UI and controller actionsFatih Acet
2016-12-19Minor adjustments API MattermostZ.J. van de Weg
[ci skip]