From: Tom Clegg Date: Mon, 6 Oct 2014 13:59:36 +0000 (-0400) Subject: 3882: refactor update-or-cancel code. X-Git-Tag: 1.1.0~2121^2~4^2 X-Git-Url: https://git.arvados.org/arvados.git/commitdiff_plain/8018af97c6ac3ca2d6b7acf8dd7c21ee0f290436 3882: refactor update-or-cancel code. --- diff --git a/services/api/test/functional/arvados/v1/jobs_controller_test.rb b/services/api/test/functional/arvados/v1/jobs_controller_test.rb index c28cdf7dac..7f4b9d52ce 100644 --- a/services/api/test/functional/arvados/v1/jobs_controller_test.rb +++ b/services/api/test/functional/arvados/v1/jobs_controller_test.rb @@ -102,14 +102,14 @@ class Arvados::V1::JobsControllerTest < ActionController::TestCase end [ - ['cancelled_at', Time.now, :success], - ['state', 'Cancelled', :success], - ['state', 'Running', :unprocessable_entity], - ['state', 'Failed', :unprocessable_entity], - ['state', 'Complete', :unprocessable_entity], - [:use_action, :cancel, :success], - ].each do |attribute, value, expected_response| - test "cancelled job stays cancelled when updated using #{attribute} #{value}" do + [:put, :update, {job:{cancelled_at: Time.now}}, :success], + [:put, :update, {job:{state: 'Cancelled'}}, :success], + [:put, :update, {job:{state: 'Running'}}, :unprocessable_entity], + [:put, :update, {job:{state: 'Failed'}}, :unprocessable_entity], + [:put, :update, {job:{state: 'Complete'}}, :unprocessable_entity], + [:post, :cancel, {}, :success], + ].each do |http_method, action, params, expected_response| + test "cancelled job stays cancelled after #{[http_method, action, params].inspect}" do # We need to verify that "cancel" creates a trigger file, so first # let's make sure there is no stale trigger file. begin @@ -118,20 +118,15 @@ class Arvados::V1::JobsControllerTest < ActionController::TestCase end authorize_with :active - if attribute == :use_action - post value, { id: jobs(:cancelled).uuid } - else - put :update, { - id: jobs(:cancelled).uuid, - job: { - attribute => value - } - } - end + self.send http_method, action, { id: jobs(:cancelled).uuid }.merge(params) assert_response expected_response - job = json_response - assert_not_nil job['cancelled_at'], 'job cancelled again using #{attribute}=#{value} did not have cancelled_at value' - assert_equal job['state'], 'Cancelled', 'cancelled again job state changed when updated using using #{attribute}=#{value}' + if expected_response == :success + job = json_response + assert_not_nil job['cancelled_at'], 'job cancelled again using #{attribute}=#{value} did not have cancelled_at value' + assert_equal job['state'], 'Cancelled', 'cancelled again job state changed when updated using using #{attribute}=#{value}' + end + # Verify database record still says Cancelled + assert_equal 'Cancelled', Job.find(jobs(:cancelled).id).state, 'job was un-cancelled' end end