X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/cb79358321eff7a49dd4a3fb6e0ea448ead92597..e7d49ab46462902a98d812b69d7257d837f85e90:/apps/workbench/test/test_helper.rb diff --git a/apps/workbench/test/test_helper.rb b/apps/workbench/test/test_helper.rb index 078190bd32..78ef2d21f1 100644 --- a/apps/workbench/test/test_helper.rb +++ b/apps/workbench/test/test_helper.rb @@ -32,11 +32,19 @@ class ActiveSupport::TestCase # in integration tests -- they do not yet inherit this setting fixtures :all def use_token token_name + was = Thread.current[:arvados_api_token] auth = api_fixture('api_client_authorizations')[token_name.to_s] Thread.current[:arvados_api_token] = auth['api_token'] + if block_given? + begin + yield + ensure + Thread.current[:arvados_api_token] = was + end + end end - setup do + teardown do Thread.current[:arvados_api_token] = nil Thread.current[:user] = nil Thread.current[:reader_tokens] = nil @@ -86,6 +94,47 @@ module ApiFixtureLoader end end +module ApiMockHelpers + def fake_api_response body, status_code, headers + resp = mock + resp.responds_like_instance_of HTTP::Message + resp.stubs(:headers).returns headers + resp.stubs(:content).returns body + resp.stubs(:status_code).returns status_code + resp + end + + def stub_api_calls_with_body body, status_code=200, headers={} + stub_api_calls + resp = fake_api_response body, status_code, headers + stub_api_client.stubs(:post).returns resp + end + + def stub_api_calls + @stubbed_client = ArvadosApiClient.new + @stubbed_client.instance_eval do + @api_client = HTTPClient.new + end + ArvadosApiClient.stubs(:new_or_current).returns(@stubbed_client) + end + + def stub_api_calls_with_invalid_json + stub_api_calls_with_body ']"omg,bogus"[' + end + + # Return the HTTPClient mock used by the ArvadosApiClient mock. You + # must have called stub_api_calls first. + def stub_api_client + @stubbed_client.instance_eval do + @api_client + end + end +end + +class ActiveSupport::TestCase + include ApiMockHelpers +end + class ActiveSupport::TestCase include ApiFixtureLoader def session_for api_client_auth_name @@ -106,7 +155,7 @@ class ApiServerForTests @main_process_pid = $$ @@server_is_running = false - def check_call *args + def check_output *args output = nil Bundler.with_clean_env do output = IO.popen *args do |io| @@ -122,7 +171,15 @@ class ApiServerForTests def run_test_server env_script = nil Dir.chdir PYTHON_TESTS_DIR do - env_script = check_call %w(python ./run_test_server.py start --auth admin) + # These are no-ops if we're running within run-tests.sh (except + # that we do get a useful env_script back from "start", even + # though it doesn't need to start up a new server). + env_script = check_output %w(python ./run_test_server.py start --auth admin) + check_output %w(python ./run_test_server.py start_arv-git-httpd) + check_output %w(python ./run_test_server.py start_keep-web) + check_output %w(python ./run_test_server.py start_nginx) + # This one isn't a no-op, even under run-tests.sh. + check_output %w(python ./run_test_server.py start_keep) end test_env = {} env_script.each_line do |line| @@ -138,8 +195,12 @@ class ApiServerForTests def stop_test_server Dir.chdir PYTHON_TESTS_DIR do - # This is a no-op if we're running within run-tests.sh - check_call %w(python ./run_test_server.py stop) + check_output %w(python ./run_test_server.py stop_keep) + # These are no-ops if we're running within run-tests.sh + check_output %w(python ./run_test_server.py stop_nginx) + check_output %w(python ./run_test_server.py stop_arv-git-httpd) + check_output %w(python ./run_test_server.py stop_keep-web) + check_output %w(python ./run_test_server.py stop) end @@server_is_running = false end @@ -165,19 +226,19 @@ class ApiServerForTests def run_rake_task task_name, arg_string Dir.chdir ARV_API_SERVER_DIR do - check_call ['bundle', 'exec', 'rake', "#{task_name}[#{arg_string}]"] + check_output ['bundle', 'exec', 'rake', "#{task_name}[#{arg_string}]"] end end end class ActionController::TestCase setup do - @counter = 0 + @test_counter = 0 end def check_counter action - @counter += 1 - if @counter == 2 + @test_counter += 1 + if @test_counter == 2 assert_equal 1, 2, "Multiple actions in controller test" end end @@ -239,12 +300,17 @@ class ActiveSupport::TestCase end def after_teardown - if self.class.want_reset_api_fixtures[:after_each_test] + if self.class.want_reset_api_fixtures[:after_each_test] and + @want_reset_api_fixtures != false self.class.reset_api_fixtures_now end super end + def reset_api_fixtures_after_test t=true + @want_reset_api_fixtures = t + end + protected def self.reset_api_fixtures_now # Never try to reset fixtures when we're just using test