X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/2a5192a38e2d5cde2f7b974c0f6ec5a615d6e139..0035033f6bf6db955b116e2e0cc052bc5c79d80e:/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 d2f56699ed..b4ddd78554 100644 --- a/services/api/test/functional/arvados/v1/nodes_controller_test.rb +++ b/services/api/test/functional/arvados/v1/nodes_controller_test.rb @@ -17,8 +17,8 @@ class Arvados::V1::NodesControllerTest < ActionController::TestCase authorize_with :inactive get :index assert_response :success - node_items = JSON.parse(@response.body)['items'] - assert_equal 0, node_items.size + assert_equal 0, json_response['items'].size + assert_equal 0, json_response['items_available'] end # active user sees non-secret attributes of up and recently-up nodes @@ -26,8 +26,9 @@ class Arvados::V1::NodesControllerTest < ActionController::TestCase authorize_with :active get :index assert_response :success - node_items = JSON.parse(@response.body)['items'] - assert_not_equal 0, node_items.size + assert_operator 0, :<, json_response['items_available'] + node_items = json_response['items'] + assert_operator 0, :<, node_items.size found_busy_node = false node_items.each do |node| assert_nil node['info'].andand['ping_secret'] @@ -113,6 +114,7 @@ class Arvados::V1::NodesControllerTest < ActionController::TestCase authorize_with user get :index, {select: ['domain']} assert_response :success + assert_operator 0, :<, json_response['items_available'] end end @@ -182,4 +184,42 @@ class Arvados::V1::NodesControllerTest < ActionController::TestCase } 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