Commit 4c904ddc authored by Rémy Coutable's avatar Rémy Coutable

Merge branch 'sh-log-grpc-failures' into 'master'

[RUN ALL RSPEC] Enable Prometheus metrics and debug info in tests

See merge request gitlab-org/gitlab!55939
parents f04952ad bee01b7b
...@@ -98,6 +98,7 @@ module Gitlab ...@@ -98,6 +98,7 @@ module Gitlab
if Rails.env.test? if Rails.env.test?
socket_filename = options[:gitaly_socket] || "gitaly.socket" socket_filename = options[:gitaly_socket] || "gitaly.socket"
prometheus_listen_addr = options[:prometheus_listen_addr]
config = { config = {
# Override the set gitaly_address since Praefect is in the loop # Override the set gitaly_address since Praefect is in the loop
...@@ -106,8 +107,9 @@ module Gitlab ...@@ -106,8 +107,9 @@ module Gitlab
# Compared to production, tests run in constrained environments. This # Compared to production, tests run in constrained environments. This
# number is meant to grow with the number of concurrent rails requests / # number is meant to grow with the number of concurrent rails requests /
# sidekiq jobs, and concurrency will be low anyway in test. # sidekiq jobs, and concurrency will be low anyway in test.
git: { catfile_cache_size: 5 } git: { catfile_cache_size: 5 },
} prometheus_listen_addr: prometheus_listen_addr
}.compact
storage_path = Rails.root.join('tmp', 'tests', 'second_storage').to_s storage_path = Rails.root.join('tmp', 'tests', 'second_storage').to_s
storages << { name: 'test_second_storage', path: storage_path } storages << { name: 'test_second_storage', path: storage_path }
......
...@@ -92,6 +92,25 @@ RSpec.configure do |config| ...@@ -92,6 +92,25 @@ RSpec.configure do |config|
config.full_backtrace = true config.full_backtrace = true
end end
# Attempt to troubleshoot https://gitlab.com/gitlab-org/gitlab/-/issues/297359
if ENV['CI']
config.after do |example|
if example.exception.is_a?(GRPC::Unavailable)
warn "=== gRPC unavailable detected, process list:"
processes = `ps -ef | grep toml`
warn processes
warn "=== free memory"
warn `free -m`
warn "=== uptime"
warn `uptime`
warn "=== Prometheus metrics:"
warn `curl -s http://localhost:9236/metrics`
warn "=== Taking goroutine dump in log/goroutines.log..."
warn `curl -o log/goroutines.log http://localhost:9236/debug/pprof/goroutine?debug=2`
end
end
end
unless ENV['CI'] unless ENV['CI']
# Re-run failures locally with `--only-failures` # Re-run failures locally with `--only-failures`
config.example_status_persistence_file_path = './spec/examples.txt' config.example_status_persistence_file_path = './spec/examples.txt'
......
...@@ -170,7 +170,14 @@ module TestEnv ...@@ -170,7 +170,14 @@ module TestEnv
install_dir: gitaly_dir, install_dir: gitaly_dir,
version: Gitlab::GitalyClient.expected_server_version, version: Gitlab::GitalyClient.expected_server_version,
task: "gitlab:gitaly:install[#{install_gitaly_args}]") do task: "gitlab:gitaly:install[#{install_gitaly_args}]") do
Gitlab::SetupHelper::Gitaly.create_configuration(gitaly_dir, { 'default' => repos_path }, force: true) Gitlab::SetupHelper::Gitaly.create_configuration(
gitaly_dir,
{ 'default' => repos_path },
force: true,
options: {
prometheus_listen_addr: ':9236'
}
)
Gitlab::SetupHelper::Gitaly.create_configuration( Gitlab::SetupHelper::Gitaly.create_configuration(
gitaly_dir, gitaly_dir,
{ 'default' => repos_path }, { 'default' => repos_path },
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment