- # test the redaction of an old version of a relation, while not being
- # authorised.
- def test_redact_relation_unauthorised
- relation = create(:relation, :with_history, :version => 4)
- relation_v3 = relation.old_relations.find_by(:version => 3)
-
- do_redact_relation(relation_v3, create(:redaction))
- assert_response :unauthorized, "should need to be authenticated to redact."
- end
-
- ##
- # test the redaction of an old version of a relation, while being
- # authorised as a normal user.
- def test_redact_relation_normal_user
- relation = create(:relation, :with_history, :version => 4)
- relation_v3 = relation.old_relations.find_by(:version => 3)
-
- auth_header = bearer_authorization_header
-
- do_redact_relation(relation_v3, create(:redaction), auth_header)
- assert_response :forbidden, "should need to be moderator to redact."
- end
-
- ##
- # test that, even as moderator, the current version of a relation
- # can't be redacted.
- def test_redact_relation_current_version
- relation = create(:relation, :with_history, :version => 4)
- relation_latest = relation.old_relations.last
-
- auth_header = bearer_authorization_header create(:moderator_user)
-
- do_redact_relation(relation_latest, create(:redaction), auth_header)
- assert_response :bad_request, "shouldn't be OK to redact current version as moderator."
- end
-
- def test_redact_relation_by_regular_with_read_prefs_scope
- auth_header = bearer_authorization_header(create(:user), :scopes => %w[read_prefs])
- do_redact_redactable_relation(auth_header)
- assert_response :forbidden, "should need to be moderator to redact."
- end
-
- def test_redact_relation_by_regular_with_write_api_scope
- auth_header = bearer_authorization_header(create(:user), :scopes => %w[write_api])
- do_redact_redactable_relation(auth_header)
- assert_response :forbidden, "should need to be moderator to redact."
- end