forked from CenterForOpenScience/osf.io
-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
add contributor page improvements for Institutional Access
- Loading branch information
John Tordoff
committed
Dec 5, 2024
1 parent
869c146
commit daa9814
Showing
5 changed files
with
180 additions
and
0 deletions.
There are no files selected for viewing
59 changes: 59 additions & 0 deletions
59
api_tests/nodes/views/test_node_contributor_insti_admin.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,59 @@ | ||
|
||
import pytest | ||
from osf.models import Contributor, NodeLog | ||
from osf_tests.factories import ( | ||
AuthUserFactory, | ||
ProjectFactory, | ||
InstitutionFactory, | ||
) | ||
from api.base.settings.defaults import API_BASE | ||
from rest_framework import status | ||
from tests.utils import assert_latest_log | ||
|
||
|
||
@pytest.mark.django_db | ||
class TestChangeInstitutionalAdminContributor: | ||
|
||
@pytest.fixture() | ||
def user(self): | ||
return AuthUserFactory() | ||
|
||
@pytest.fixture() | ||
def institution(self): | ||
return InstitutionFactory() | ||
|
||
@pytest.fixture() | ||
def institutional_admin(self, institution): | ||
admin_user = AuthUserFactory() | ||
institution.get_group('institutional_admins').user_set.add(admin_user) | ||
return admin_user | ||
|
||
@pytest.fixture() | ||
def project(self, user, institutional_admin): | ||
project = ProjectFactory(creator=user) | ||
project.add_contributor(institutional_admin, visible=False) | ||
return project | ||
|
||
@pytest.fixture() | ||
def url_contrib(self, project, user): | ||
return f'/{API_BASE}nodes/{project._id}/contributors/{user._id}/' | ||
|
||
def test_cannot_set_institutional_admin_contributor_bibliographic( | ||
self, app, user, project, institutional_admin, url_contrib): | ||
contrib_id = f'{project._id}-{institutional_admin._id}' | ||
|
||
data = { | ||
'data': { | ||
'id': contrib_id, | ||
'type': 'contributors', | ||
'attributes': { | ||
'bibliographic': True, | ||
} | ||
} | ||
} | ||
res = app.put_json_api(url_contrib, data, auth=user.auth, expect_errors=True) | ||
print(res.__dict__) | ||
assert res.status_code == status.HTTP_400_BAD_REQUEST | ||
project.reload() | ||
contributor = Contributor.objects.get(id=institutional_admin_contributor.id) | ||
assert not contributor.visible # Bibliographic is tied to visible |
23 changes: 23 additions & 0 deletions
23
osf/migrations/0025_contributor_institutional_admin_and_more.py
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
# Generated by Django 4.2.13 on 2024-12-04 23:25 | ||
|
||
from django.db import migrations, models | ||
import django.db.models.deletion | ||
|
||
|
||
class Migration(migrations.Migration): | ||
|
||
dependencies = [ | ||
('osf', '0024_institution_link_to_external_reports_archive'), | ||
] | ||
|
||
operations = [ | ||
migrations.AddField( | ||
model_name='contributor', | ||
name='institutional_admin', | ||
field=models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.CASCADE, to='osf.institution'), | ||
), | ||
migrations.AddConstraint( | ||
model_name='contributor', | ||
constraint=models.CheckConstraint(check=models.Q(('visible', True), ('institutional_admin__isnull', False), _negated=True), name='no_visible_with_institutional_admin'), | ||
), | ||
] |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,75 @@ | ||
import pytest | ||
from django.core.exceptions import ValidationError | ||
from osf.models import Contributor, Institution | ||
from osf_tests.factories import AuthUserFactory, ProjectFactory, InstitutionFactory | ||
from django.db.utils import IntegrityError | ||
|
||
@pytest.mark.django_db | ||
class TestContributorModel: | ||
|
||
@pytest.fixture() | ||
def user(self): | ||
return AuthUserFactory() | ||
|
||
@pytest.fixture() | ||
def project(self, user): | ||
return ProjectFactory(creator=user) | ||
|
||
@pytest.fixture() | ||
def institution(self): | ||
return InstitutionFactory() | ||
|
||
def test_contributor_with_visible_and_institutional_admin_raises_error(self, user, project, institution): | ||
contributor = Contributor( | ||
user=user, | ||
node=project, | ||
visible=True, | ||
institutional_admin=institution | ||
) | ||
with pytest.raises(IntegrityError, match='new row for relation "osf_contributor" violates check constraint "no_visible_with_institutional_admin"'): | ||
contributor.save() # Use clean() for validation logic | ||
|
||
def test_contributor_with_visible_but_no_institutional_admin(self, user, project): | ||
# Ensure no duplicate contributor exists | ||
Contributor.objects.filter(user=user, node=project).delete() | ||
|
||
contributor = Contributor( | ||
user=user, | ||
node=project, | ||
visible=True, | ||
institutional_admin=None | ||
) | ||
# This should not raise an error | ||
contributor.save() | ||
|
||
def test_contributor_with_institutional_admin_but_not_visible(self, user, project, institution): | ||
# Ensure no duplicate contributor exists | ||
Contributor.objects.filter(user=user, node=project).delete() | ||
|
||
contributor = Contributor( | ||
user=user, | ||
node=project, | ||
visible=False, | ||
institutional_admin=institution | ||
) | ||
# This should not raise an error | ||
contributor.save() | ||
|
||
def test_database_constraint_no_visible_with_institutional_admin(self, user, project, institution): | ||
# Ensure no duplicate contributor exists | ||
Contributor.objects.filter(user=user, node=project).delete() | ||
|
||
Contributor.objects.create( | ||
user=user, | ||
node=project, | ||
visible=False, | ||
institutional_admin=institution | ||
) # Should succeed | ||
|
||
with pytest.raises(Exception): # Check database constraint | ||
Contributor.objects.create( | ||
user=user, | ||
node=project, | ||
visible=True, | ||
institutional_admin=institution | ||
) |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters