- 15 Jun, 2016 9 commits
-
-
Douwe Maan authored
Resolve "Track the number of new Redis connections per transaction" ## What does this MR do? Add a new metric counter, `new_redis_connections`, that contains the number of calls to `Redis::Client#connect` in the current transaction. ## Are there points in the code the reviewer needs to double check? Not sure. I tested this in kind of a brute-force way: 1. Add a debugger in the monkey-patched `connect` method. 2. With metrics enabled, start the app and load a page. 3. The first Redis connection is created by `Rack::Attack` and isn't in a transaction, but still works fine. 4. The second Redis connection is within a transaction (the page load), and increments the counter. 5. If I reload the page, neither debugger is hit. 6. If I use a Redis client and do `CLIENT KILL` on my two existing clients, then reload the page, I get 3 and 4 again. 7. If I disable metrics collection, the debugger never gets hit. ## Why was this MR needed? We may have a Redis connection leak somewhere, so adding metrics will let us track this. ## What are the relevant issue numbers? Closes #18451. ## Screenshots (if relevant) Hahaha nope, not relevant. ## Does this MR meet the acceptance criteria? - [ ] [CHANGELOG](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/CHANGELOG) entry added - [ ] [Documentation created/updated](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/doc/development/doc_styleguide.md) - [ ] API support added - [ ] Tests - [ ] Added for this feature/bug - [ ] All builds are passing - [ ] Conform by the [style guides](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/CONTRIBUTING.md#style-guides) - [ ] Branch has no merge conflicts with `master` (if you do - rebase it please) - [ ] [Squashed related commits together](https://git-scm.com/book/en/Git-Tools-Rewriting-History#Squashing-Commits) cc @yorickpeterse See merge request !4649
-
Achilleas Pipinellis authored
Add docs for assigning labels/milestone when moving issue Extends https://gitlab.com/gitlab-org/gitlab-ce/merge_requests/3934 See merge request !4069
-
Grzegorz Bizon authored
[ci skip]
-
Achilleas Pipinellis authored
Document CI_BUILD_TOKEN ## What does this MR do? Adds `CI_BUILD_TOKEN` to CI variables documentation. See merge request !4664
-
Yorick Peterse authored
Include user relationship when retrieving award_emoji See merge request !4647
-
Dmitriy Zaporozhets authored
-
Paco Guzman authored
Avoiding N+1 when showing grouped awards and when calculating participants for awardable entities
-
Mark Pundsack authored
-
Stan Hu authored
Don't fail builds for projects that are deleted when they are stuck ## What does this MR do? Solves when dropping stuck connection. ``` Dropping stuck pending build 1545510 for runner NoMethodError: undefined method `origin_merge_requests' for nil:NilClass from /opt/gitlab/embedded/service/gitlab-rails/app/services/merge_requests/base_service.rb:50:in `merge_request_from' from /opt/gitlab/embedded/service/gitlab-rails/app/services/merge_requests/base_service.rb:57:in `each_merge_request' from /opt/gitlab/embedded/service/gitlab-rails/app/services/merge_requests/add_todo_when_build_fails_service.rb:5:in `execute' from /opt/gitlab/embedded/service/gitlab-rails/lib/gitlab/metrics/instrumentation.rb:164:in `execute' from /opt/gitlab/embedded/service/gitlab-rails/app/models/commit_status.rb:51:in `block (2 levels) in <class:CommitStatus>' from /opt/gitlab/embedded/service/gem/ruby/2.1.0/gems/state_machines-0.4.0/lib/state_machines/eval_helpers.rb:79:in `call' ... ``` This happens, because that `default_scope` of `Projects` filters returns the projects that are not deleted, where `Ci::Build` doesn't take into account. See merge request !4609
-
- 14 Jun, 2016 31 commits
-
-
Stan Hu authored
Fix typo in obtaining a backtrace from all threads in gdb See merge request !4612
-
Jacob Schatz authored
Fix note polling when a window has been hidden `refresh` was called, `refreshing` was set to true, but then because `document.hidden` was true, `getContent` was never called, and `refreshing` never got reset to `false`, which stopped polling entirely until refresh. See merge request !4635
-
Stan Hu authored
Manually create todo for issuable ## What does this MR do? Adds a button to the sidebar in issues & merge requests to allow users to manually create a todo item themselves. ## What are the relevant issue numbers? Closes #15045 ## Screenshots (if relevant) data:image/s3,"s3://crabby-images/fa331/fa331a7ed642ee73ef2151ba54e50f6bb3c542f6" alt="Screen_Shot_2016-06-07_at_09.52.14" data:image/s3,"s3://crabby-images/9fde0/9fde0f99daca573a8acf849fe7d62ab6098c7e43" alt="Screen_Shot_2016-06-07_at_09.52.06" data:image/s3,"s3://crabby-images/b5b34/b5b34a21a163fba697501e36ea2d8b9a6d259c55" alt="Screen_Shot_2016-06-07_at_09.51.14" See merge request !4502
-
Robert Speicher authored
Only show notes through JSON on confidential issues that the user has access to Fixes https://gitlab.com/gitlab-org/gitlab-ce/issues/18535 See merge request !1970
-
Jacob Schatz authored
Update CHANGELOG ## What does this MR do? Updates the CHANGELOG See merge request !4549
-
Douglas Barbosa Alexandre authored
-
Douglas Barbosa Alexandre authored
-
Annabel Dunstone authored
-
Jacob Schatz authored
Fixes bulk-assign labels not working when navigating through pages ## What does this MR do? This MR fixes an issue on bulk-assign labels not working when navigating though pages. The functionality was not working because events on checkboxes weren't working. This re-runs `Issuable.initChecks()` and makes sure we are not leaving zombie event handlers by turning them off first. Also fixes tests to use `wait_for_ajax` since label filtering is now using `Turbolinks` for redirection. ## Does this MR meet the acceptance criteria? - [ ] [CHANGELOG](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/CHANGELOG) entry added - [ ] [Documentation created/updated](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/doc/development/doc_styleguide.md) - [ ] API support added - [ ] Tests - [ ] Added for this feature/bug - [x] All builds are passing - [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 you do - rebase it please) - [x] [Squashed related commits together](https://git-scm.com/book/en/Git-Tools-Rewriting-History#Squashing-Commits) See merge request !4632
-
Alfredo Sumaran authored
-
Alfredo Sumaran authored
-
Alfredo Sumaran authored
-
Alfredo Sumaran authored
-
Jacob Schatz authored
Aligned the two navs horizontally ## What does this MR do? Previously the 2 top navs were not aligned horizontally together. The top nav would be slightly to the left due to the settings dropdown. This corrects that by putting `position: absolute` on the dropdown toggle. ## What are the relevant issue numbers? Closes #18513 ## Screenshots (if relevant) data:image/s3,"s3://crabby-images/987fc/987fcab034e921b5900a41f905c80df2cc9aee45" alt="Screen_Shot_2016-06-13_at_10.20.22" See merge request !4616
-
Rémy Coutable authored
Update allocations Gem & ignore classes without names ## What does this MR do? 1. Updates the allocations Gem to 1.0.5 so it can be used on 2.2/2.3 without crashing 2. Changes the background sampler to ignore classes/modules without a name (as we can't do much with these) ## Are there points in the code the reviewer needs to double check? No. ## Why was this MR needed? Using MRI 2.2 or 2.3 would lead to a segmentation fault in the allocations Gem, sometimes this problem would also occur on 2.1 ## What are the relevant issue numbers? Not an issue, but the merge request that highlighted these problems: !3807 ## Does this MR meet the acceptance criteria? - [x] [CHANGELOG](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/CHANGELOG) entry 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 [style guides](https://gitlab.com/gitlab-org/gitlab-ce/blob/master/CONTRIBUTING.md#style-guides) - [ ] Branch has no merge conflicts with `master` (if you do - rebase it please) - [x] [Squashed related commits together](https://git-scm.com/book/en/Git-Tools-Rewriting-History#Squashing-Commits) See merge request !4645
-
Phil Hughes authored
Uses outerWidth instead of width
-
Douwe Maan authored
Revert "Added API endpoint for Sidekiq Metrics" @DouweM please merge my accidental push to master. See merge request !4651
-
Patricio Cano authored
This reverts commit 06e0ef07
-
Patricio Cano authored
-
Yorick Peterse authored
-
Yorick Peterse authored
We can't do a lot with classes without names as we can't filter by them, have no idea where they come from, etc. As such it's best to just ignore these.
-
Yorick Peterse authored
This allows it to be used on Ruby 2.3 without it crashing all the time.
-
Jacob Schatz authored
Put all sidebar icons in fixed width container ## What does this MR do? Puts all icons (font awesome and custom) in fixed width container to fix weird alignment ## Why was this MR needed? Mix of font awesome icons & custom icons results in different icon widths ## What are the relevant issue numbers? Closes #18539 ## Screenshots (if relevant) <img src="/uploads/94a82258d5d71df0b9608ccd4d7e5cd1/Screen_Shot_2016-06-14_at_9.57.25_AM.png" width="400px"> See merge request !4648
-
Sean McGivern authored
-
Sean McGivern authored
Increment the counter `new_redis_connections` on each call to `Redis::Client#connect`, if we're in a transaction.
-
Annabel Dunstone authored
-
Robert Speicher authored
Forbid scripting for wiki files Wiki files (not pages - files in the repo) are just sent to the browser with whatever content-type the mime_types gem assigns to them based on their extension. As this is from the same domain as the GitLab application, this is an XSS vulnerability. Set a CSP forbidding all sources for scripting, CSS, XHR, etc. on these files. Fixes https://gitlab.com/gitlab-org/gitlab-ce/issues/17298. See merge request !1969
-
Douwe Maan authored
Allow users to request access to projects and groups #### TODO: - [x] Factorize the projects & groups members list - [x] Factorize `request_access` and `approve` controller methods into a concern - [x] Factorize the project & group dropdowns - [x] Factorize access request routes - [x] Factorize mailers #### Will be done in separate MRs - [ ] Documentation - [ ] API #### Access request to project - [x] Design project access request button to spec (defined in #13948) - [x] Request access to a project as a logged in user - [x] Withdraw access request to a project as a logged in user - [x] Do not treat project member request as actual membership (done partly in Ability) - [x] Display access requests on project's members page (+ allow to change level, approve, and deny request) - [x] Email requesting user at notification email address when accepted/denied - [x] Email all project admins at notification email addresses when new access request - [x] Unit specs to cover new functionality: `AccessRequestable` is missing specs - [x] Controller specs to cover new functionality - [x] Mailer specs to cover new functionality - [x] Features specs to cover new UI and interactions - [x] Regression specs still passing #### Access request to group - [x] Design group access request button to spec (defined in #13948) - [x] Request access to a group as a logged in user - [x] Withdraw access request to a group as a logged in user - [x] Do not treat group member request as actual membership - [x] Display access requests on group's members page (+ allow to change level, approve, and deny request) - [x] Email requesting user at notification email address when accepted/denied - [x] Email all project admins at notification email addresses when new access request - [x] Unit specs to cover new functionality - [x] Controller specs to cover new functionality - [x] Mailer specs to cover new functionality - [x] Features specs to cover new UI and interactions - [x] Regression specs still passing Closes #13948. ### Requesting access to a project #### Responsive UI data:image/s3,"s3://crabby-images/ec285/ec2854064f9aaa1e0605365f7057494056bac45d" alt="request-access-to-project" #### Request access link data:image/s3,"s3://crabby-images/80843/80843642282f633834c648fc415b896e8ba01671" alt="1-project-request-access-link" #### Flash once access is requested data:image/s3,"s3://crabby-images/0f8fa/0f8fabff202f4c2a928705b9faf8967d5a5fe8ad" alt="2-project-request-access-flash" #### Email sent to project admins on new access requests ##### HTML Email data:image/s3,"s3://crabby-images/8eb01/8eb0138f6ade0b9df97b52c0c8affd5c90511ae1" alt="3-project-request-access-email-html" ##### Plain Email data:image/s3,"s3://crabby-images/81274/81274f95ab77e3690dc571117394eeaa94fd41d8" alt="4-project-request-access-email-plain" ### Withdrawing access request to a project #### Withdraw access request link data:image/s3,"s3://crabby-images/a9867/a9867e20f6ad7b47dd5fb2a3d1bc92ef2a141bcb" alt="5-project-withdraw-request-link" #### Withdraw access request confirmation dialog box data:image/s3,"s3://crabby-images/74699/74699353a38584836b7942ac1ea4bf9d8aa23099" alt="6-project-withdraw-request-confirm" #### Flash once access has been withdrawn data:image/s3,"s3://crabby-images/1af3c/1af3cf70cfc7290f5776a36f1aeb03143fe8e53d" alt="6-2-project-withdraw-request-confirm" ### Access requests management page data:image/s3,"s3://crabby-images/627df/627df2f69bec3ae083a528b220b6ed5fd018e02e" alt="7-project-access-requests" #### Deny access request confirmation dialog box data:image/s3,"s3://crabby-images/67170/67170fe09baad3e3b6bf4b88b8a4cd3a9afeeea8" alt="8-project-access-request-deny-confirm" #### Email sent to requester on denied access requests ##### HTML Email data:image/s3,"s3://crabby-images/c0353/c0353091247165db133aac7acddb3e18627841df" alt="9-project-request-access-denied-email-html" ##### Plain Email data:image/s3,"s3://crabby-images/d0f8d/d0f8de0d29f7ddae43d5a26520d602e9d2b4fb39" alt="10-project-request-access-denied-email-plain" #### Email sent to requester on granted access requests ##### HTML Email data:image/s3,"s3://crabby-images/2d32b/2d32b1db8aac8aeece1b340a1d3326aa05387d5f" alt="11-project-request-access-granted-email-html" ##### Plain Email data:image/s3,"s3://crabby-images/04391/0439184147dba8f7acfddd6fb6db421a63972ea7" alt="12-project-request-access-granted-email-plain" ---------------------------------- ---------------------------------- ### Requesting access to a group #### Responsive UI data:image/s3,"s3://crabby-images/6da19/6da19a6bba912deaba1b28a7fdfce25b02390b0a" alt="request-access-to-group" #### Request access link data:image/s3,"s3://crabby-images/c57d0/c57d0fd9386e73885745ef5534084fa8296c4d0c" alt="1-group-request-access-link" #### Flash once access is requested data:image/s3,"s3://crabby-images/081db/081dbfbcd42b798de56255a730256b63571a5b81" alt="2-group-request-access-flash" #### Email sent to project admins on new access requests ##### HTML Email data:image/s3,"s3://crabby-images/1cd2a/1cd2a5ec83f7ac08f76e817fc7df925c3526e253" alt="3-group-request-access-email-html" ##### Plain Email data:image/s3,"s3://crabby-images/6a750/6a750dab283031fe3d93c2eea6db0defb86b3d1e" alt="4-group-request-access-email-plain" ### Withdrawing access request to a project #### Withdraw access request link data:image/s3,"s3://crabby-images/159e7/159e7c911603b58dff6c765ecd8c266ee90b1c04" alt="5-group-withdraw-request-link" #### Withdraw access request confirmation dialog box data:image/s3,"s3://crabby-images/dfcc5/dfcc5c45fa66db1ba6492d86bc76aa0d0250623d" alt="6-group-withdraw-request-confirm" #### Flash once access has been withdrawn data:image/s3,"s3://crabby-images/4ffab/4ffabad82059aab26a6f766eed2d5ce115c0316d" alt="6-2-group-withdraw-request-confirm" ### Access requests management page data:image/s3,"s3://crabby-images/b6b3e/b6b3ec2e03eb628f2812cac8f4a8a9ad8f08fbe5" alt="7-group-access-requests" #### Deny access request confirmation dialog box data:image/s3,"s3://crabby-images/521f5/521f5e1d883e49bda6c2ca53ef0d4545bf76560a" alt="8-group-access-request-deny-confirm" #### Email sent to requester on denied access requests ##### HTML Email data:image/s3,"s3://crabby-images/e5772/e57727256ed4b0f6aac909e240f1741986b9d32a" alt="9-group-request-access-denied-email-html" ##### Plain Email data:image/s3,"s3://crabby-images/fa3da/fa3da47a73f390edc7560f4bff197a536b6d3878" alt="10-group-request-access-denied-email-plain" #### Email sent to requester on granted access requests ##### HTML Email data:image/s3,"s3://crabby-images/f9e47/f9e47138c75c16f136ad533385c7f9ad4bb2c1fd" alt="11-group-request-access-granted-email-html" ##### Plain Email data:image/s3,"s3://crabby-images/976d4/976d4c0ec675f4e790764661e0fecf293151ab61" alt="12-group-request-access-granted-email-plain" See merge request !3798
-
Yorick Peterse authored
Instrument Grape API endpoints See merge request !4587
-
Yorick Peterse authored
Instrument private methods and instance private methods See merge request !4639
-
Douwe Maan authored
# Conflicts: # app/views/layouts/nav/_project.html.haml
-