-
Notifications
You must be signed in to change notification settings - Fork 43
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
Implement Ceph multiple pools and tests #167
base: master
Are you sure you want to change the base?
Changes from 1 commit
File filter
Filter by extension
Conversations
Jump to
Diff view
Diff view
There are no files selected for viewing
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -346,13 +346,13 @@ | |
|
||
volumes.each_with_index do |volume, index| | ||
target_device = "vd#{('a'..'z').to_a[index]}" | ||
if ceph_args && volume.pool_name.include?(ceph_args["libvirt_ceph_pool"]) | ||
if ceph_args && ceph_args["libvirt_ceph_pools"]&.include?(volume.pool_name) | ||
xml.disk(:type => "network", :device => "disk") do | ||
xml.driver(:name => "qemu", :type => volume.format_type, :cache => "writeback", :discard => "unmap") | ||
xml.source(:protocol => "rbd", :name => volume.path) | ||
|
||
ceph_args["monitor"]&.split(",")&.each do |monitor| | ||
xml.host(:name => monitor, :port => ceph_args["port"]) | ||
xml.source(:protocol => "rbd", :name => volume.path) do | ||
ceph_args["monitor"]&.each do |monitor| | ||
xml.host(:name => monitor, :port => ceph_args["port"]) | ||
end | ||
end | ||
|
||
xml.auth(:username => ceph_args["auth_username"]) do | ||
|
@@ -458,13 +458,20 @@ | |
|
||
args = {} | ||
|
||
valid_keys = ["monitor", "port", "libvirt_ceph_pools", "auth_username", "auth_uuid", "bus_type"] | ||
Check warning on line 461 in lib/fog/libvirt/models/compute/server.rb GitHub Actions / runner / rubocop
|
||
array_values = ["monitor", "libvirt_ceph_pools"] | ||
|
||
File.readlines(path).each do |line| | ||
pair = line.strip.split("=") | ||
key = pair[0] | ||
value = pair[1] | ||
args[key] = value | ||
key = pair[0].strip | ||
if valid_keys.include?(key) | ||
value = array_values.include?(key) ? pair[1].split(',').map(&:strip) : pair[1].strip | ||
args[key] = value | ||
end | ||
end | ||
|
||
puts args | ||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. This looks like debug code There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Oups. I will remove that :) |
||
|
||
args | ||
end | ||
|
||
|
Original file line number | Diff line number | Diff line change | ||||||||||||
---|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
@@ -1,10 +1,50 @@ | ||||||||||||||
RealFile = File | ||||||||||||||
class FakeFile < RealFile | ||||||||||||||
def self.file?(path) | ||||||||||||||
if path == '/etc/foreman/ceph.conf' | ||||||||||||||
Check warning on line 4 in tests/libvirt/models/compute/server_tests.rb GitHub Actions / runner / rubocop
|
||||||||||||||
return true | ||||||||||||||
Check warning on line 5 in tests/libvirt/models/compute/server_tests.rb GitHub Actions / runner / rubocop
|
||||||||||||||
else | ||||||||||||||
return RealFile.file(path) | ||||||||||||||
Check warning on line 7 in tests/libvirt/models/compute/server_tests.rb GitHub Actions / runner / rubocop
|
||||||||||||||
end | ||||||||||||||
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. To remove some RuboCop concerns, perhaps reduce it to
Suggested change
There was a problem hiding this comment. Choose a reason for hiding this commentThe reason will be displayed to describe this comment to others. Learn more. Nice ! I will change that. I'm more used to developing in Python than in Ruby. |
||||||||||||||
end | ||||||||||||||
|
||||||||||||||
def self.readlines(path) | ||||||||||||||
if path == '/etc/foreman/ceph.conf' | ||||||||||||||
Check warning on line 12 in tests/libvirt/models/compute/server_tests.rb GitHub Actions / runner / rubocop
|
||||||||||||||
return [ | ||||||||||||||
Check warning on line 13 in tests/libvirt/models/compute/server_tests.rb GitHub Actions / runner / rubocop
|
||||||||||||||
"monitor=mon001.example.com,mon002.example.com,mon003.example.com", | ||||||||||||||
"port=6789", | ||||||||||||||
"libvirt_ceph_pools=rbd_pool_name,second_rbd_pool_name", | ||||||||||||||
"auth_username=libvirt", | ||||||||||||||
"auth_uuid=uuid_of_libvirt_secret", | ||||||||||||||
"bus_type=virtio" | ||||||||||||||
] | ||||||||||||||
else | ||||||||||||||
return RealFile.readlines(path) | ||||||||||||||
Check warning on line 22 in tests/libvirt/models/compute/server_tests.rb GitHub Actions / runner / rubocop
|
||||||||||||||
end | ||||||||||||||
end | ||||||||||||||
end | ||||||||||||||
|
||||||||||||||
Shindo.tests('Fog::Compute[:libvirt] | server model', ['libvirt']) do | ||||||||||||||
|
||||||||||||||
servers = Fog::Compute[:libvirt].servers | ||||||||||||||
# Match the mac in dhcp_leases mock | ||||||||||||||
nics = Fog.mock? ? [{ :type => 'network', :network => 'default', :mac => 'aa:bb:cc:dd:ee:ff' }] : nil | ||||||||||||||
server = servers.create(:name => Fog::Mock.random_letters(8), :nics => nics) | ||||||||||||||
|
||||||||||||||
before do | ||||||||||||||
Object.class_eval do | ||||||||||||||
remove_const(:File) | ||||||||||||||
const_set(:File, FakeFile) | ||||||||||||||
end | ||||||||||||||
end | ||||||||||||||
|
||||||||||||||
after do | ||||||||||||||
Object.class_eval do | ||||||||||||||
remove_const(:File) | ||||||||||||||
const_set(:File, RealFile) | ||||||||||||||
end | ||||||||||||||
end | ||||||||||||||
|
||||||||||||||
tests('The server model should') do | ||||||||||||||
tests('have the action') do | ||||||||||||||
test('autostart') { server.respond_to? 'autostart' } | ||||||||||||||
|
@@ -89,6 +129,26 @@ | |||||||||||||
xml = server.to_xml | ||||||||||||||
xml.match?(/<disk type="block" device="disk">/) && xml.match?(%r{<source dev="/dev/sda"/>}) | ||||||||||||||
end | ||||||||||||||
test("with disk of type ceph") do | ||||||||||||||
server = Fog::Libvirt::Compute::Server.new( | ||||||||||||||
{ | ||||||||||||||
:nics => [], | ||||||||||||||
:volumes => [ | ||||||||||||||
Fog::Libvirt::Compute::Volume.new({ :path => "rbd_pool_name/block-1", :pool_name => "rbd_pool_name" }) | ||||||||||||||
] | ||||||||||||||
} | ||||||||||||||
) | ||||||||||||||
|
||||||||||||||
Check warning on line 141 in tests/libvirt/models/compute/server_tests.rb GitHub Actions / runner / rubocop
|
||||||||||||||
xml = server.to_xml | ||||||||||||||
|
||||||||||||||
network_disk = xml.match?(/<disk type="network" device="disk">/) | ||||||||||||||
mon_host = xml.match?(%r{<host name="mon001.example.com" port="6789"/>}) | ||||||||||||||
source_rbd = xml.match?(%r{<source protocol="rbd" name="rbd_pool_name/block-1">}) | ||||||||||||||
auth_username = xml.match?(/<auth username="libvirt">/) | ||||||||||||||
auth_secret = xml.match?(%r{<secret type="ceph" uuid="uuid_of_libvirt_secret"/>}) | ||||||||||||||
|
||||||||||||||
network_disk && mon_host && source_rbd && auth_username && auth_secret | ||||||||||||||
end | ||||||||||||||
test("with q35 machine type on x86_64") { server.to_xml.match?(%r{<type arch="x86_64" machine="q35">hvm</type>}) } | ||||||||||||||
end | ||||||||||||||
test("with efi firmware") do | ||||||||||||||
|
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
Is there a reason to limit this? Wouldn't it be safe to just parse everything?
There was a problem hiding this comment.
Choose a reason for hiding this comment
The reason will be displayed to describe this comment to others. Learn more.
The configuration file can contains some comments or extra lines. So I think it's better to only import configuration line respecting a minimal schema.