X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/66c13b6055a363cb08197b8c5d040ed9a511c8ca..d8616b7126de7e234b901b9bb166b5e4203da3c0:/services/api/test/functional/arvados/v1/nodes_controller_test.rb diff --git a/services/api/test/functional/arvados/v1/nodes_controller_test.rb b/services/api/test/functional/arvados/v1/nodes_controller_test.rb index d74450587d..428c663a77 100644 --- a/services/api/test/functional/arvados/v1/nodes_controller_test.rb +++ b/services/api/test/functional/arvados/v1/nodes_controller_test.rb @@ -108,6 +108,14 @@ class Arvados::V1::NodesControllerTest < ActionController::TestCase assert_nil(json_response["job"], "spectator can see node's assigned job") end + [:admin, :spectator].each do |user| + test "select param does not break node list for #{user}" do + authorize_with user + get :index, {select: ['domain']} + assert_response :success + end + end + test "admin can associate a job with a node" do changed_node = nodes(:idle) assigned_job = jobs(:queued) @@ -165,4 +173,51 @@ class Arvados::V1::NodesControllerTest < ActionController::TestCase assert_equal(jobs(:nearly_finished_job).uuid, json_response["job_uuid"], "mismatched job UUID after ping update") end + + test "node should fail ping with invalid hostname config format" do + Rails.configuration.assign_node_hostname = 'compute%04' # should end with "04d" + post :ping, { + id: nodes(:new_with_no_hostname).uuid, + ping_secret: nodes(:new_with_no_hostname).info['ping_secret'], + } + assert_response 422 + end + + test "first ping should set ip addr using local_ipv4 when provided" do + post :ping, { + id: 'zzzzz-7ekkf-nodenoipaddryet', + instance_id: 'i-0000000', + local_ipv4: '172.17.2.172', + ping_secret: 'abcdyefg4lb5q4gzqqtrnq30oyj08r8dtdimmanbqw49z1anz2' + } + assert_response :success + response = JSON.parse(@response.body) + assert_equal 'zzzzz-7ekkf-nodenoipaddryet', response['uuid'] + assert_equal '172.17.2.172', response['ip_address'] + end + + test "first ping should set ip addr using remote_ip when local_ipv4 is not provided" do + post :ping, { + id: 'zzzzz-7ekkf-nodenoipaddryet', + instance_id: 'i-0000000', + ping_secret: 'abcdyefg4lb5q4gzqqtrnq30oyj08r8dtdimmanbqw49z1anz2' + } + assert_response :success + response = JSON.parse(@response.body) + assert_equal 'zzzzz-7ekkf-nodenoipaddryet', response['uuid'] + assert_equal request.remote_ip, response['ip_address'] + end + + test "future pings should not change previous ip address" do + post :ping, { + id: 'zzzzz-7ekkf-2z3mc76g2q73aio', + instance_id: 'i-0000000', + local_ipv4: '172.17.2.175', + ping_secret: '69udawxvn3zzj45hs8bumvndricrha4lcpi23pd69e44soanc0' + } + assert_response :success + response = JSON.parse(@response.body) + assert_equal 'zzzzz-7ekkf-2z3mc76g2q73aio', response['uuid'] + assert_equal '172.17.2.174', response['ip_address'] # original ip address is not overwritten + end end