2
0

Display Valkey version on admin dashboard (#35785)

This commit is contained in:
Yamagishi Kazutoshi
2025-09-10 19:58:51 +09:00
committed by GitHub
parent eb118d8523
commit ffaa672fd6
5 changed files with 104 additions and 33 deletions

View File

@@ -1,7 +1,7 @@
# frozen_string_literal: true
class Admin::Metrics::Dimension::SoftwareVersionsDimension < Admin::Metrics::Dimension::BaseDimension
include Redisable
include Admin::Metrics::Dimension::StoreHelper
def key
'software_versions'
@@ -45,13 +45,11 @@ class Admin::Metrics::Dimension::SoftwareVersionsDimension < Admin::Metrics::Dim
end
def redis_version
value = redis_info['redis_version']
{
key: 'redis',
human_key: 'Redis',
value: value,
human_value: value,
human_key: store_name,
value: store_version,
human_value: store_version,
}
end
@@ -117,8 +115,4 @@ class Admin::Metrics::Dimension::SoftwareVersionsDimension < Admin::Metrics::Dim
rescue Terrapin::CommandNotFoundError, Terrapin::ExitStatusError, Oj::ParseError
nil
end
def redis_info
@redis_info ||= redis.info
end
end

View File

@@ -1,8 +1,8 @@
# frozen_string_literal: true
class Admin::Metrics::Dimension::SpaceUsageDimension < Admin::Metrics::Dimension::BaseDimension
include Redisable
include ActionView::Helpers::NumberHelper
include Admin::Metrics::Dimension::StoreHelper
def key
'space_usage'
@@ -27,14 +27,12 @@ class Admin::Metrics::Dimension::SpaceUsageDimension < Admin::Metrics::Dimension
end
def redis_size
value = redis_info['used_memory']
{
key: 'redis',
human_key: 'Redis',
value: value.to_s,
human_key: store_name,
value: store_size.to_s,
unit: 'bytes',
human_value: number_to_human_size(value),
human_value: number_to_human_size(store_size),
}
end
@@ -57,10 +55,6 @@ class Admin::Metrics::Dimension::SpaceUsageDimension < Admin::Metrics::Dimension
}
end
def redis_info
@redis_info ||= redis.info
end
def search_size
return unless Chewy.enabled?

View File

@@ -0,0 +1,26 @@
# frozen_string_literal: true
module Admin::Metrics::Dimension::StoreHelper
include Redisable
private
def store_name
return 'Valkey' if redis_info.key?('valkey_version')
return 'Dragonfly' if redis_info.key?('dragonfly_version')
'Redis'
end
def store_version
redis_info['valkey_version'] || redis_info['dragonfly_version'] || redis_info['redis_version']
end
def store_size
redis_info['used_memory']
end
def redis_info
@redis_info ||= redis.info
end
end

View File

@@ -9,14 +9,44 @@ RSpec.describe Admin::Metrics::Dimension::SoftwareVersionsDimension do
let(:end_at) { Time.now.utc }
let(:limit) { 10 }
let(:params) { ActionController::Parameters.new }
let(:redis_human_key) { 'Redis' }
let(:redis_version) { '7.4.5' }
let(:redis_info) { { 'redis_version' => redis_version } }
describe '#data' do
it 'reports on the running software' do
expect(subject.data.map(&:symbolize_keys))
.to include(
include(key: 'mastodon', value: Mastodon::Version.to_s),
include(key: 'ruby', value: include(RUBY_VERSION))
)
shared_examples 'shared behavior' do
before do
allow(subject).to receive(:redis_info).and_return(redis_info) # rubocop:disable RSpec/SubjectStub
end
it 'reports on the running software' do
expect(subject.data.map(&:symbolize_keys))
.to include(
include(key: 'mastodon', value: Mastodon::Version.to_s),
include(key: 'ruby', value: include(RUBY_VERSION)),
include(key: 'redis', human_key: redis_human_key, value: redis_version)
)
end
end
context 'when using redis' do
it_behaves_like 'shared behavior'
end
context 'when using valkey' do
let(:redis_human_key) { 'Valkey' }
let(:redis_version) { '8.1.3' }
let(:redis_info) { { 'valkey_version' => redis_version } }
it_behaves_like 'shared behavior'
end
context 'when using dragonfly' do
let(:redis_human_key) { 'Dragonfly' }
let(:redis_version) { 'df-v1.32.0' }
let(:redis_info) { { 'dragonfly_version' => redis_version } }
it_behaves_like 'shared behavior'
end
end
end

View File

@@ -10,14 +10,41 @@ RSpec.describe Admin::Metrics::Dimension::SpaceUsageDimension do
let(:limit) { 10 }
let(:params) { ActionController::Parameters.new }
let(:redis_human_key) { 'Redis' }
let(:redis_info) { { 'redis_version' => '7.4.5', 'used_memory' => 1_024 } }
describe '#data' do
it 'reports on used storage space' do
expect(subject.data.map(&:symbolize_keys))
.to include(
include(key: 'media', value: /\d/),
include(key: 'postgresql', value: /\d/),
include(key: 'redis', value: /\d/)
)
shared_examples 'shared behavior' do
before do
allow(subject).to receive(:redis_info).and_return(redis_info) # rubocop:disable RSpec/SubjectStub
end
it 'reports on used storage space' do
expect(subject.data.map(&:symbolize_keys))
.to include(
include(key: 'media', value: /\d/),
include(key: 'postgresql', value: /\d/),
include(key: 'redis', human_key: redis_human_key, value: /\d/)
)
end
end
context 'when using redis' do
it_behaves_like 'shared behavior'
end
context 'when using valkey' do
let(:redis_human_key) { 'Valkey' }
let(:redis_info) { { 'valkey_version' => '8.1.3', 'used_memory' => 1_024 } }
it_behaves_like 'shared behavior'
end
context 'when using dragonfly' do
let(:redis_human_key) { 'Dragonfly' }
let(:redis_info) { { 'dragonfly_version' => 'df-v1.32.0', 'used_memory' => 1_024 } }
it_behaves_like 'shared behavior'
end
end
end