[why] we have some providers: ipxe, container, libvirt
all of them need register testbox info and consume job from scheduler
Signed-off-by: Xiao Shenwei xiaoshenwei96@163.com --- lib/sched_client.rb | 39 +++++++++++++++++++++++++++++++++++++++ 1 file changed, 39 insertions(+)
diff --git a/lib/sched_client.rb b/lib/sched_client.rb index fec4b14..b317790 100644 --- a/lib/sched_client.rb +++ b/lib/sched_client.rb @@ -16,4 +16,43 @@ class SchedClient resource = RestClient::Resource.new("http://#%7B@host%7D:#%7B@port%7D/submit_job") resource.post(job_json) end + + # scheduler API /boot.:boot_type/:parameter/:value + # boot_type parameter + # 1 ipxe mac + # 2 container hostname + # 3 libvirt mac + def consume_job(boot_type, parameter, value) + RestClient.get "http://#%7B@host%7D:#%7B@port%7D/boot.#%7Bboot_type%7D/#%7Bparameter%7D/#%7B..." + end + + # some provider only need register host2queues + # like boot.container + def register_mac2host(hostname, mac) + @hostname = hostname + @mac = mac + RestClient.put( + "http://#%7B@host%7D:#%7B@port%7D/set_host_mac?hostname=#%7B@hostname%7D&...", {} + ) + end + + def register_host2queues(hostname, queues) + @hostname = hostname + @queues = queues + RestClient.put( + "http://#%7B@host%7D:#%7B@port%7D/set_host2queues?host=#%7B@hostname%7D&q...", {} + ) + end + + def delete_mac2host + RestClient.put( + "http://#%7B@host%7D:#%7B@port%7D/del_host_mac?mac=#%7B@mac%7D", {} + ) + end + + def delete_host2queues + RestClient.put( + "http://#%7B@host%7D:#%7B@port%7D/del_host2queues?host=#%7B@hostname%7D", {} + ) + end end