Display Valkey version on admin dashboard (#35785)
This commit is contained in:
committed by
GitHub
parent
eb118d8523
commit
ffaa672fd6
@@ -1,7 +1,7 @@
|
|||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
class Admin::Metrics::Dimension::SoftwareVersionsDimension < Admin::Metrics::Dimension::BaseDimension
|
class Admin::Metrics::Dimension::SoftwareVersionsDimension < Admin::Metrics::Dimension::BaseDimension
|
||||||
include Redisable
|
include Admin::Metrics::Dimension::StoreHelper
|
||||||
|
|
||||||
def key
|
def key
|
||||||
'software_versions'
|
'software_versions'
|
||||||
@@ -45,13 +45,11 @@ class Admin::Metrics::Dimension::SoftwareVersionsDimension < Admin::Metrics::Dim
|
|||||||
end
|
end
|
||||||
|
|
||||||
def redis_version
|
def redis_version
|
||||||
value = redis_info['redis_version']
|
|
||||||
|
|
||||||
{
|
{
|
||||||
key: 'redis',
|
key: 'redis',
|
||||||
human_key: 'Redis',
|
human_key: store_name,
|
||||||
value: value,
|
value: store_version,
|
||||||
human_value: value,
|
human_value: store_version,
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -117,8 +115,4 @@ class Admin::Metrics::Dimension::SoftwareVersionsDimension < Admin::Metrics::Dim
|
|||||||
rescue Terrapin::CommandNotFoundError, Terrapin::ExitStatusError, Oj::ParseError
|
rescue Terrapin::CommandNotFoundError, Terrapin::ExitStatusError, Oj::ParseError
|
||||||
nil
|
nil
|
||||||
end
|
end
|
||||||
|
|
||||||
def redis_info
|
|
||||||
@redis_info ||= redis.info
|
|
||||||
end
|
|
||||||
end
|
end
|
||||||
|
|||||||
@@ -1,8 +1,8 @@
|
|||||||
# frozen_string_literal: true
|
# frozen_string_literal: true
|
||||||
|
|
||||||
class Admin::Metrics::Dimension::SpaceUsageDimension < Admin::Metrics::Dimension::BaseDimension
|
class Admin::Metrics::Dimension::SpaceUsageDimension < Admin::Metrics::Dimension::BaseDimension
|
||||||
include Redisable
|
|
||||||
include ActionView::Helpers::NumberHelper
|
include ActionView::Helpers::NumberHelper
|
||||||
|
include Admin::Metrics::Dimension::StoreHelper
|
||||||
|
|
||||||
def key
|
def key
|
||||||
'space_usage'
|
'space_usage'
|
||||||
@@ -27,14 +27,12 @@ class Admin::Metrics::Dimension::SpaceUsageDimension < Admin::Metrics::Dimension
|
|||||||
end
|
end
|
||||||
|
|
||||||
def redis_size
|
def redis_size
|
||||||
value = redis_info['used_memory']
|
|
||||||
|
|
||||||
{
|
{
|
||||||
key: 'redis',
|
key: 'redis',
|
||||||
human_key: 'Redis',
|
human_key: store_name,
|
||||||
value: value.to_s,
|
value: store_size.to_s,
|
||||||
unit: 'bytes',
|
unit: 'bytes',
|
||||||
human_value: number_to_human_size(value),
|
human_value: number_to_human_size(store_size),
|
||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
@@ -57,10 +55,6 @@ class Admin::Metrics::Dimension::SpaceUsageDimension < Admin::Metrics::Dimension
|
|||||||
}
|
}
|
||||||
end
|
end
|
||||||
|
|
||||||
def redis_info
|
|
||||||
@redis_info ||= redis.info
|
|
||||||
end
|
|
||||||
|
|
||||||
def search_size
|
def search_size
|
||||||
return unless Chewy.enabled?
|
return unless Chewy.enabled?
|
||||||
|
|
||||||
|
|||||||
26
app/lib/admin/metrics/dimension/store_helper.rb
Normal file
26
app/lib/admin/metrics/dimension/store_helper.rb
Normal 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
|
||||||
@@ -9,14 +9,44 @@ RSpec.describe Admin::Metrics::Dimension::SoftwareVersionsDimension do
|
|||||||
let(:end_at) { Time.now.utc }
|
let(:end_at) { Time.now.utc }
|
||||||
let(:limit) { 10 }
|
let(:limit) { 10 }
|
||||||
let(:params) { ActionController::Parameters.new }
|
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
|
describe '#data' do
|
||||||
|
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
|
it 'reports on the running software' do
|
||||||
expect(subject.data.map(&:symbolize_keys))
|
expect(subject.data.map(&:symbolize_keys))
|
||||||
.to include(
|
.to include(
|
||||||
include(key: 'mastodon', value: Mastodon::Version.to_s),
|
include(key: 'mastodon', value: Mastodon::Version.to_s),
|
||||||
include(key: 'ruby', value: include(RUBY_VERSION))
|
include(key: 'ruby', value: include(RUBY_VERSION)),
|
||||||
|
include(key: 'redis', human_key: redis_human_key, value: redis_version)
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
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
|
end
|
||||||
|
|||||||
@@ -10,14 +10,41 @@ RSpec.describe Admin::Metrics::Dimension::SpaceUsageDimension do
|
|||||||
let(:limit) { 10 }
|
let(:limit) { 10 }
|
||||||
let(:params) { ActionController::Parameters.new }
|
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
|
describe '#data' do
|
||||||
|
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
|
it 'reports on used storage space' do
|
||||||
expect(subject.data.map(&:symbolize_keys))
|
expect(subject.data.map(&:symbolize_keys))
|
||||||
.to include(
|
.to include(
|
||||||
include(key: 'media', value: /\d/),
|
include(key: 'media', value: /\d/),
|
||||||
include(key: 'postgresql', value: /\d/),
|
include(key: 'postgresql', value: /\d/),
|
||||||
include(key: 'redis', value: /\d/)
|
include(key: 'redis', human_key: redis_human_key, value: /\d/)
|
||||||
)
|
)
|
||||||
end
|
end
|
||||||
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
|
end
|
||||||
|
|||||||
Reference in New Issue
Block a user