X-Git-Url: https://git.arvados.org/arvados.git/blobdiff_plain/43773cb247a1fb744b57070b715bfa5d53a00822..6e86ca6fa82619f721643f2aabc81851cb1e272a:/services/api/test/unit/job_test.rb diff --git a/services/api/test/unit/job_test.rb b/services/api/test/unit/job_test.rb index 5079316934..5f53b2ab9b 100644 --- a/services/api/test/unit/job_test.rb +++ b/services/api/test/unit/job_test.rb @@ -1,7 +1,109 @@ require 'test_helper' class JobTest < ActiveSupport::TestCase - # test "the truth" do - # assert true - # end + BAD_COLLECTION = "#{'f' * 32}+0" + + setup do + set_user_from_auth :active + end + + test "Job without Docker image doesn't get locator" do + job = Job.new + assert job.valid? + assert_nil job.docker_image_locator + end + + { 'name' => [:links, :docker_image_collection_repository, :name], + 'hash' => [:links, :docker_image_collection_hash, :name], + 'locator' => [:collections, :docker_image, :uuid], + }.each_pair do |spec_type, (fixture_type, fixture_name, fixture_attr)| + test "Job initialized with Docker image #{spec_type} gets locator" do + image_spec = send(fixture_type, fixture_name).send(fixture_attr) + job = Job.new(runtime_constraints: {'docker_image' => image_spec}) + assert(job.valid?, "Docker image #{spec_type} was invalid") + assert_equal(collections(:docker_image).uuid, job.docker_image_locator) + end + + test "Job modified with Docker image #{spec_type} gets locator" do + job = Job.new + assert job.valid? + assert_nil job.docker_image_locator + image_spec = send(fixture_type, fixture_name).send(fixture_attr) + job.runtime_constraints['docker_image'] = image_spec + assert(job.valid?, "modified Docker image #{spec_type} was invalid") + assert_equal(collections(:docker_image).uuid, job.docker_image_locator) + end + end + + test "removing a Docker runtime constraint removes the locator" do + image_locator = collections(:docker_image).uuid + job = Job.new(runtime_constraints: {'docker_image' => image_locator}) + assert job.valid? + assert_equal(image_locator, job.docker_image_locator) + job.runtime_constraints = {} + assert(job.valid?, "clearing runtime constraints made the Job invalid") + assert_nil job.docker_image_locator + end + + test "locate a Docker image with a repository + tag" do + image_repo, image_tag = + links(:docker_image_collection_tag2).name.split(':', 2) + job = Job.new(runtime_constraints: + {'docker_image' => image_repo, + 'docker_image_tag' => image_tag}) + assert(job.valid?, "Job with Docker tag search invalid") + assert_equal(collections(:docker_image).uuid, job.docker_image_locator) + end + + test "can't locate a Docker image with a nonexistent tag" do + image_repo = links(:docker_image_collection_repository).name + image_tag = '__nonexistent tag__' + job = Job.new(runtime_constraints: + {'docker_image' => image_repo, + 'docker_image_tag' => image_tag}) + assert(job.invalid?, "Job with bad Docker tag valid") + end + + test "locate a Docker image with a partial hash" do + image_hash = links(:docker_image_collection_hash).name[0..24] + job = Job.new(runtime_constraints: {'docker_image' => image_hash}) + assert(job.valid?, "Job with partial Docker image hash failed") + assert_equal(collections(:docker_image).uuid, job.docker_image_locator) + end + + { 'name' => 'arvados_test_nonexistent', + 'hash' => 'f' * 64, + 'locator' => BAD_COLLECTION, + }.each_pair do |spec_type, image_spec| + test "Job validation fails with nonexistent Docker image #{spec_type}" do + job = Job.new(runtime_constraints: {'docker_image' => image_spec}) + assert(job.invalid?, "nonexistent Docker image #{spec_type} was valid") + end + end + + test "Job validation fails with non-Docker Collection constraint" do + job = Job.new(runtime_constraints: + {'docker_image' => collections(:foo_file).uuid}) + assert(job.invalid?, "non-Docker Collection constraint was valid") + end + + test "can't create Job with Docker image locator" do + begin + job = Job.new(docker_image_locator: BAD_COLLECTION) + rescue ActiveModel::MassAssignmentSecurity::Error + # Test passes - expected attribute protection + else + assert_nil job.docker_image_locator + end + end + + test "can't assign Docker image locator to Job" do + job = Job.new + begin + Job.docker_image_locator = BAD_COLLECTION + rescue NoMethodError + # Test passes - expected attribute protection + end + assert_nil job.docker_image_locator + end end