- # Once project is frozen, cannot create new items inside it or
- # its descendants
- [proj, proj_inner].each do |frozen|
- assert_raises do
- collections(:collection_owned_by_active).update_attributes!(owner_uuid: frozen.uuid)
- end
- assert_raises do
- Collection.create!(owner_uuid: frozen.uuid, name: 'inside-frozen-project')
- end
- assert_raises do
- Group.create!(owner_uuid: frozen.uuid, group_class: 'project', name: 'inside-frozen-project')
- end
- cr = ContainerRequest.new(
- command: ["echo", "foo"],
- container_image: links(:docker_image_collection_tag).name,
- cwd: "/tmp",
- environment: {},
- mounts: {"/out" => {"kind" => "tmp", "capacity" => 1000000}},
- output_path: "/out",
- runtime_constraints: {"vcpus" => 1, "ram" => 2},
- name: "foo",
- description: "bar",
- owner_uuid: frozen.uuid,
- )
- assert_raises ArvadosModel::PermissionDeniedError do
- cr.save
- end
- assert_match /frozen/, cr.errors.inspect
- # Check the frozen-parent condition is the only reason save failed.
- cr.owner_uuid = users(:active).uuid
- assert cr.save
- cr.destroy
- end
-
- # Once project is frozen, cannot change name/contents, move,
- # trash, or delete the project or anything beneath it
- [proj, proj_inner, coll].each do |frozen|
- assert_raises(StandardError, "should reject rename of #{frozen.uuid} with parent #{frozen.owner_uuid}") do
- frozen.update_attributes!(name: 'foo2')
- end
- frozen.reload
-
- if frozen.is_a?(Collection)
- assert_raises(StandardError, "should reject manifest change of #{frozen.uuid}") do
- frozen.update_attributes!(manifest_text: ". d41d8cd98f00b204e9800998ecf8427e+0 0:0:foo\n")
+ [:active, :admin].each do |u|
+ act_as_user users(u) do
+ # Once project is frozen, cannot create new items inside it or
+ # its descendants
+ [proj, proj_inner].each do |frozen|
+ assert_raises do
+ collections(:collection_owned_by_active).update!(owner_uuid: frozen.uuid)
+ end
+ assert_raises do
+ Collection.create!(owner_uuid: frozen.uuid, name: 'inside-frozen-project')
+ end
+ assert_raises do
+ Group.create!(owner_uuid: frozen.uuid, group_class: 'project', name: 'inside-frozen-project')
+ end
+ cr = ContainerRequest.new(test_cr_attrs.merge(owner_uuid: frozen.uuid))
+ assert_raises ArvadosModel::PermissionDeniedError do
+ cr.save
+ end
+ assert_match /frozen/, cr.errors.inspect
+ # Check the frozen-parent condition is the only reason save failed.
+ cr.owner_uuid = users(u).uuid
+ assert cr.save
+ cr.destroy