diff options
author | Zeger-Jan van de Weg <git@zjvandeweg.nl> | 2017-10-12 10:39:11 +0200 |
---|---|---|
committer | Zeger-Jan van de Weg <git@zjvandeweg.nl> | 2017-10-16 13:25:51 +0200 |
commit | 61f4d08b7bf734c9af579e54fa8c74ac1bde4b39 (patch) | |
tree | 9ede84bedd25665b6197f040884a64c4d0386d9f /doc | |
parent | 2087f121bfedd2f51eb943f23026e823d196466a (diff) | |
download | gitlab-ce-61f4d08b7bf734c9af579e54fa8c74ac1bde4b39.tar.gz |
Allow testing on Gitaly call count
Previous efforts were aimed at detecting N + 1 queries, general
regressions are hard to find and mitigate.
Diffstat (limited to 'doc')
-rw-r--r-- | doc/development/gitaly.md | 34 |
1 files changed, 31 insertions, 3 deletions
diff --git a/doc/development/gitaly.md b/doc/development/gitaly.md index e41d258bec6..0f73217ada3 100644 --- a/doc/development/gitaly.md +++ b/doc/development/gitaly.md @@ -52,8 +52,8 @@ rm -rf tmp/tests/gitaly ## `TooManyInvocationsError` errors -During development and testing, you may experience `Gitlab::GitalyClient::TooManyInvocationsError` failures. -The `GitalyClient` will attempt to block against potential n+1 issues by raising this error +During development and testing, you may experience `Gitlab::GitalyClient::TooManyInvocationsError` failures. +The `GitalyClient` will attempt to block against potential n+1 issues by raising this error when Gitaly is called more than 30 times in a single Rails request or Sidekiq execution. As a temporary measure, export `GITALY_DISABLE_REQUEST_LIMITS=1` to suppress the error. This will disable the n+1 detection @@ -64,7 +64,7 @@ Please raise an issue in the GitLab CE or EE repositories to report the issue. I `TooManyInvocationsError`. Also include any known failing tests if possible. Isolate the source of the n+1 problem. This will normally be a loop that results in Gitaly being called for each -element in an array. If you are unable to isolate the problem, please contact a member +element in an array. If you are unable to isolate the problem, please contact a member of the [Gitaly Team](https://gitlab.com/groups/gl-gitaly/group_members) for assistance. Once the source has been found, wrap it in an `allow_n_plus_1_calls` block, as follows: @@ -79,6 +79,34 @@ end Once the code is wrapped in this block, this code-path will be excluded from n+1 detection. +## Request counts + +Commits and other git data, is now fetched through Gitaly. These fetches can, +much like with a database, be batched. This improves performance for the client +and for Gitaly itself and therefore for the users too. To keep performance stable +and guard performance regressions, Gitaly calls can be counted and the call count +can be tested against: + +```ruby +describe 'Gitaly Request count tests' do + context 'when the request store is activated', :request_store do + it 'correctly counts the gitaly requests made' do + count = gitaly_request_count { subject } + + expect { subject }.to change { Gitlab::GitalyClient.get_request_count }.by(10) + end + end + + context 'when the request store is disabled' do + it 'is always zero' do + subject + + expect(Gitlab::GitalyClient.get_request_count).to be_zero + end + end +end +``` + --- [Return to Development documentation](README.md) |