DocumentAuthor, rename author field to email and make it optional (for modeling old email-less submissions), remove the authors many to many referencing field from Document as it is not really pointing the right place. Update the Secretariat tools to show affiliation and country. Add migration for getting rid of the fake email addresses that the migration script created some years ago (just set the author email field to null). - Legacy-Id: 12739
438 lines
18 KiB
Python
438 lines
18 KiB
Python
# -*- coding: utf-8 -*-
|
|
import datetime
|
|
|
|
from django.conf import settings
|
|
from django.contrib.auth.models import User
|
|
|
|
import debug # pyflakes:ignore
|
|
|
|
from ietf.doc.models import Document, DocAlias, State, DocumentAuthor, BallotType, DocEvent, BallotDocEvent, RelatedDocument, NewRevisionDocEvent
|
|
from ietf.group.models import Group, GroupHistory, Role, RoleHistory
|
|
from ietf.iesg.models import TelechatDate
|
|
from ietf.ipr.models import HolderIprDisclosure, IprDocRel, IprDisclosureStateName, IprLicenseTypeName
|
|
from ietf.meeting.models import Meeting
|
|
from ietf.name.models import StreamName, DocRelationshipName
|
|
from ietf.person.models import Person, Email
|
|
from ietf.group.utils import setup_default_community_list_for_group
|
|
from ietf.review.models import (ReviewRequest, ReviewerSettings, ReviewResultName, ReviewTypeName, ReviewTeamSettings )
|
|
|
|
def create_person(group, role_name, name=None, username=None, email_address=None, password=None):
|
|
"""Add person/user/email and role."""
|
|
if not name:
|
|
name = group.acronym.capitalize() + " " + role_name.capitalize()
|
|
if not username:
|
|
username = group.acronym + "-" + role_name
|
|
if not email_address:
|
|
email_address = username + "@ietf.org"
|
|
if not password:
|
|
password = username + "+password"
|
|
|
|
user = User.objects.create(username=username)
|
|
user.set_password(password)
|
|
user.save()
|
|
person = Person.objects.create(name=name, ascii=name, user=user)
|
|
email = Email.objects.create(address=email_address, person=person)
|
|
Role.objects.create(group=group, name_id=role_name, person=person, email=email)
|
|
return person
|
|
|
|
def create_group(**kwargs):
|
|
group, created = Group.objects.get_or_create(state_id="active", **kwargs)
|
|
return group
|
|
|
|
def make_immutable_base_data():
|
|
"""Some base data (groups, etc.) that doesn't need to be modified by
|
|
tests and is thus safe to load once and for all at the start of
|
|
all tests in a run."""
|
|
|
|
# telechat dates
|
|
t = datetime.date.today()
|
|
old = TelechatDate.objects.create(date=t - datetime.timedelta(days=14)).date # pyflakes:ignore
|
|
date1 = TelechatDate.objects.create(date=t).date # pyflakes:ignore
|
|
date2 = TelechatDate.objects.create(date=t + datetime.timedelta(days=14)).date # pyflakes:ignore
|
|
date3 = TelechatDate.objects.create(date=t + datetime.timedelta(days=14 * 2)).date # pyflakes:ignore
|
|
date4 = TelechatDate.objects.create(date=t + datetime.timedelta(days=14 * 3)).date # pyflakes:ignore
|
|
|
|
# system
|
|
system_person = Person.objects.create(name="(System)", ascii="(System)", address="")
|
|
Email.objects.create(address="", person=system_person)
|
|
|
|
# high-level groups
|
|
ietf = create_group(name="IETF", acronym="ietf", type_id="ietf")
|
|
create_person(ietf, "chair")
|
|
create_person(ietf, "admdir")
|
|
|
|
irtf = create_group(name="IRTF", acronym="irtf", type_id="irtf")
|
|
create_person(irtf, "chair")
|
|
|
|
secretariat = create_group(name="IETF Secretariat", acronym="secretariat", type_id="ietf")
|
|
create_person(secretariat, "secr", name="Sec Retary", username="secretary")
|
|
|
|
iab = create_group(name="Internet Architecture Board", acronym="iab", type_id="ietf", parent=ietf)
|
|
create_person(iab, "chair")
|
|
|
|
ise = create_group(name="Independent Submission Editor", acronym="ise", type_id="ietf")
|
|
create_person(ise, "chair")
|
|
|
|
rsoc = create_group(name="RFC Series Oversight Committee", acronym="rsoc", type_id="ietf")
|
|
create_person(rsoc, "chair")
|
|
|
|
iepg = create_group(name="IEPG", acronym="iepg", type_id="ietf")
|
|
create_person(iepg, "chair")
|
|
|
|
iana = create_group(name="IANA", acronym="iana", type_id="ietf")
|
|
create_person(iana, "auth", name="Iña Iana", username="iana", email_address="iana@ia.na")
|
|
|
|
rfc_editor = create_group(name="RFC Editor", acronym="rfceditor", type_id="rfcedtyp")
|
|
create_person(rfc_editor, "auth", name="Rfc Editor", username="rfc", email_address="rfc@edit.or")
|
|
|
|
iesg = create_group(name="Internet Engineering Steering Group", acronym="iesg", type_id="ietf", parent=ietf) # pyflakes:ignore
|
|
|
|
individ = create_group(name="Individual submissions", acronym="none", type_id="individ") # pyflakes:ignore
|
|
|
|
# one area
|
|
area = create_group(name="Far Future", acronym="farfut", type_id="area", parent=ietf)
|
|
create_person(area, "ad", name=u"Areað Irector", username="ad", email_address="aread@ietf.org")
|
|
|
|
# second area
|
|
opsarea = create_group(name="Operations", acronym="ops", type_id="area", parent=ietf)
|
|
create_person(opsarea, "ad")
|
|
sops = create_group(name="Server Operations", acronym="sops", type_id="wg", parent=opsarea)
|
|
create_person(sops, "chair", name="Sops Chairman", username="sopschairman")
|
|
create_person(sops, "secr", name="Sops Secretary", username="sopssecretary")
|
|
|
|
# create a bunch of ads for swarm tests
|
|
for i in range(1, 10):
|
|
u = User.objects.create(username="ad%s" % i)
|
|
p = Person.objects.create(name="Ad No%s" % i, ascii="Ad No%s" % i, user=u)
|
|
email = Email.objects.create(address="ad%s@ietf.org" % i, person=p)
|
|
if i < 6:
|
|
# active
|
|
Role.objects.create(name_id="ad", group=area, person=p, email=email)
|
|
else:
|
|
# inactive
|
|
areahist = GroupHistory.objects.create(
|
|
group=area,
|
|
name=area.name,
|
|
acronym=area.acronym,
|
|
type_id=area.type_id,
|
|
state_id=area.state_id,
|
|
parent=area.parent
|
|
)
|
|
RoleHistory.objects.create(
|
|
name_id="ad",
|
|
group=areahist,
|
|
person=p,
|
|
email=email)
|
|
|
|
def make_test_data():
|
|
area = Group.objects.get(acronym="farfut")
|
|
ad = Person.objects.get(user__username="ad")
|
|
irtf = Group.objects.get(acronym='irtf')
|
|
|
|
# mars WG
|
|
group = Group.objects.create(
|
|
name="Martian Special Interest Group",
|
|
acronym="mars",
|
|
state_id="active",
|
|
type_id="wg",
|
|
parent=area,
|
|
list_email="mars-wg@ietf.org",
|
|
)
|
|
mars_wg = group
|
|
charter = Document.objects.create(
|
|
name="charter-ietf-" + group.acronym,
|
|
type_id="charter",
|
|
title=group.name,
|
|
group=group,
|
|
rev="00",
|
|
)
|
|
charter.set_state(State.objects.get(used=True, slug="approved", type="charter"))
|
|
group.charter = charter
|
|
group.save()
|
|
DocAlias.objects.create(
|
|
name=charter.name,
|
|
document=charter
|
|
)
|
|
setup_default_community_list_for_group(group)
|
|
|
|
# ames WG
|
|
group = Group.objects.create(
|
|
name="Asteroid Mining Equipment Standardization Group",
|
|
acronym="ames",
|
|
state_id="proposed",
|
|
type_id="wg",
|
|
parent=area,
|
|
list_email="ames-wg@ietf.org",
|
|
)
|
|
ames_wg = group
|
|
charter = Document.objects.create(
|
|
name="charter-ietf-" + group.acronym,
|
|
type_id="charter",
|
|
title=group.name,
|
|
group=group,
|
|
rev="00",
|
|
)
|
|
charter.set_state(State.objects.get(used=True, slug="infrev", type="charter"))
|
|
DocAlias.objects.create(
|
|
name=charter.name,
|
|
document=charter
|
|
)
|
|
group.charter = charter
|
|
group.save()
|
|
setup_default_community_list_for_group(group)
|
|
|
|
# irg RG
|
|
irg_rg = Group.objects.create(
|
|
name="Internet Research Group",
|
|
acronym="irg",
|
|
state_id="active",
|
|
type_id="rg",
|
|
parent=irtf,
|
|
list_email="irg-rg@ietf.org",
|
|
)
|
|
#charter = Document.objects.create(
|
|
# name="charter-ietf-" + group.acronym,
|
|
# type_id="charter",
|
|
# title=group.name,
|
|
# group=group,
|
|
# rev="00",
|
|
# )
|
|
#charter.set_state(State.objects.get(used=True, slug="infrev", type="charter"))
|
|
#DocAlias.objects.create(
|
|
# name=charter.name,
|
|
# document=charter
|
|
# )
|
|
#group.charter = charter
|
|
#group.save()
|
|
|
|
# plain IETF'er
|
|
u = User.objects.create(username="plain")
|
|
u.set_password("plain+password")
|
|
u.save()
|
|
plainman = Person.objects.create(name="Plain Man", ascii="Plain Man", user=u)
|
|
email = Email.objects.create(address="plain@example.com", person=plainman)
|
|
|
|
# group personnel
|
|
create_person(mars_wg, "chair", name="WG Cháir Man", username="marschairman")
|
|
create_person(mars_wg, "delegate", name="WG Dèlegate", username="marsdelegate")
|
|
create_person(mars_wg, "secr", name="Miss Secretary", username="marssecretary")
|
|
|
|
mars_wg.role_set.get_or_create(name_id='ad',person=ad,email=ad.role_email('ad'))
|
|
mars_wg.save()
|
|
|
|
create_person(ames_wg, "chair", name="Ames Chair Man", username="ameschairman")
|
|
create_person(ames_wg, "delegate", name="Ames Delegate", username="amesdelegate")
|
|
create_person(ames_wg, "secr", name="Mr Secretary", username="amessecretary")
|
|
ames_wg.role_set.get_or_create(name_id='ad',person=ad,email=ad.role_email('ad'))
|
|
ames_wg.save()
|
|
|
|
create_person(irg_rg, "chair", name="Irg Chair Man", username="irgchairman")
|
|
|
|
# old draft
|
|
old_draft = Document.objects.create(
|
|
name="draft-foo-mars-test",
|
|
time=datetime.datetime.now() - datetime.timedelta(days=settings.INTERNET_DRAFT_DAYS_TO_EXPIRE),
|
|
type_id="draft",
|
|
title="Optimizing Martian Network Topologies",
|
|
stream_id="ietf",
|
|
abstract="Techniques for achieving near-optimal Martian networks.",
|
|
rev="00",
|
|
pages=2,
|
|
expires=datetime.datetime.now(),
|
|
)
|
|
old_draft.set_state(State.objects.get(used=True, type="draft", slug="expired"))
|
|
old_alias = DocAlias.objects.create(document=old_draft, name=old_draft.name)
|
|
|
|
# draft
|
|
draft = Document.objects.create(
|
|
name="draft-ietf-mars-test",
|
|
time=datetime.datetime.now(),
|
|
type_id="draft",
|
|
title="Optimizing Martian Network Topologies",
|
|
stream_id="ietf",
|
|
group=mars_wg,
|
|
abstract="Techniques for achieving near-optimal Martian networks.",
|
|
rev="01",
|
|
pages=2,
|
|
intended_std_level_id="ps",
|
|
shepherd=email,
|
|
ad=ad,
|
|
expires=datetime.datetime.now() + datetime.timedelta(days=settings.INTERNET_DRAFT_DAYS_TO_EXPIRE),
|
|
notify="aliens@example.mars",
|
|
note="",
|
|
)
|
|
|
|
draft.set_state(State.objects.get(used=True, type="draft", slug="active"))
|
|
draft.set_state(State.objects.get(used=True, type="draft-iesg", slug="pub-req"))
|
|
draft.set_state(State.objects.get(used=True, type="draft-stream-%s" % draft.stream_id, slug="wg-doc"))
|
|
|
|
doc_alias = DocAlias.objects.create(
|
|
document=draft,
|
|
name=draft.name,
|
|
)
|
|
|
|
RelatedDocument.objects.create(source=draft, target=old_alias, relationship=DocRelationshipName.objects.get(slug='replaces'))
|
|
old_draft.set_state(State.objects.get(type='draft', slug='repl'))
|
|
|
|
DocumentAuthor.objects.create(
|
|
document=draft,
|
|
person=Person.objects.get(email__address="aread@ietf.org"),
|
|
email=Email.objects.get(address="aread@ietf.org"),
|
|
order=1
|
|
)
|
|
|
|
# fill in some useful default events
|
|
DocEvent.objects.create(
|
|
type="started_iesg_process",
|
|
by=ad,
|
|
doc=draft,
|
|
desc="Started IESG process",
|
|
)
|
|
|
|
NewRevisionDocEvent.objects.create(
|
|
type="new_revision",
|
|
by=ad,
|
|
doc=draft,
|
|
desc="New revision available",
|
|
rev="01",
|
|
)
|
|
|
|
BallotDocEvent.objects.create(
|
|
type="created_ballot",
|
|
ballot_type=BallotType.objects.get(doc_type="draft", slug="approve"),
|
|
by=ad,
|
|
doc=draft,
|
|
desc="Created ballot",
|
|
)
|
|
|
|
# IPR
|
|
ipr = HolderIprDisclosure.objects.create(
|
|
by=Person.objects.get(name="(System)"),
|
|
title="Statement regarding rights",
|
|
holder_legal_name="Native Martians United",
|
|
state=IprDisclosureStateName.objects.get(slug='posted'),
|
|
patent_info='US12345',
|
|
holder_contact_name='George',
|
|
holder_contact_email='george@acme.com',
|
|
holder_contact_info='14 Main Street\nEarth',
|
|
licensing=IprLicenseTypeName.objects.get(slug='royalty-free'),
|
|
submitter_name='George',
|
|
submitter_email='george@acme.com',
|
|
)
|
|
|
|
IprDocRel.objects.create(
|
|
disclosure=ipr,
|
|
document=doc_alias,
|
|
revisions='00',
|
|
)
|
|
|
|
# meeting
|
|
Meeting.objects.create(
|
|
number="42",
|
|
type_id="ietf",
|
|
date=datetime.date.today() + datetime.timedelta(days=180),
|
|
city="New York",
|
|
country="US",
|
|
time_zone="US/Eastern",
|
|
break_area="Lounge",
|
|
reg_area="Lobby",
|
|
)
|
|
|
|
# interim meeting
|
|
Meeting.objects.create(
|
|
number="interim-2015-mars-01",
|
|
type_id='interim',
|
|
date=datetime.date(2015,1,1),
|
|
city="New York",
|
|
country="US",
|
|
)
|
|
|
|
# an independent submission before review
|
|
doc = Document.objects.create(name='draft-imaginary-independent-submission',type_id='draft',rev='00')
|
|
doc.set_state(State.objects.get(used=True, type="draft", slug="active"))
|
|
DocAlias.objects.create(name=doc.name, document=doc)
|
|
|
|
# an irtf submission mid review
|
|
doc = Document.objects.create(name='draft-imaginary-irtf-submission', type_id='draft',rev='00', stream=StreamName.objects.get(slug='irtf'))
|
|
docalias = DocAlias.objects.create(name=doc.name, document=doc)
|
|
doc.set_state(State.objects.get(type="draft", slug="active"))
|
|
crdoc = Document.objects.create(name='conflict-review-imaginary-irtf-submission', type_id='conflrev', rev='00', notify="fsm@ietf.org")
|
|
DocAlias.objects.create(name=crdoc.name, document=crdoc)
|
|
crdoc.set_state(State.objects.get(name='Needs Shepherd', type__slug='conflrev'))
|
|
crdoc.relateddocument_set.create(target=docalias,relationship_id='conflrev')
|
|
|
|
# A status change mid review
|
|
iesg = Group.objects.get(acronym='iesg')
|
|
doc = Document.objects.create(name='status-change-imaginary-mid-review',type_id='statchg', rev='00', notify="fsm@ietf.org",group=iesg)
|
|
doc.set_state(State.objects.get(slug='needshep',type__slug='statchg'))
|
|
docalias = DocAlias.objects.create(name='status-change-imaginary-mid-review',document=doc)
|
|
|
|
# Some things for a status change to affect
|
|
def rfc_for_status_change_test_factory(name,rfc_num,std_level_id):
|
|
target_rfc = Document.objects.create(name=name, type_id='draft', std_level_id=std_level_id, notify="%s@ietf.org"%name)
|
|
target_rfc.set_state(State.objects.get(slug='rfc',type__slug='draft'))
|
|
docalias = DocAlias.objects.create(name=name,document=target_rfc)
|
|
docalias = DocAlias.objects.create(name='rfc%d'%rfc_num,document=target_rfc) # pyflakes:ignore
|
|
return target_rfc
|
|
rfc_for_status_change_test_factory('draft-ietf-random-thing',9999,'ps')
|
|
rfc_for_status_change_test_factory('draft-ietf-random-otherthing',9998,'inf')
|
|
rfc_for_status_change_test_factory('draft-was-never-issued',14,'unkn')
|
|
|
|
# Instances of the remaining document types
|
|
# (Except liaison, liai-att, and recording which the code in ietf.doc does not use...)
|
|
# Meeting-related documents are created in make_meeting_test_data, and
|
|
# associated with a session
|
|
|
|
return draft
|
|
|
|
def make_review_data(doc):
|
|
team1 = create_group(acronym="reviewteam", name="Review Team", type_id="dir", list_email="reviewteam@ietf.org", parent=Group.objects.get(acronym="farfut"))
|
|
team2 = create_group(acronym="reviewteam2", name="Review Team 2", type_id="dir", list_email="reviewteam2@ietf.org", parent=Group.objects.get(acronym="farfut"))
|
|
team3 = create_group(acronym="reviewteam3", name="Review Team 3", type_id="dir", list_email="reviewteam2@ietf.org", parent=Group.objects.get(acronym="farfut"))
|
|
for team in (team1, team2, team3):
|
|
ReviewTeamSettings.objects.create(group=team)
|
|
for r in ReviewResultName.objects.filter(slug__in=["issues", "ready-issues", "ready", "not-ready"]):
|
|
team.reviewteamsettings.review_results.add(r)
|
|
for t in ReviewTypeName.objects.filter(slug__in=["early", "lc", "telechat"]):
|
|
team.reviewteamsettings.review_types.add(t)
|
|
|
|
u = User.objects.create(username="reviewer")
|
|
u.set_password("reviewer+password")
|
|
u.save()
|
|
reviewer = Person.objects.create(name=u"Some Réviewer", ascii="Some Reviewer", user=u)
|
|
email = Email.objects.create(address="reviewer@example.com", person=reviewer)
|
|
|
|
for team in (team1, team2, team3):
|
|
Role.objects.create(name_id="reviewer", person=reviewer, email=email, group=team)
|
|
ReviewerSettings.objects.create(team=team, person=reviewer, min_interval=14, skip_next=0)
|
|
|
|
review_req = ReviewRequest.objects.create(
|
|
doc=doc,
|
|
team=team1,
|
|
type_id="early",
|
|
deadline=datetime.datetime.now() + datetime.timedelta(days=20),
|
|
state_id="accepted",
|
|
requested_by=reviewer,
|
|
reviewer=email,
|
|
)
|
|
|
|
p = Person.objects.get(user__username="marschairman")
|
|
Role.objects.create(name_id="reviewer", person=p, email=p.email_set.first(), group=team1)
|
|
|
|
u = User.objects.create(username="reviewsecretary")
|
|
u.set_password("reviewsecretary+password")
|
|
u.save()
|
|
reviewsecretary = Person.objects.create(name=u"Réview Secretary", ascii="Review Secretary", user=u)
|
|
reviewsecretary_email = Email.objects.create(address="reviewsecretary@example.com", person=reviewsecretary)
|
|
Role.objects.create(name_id="secr", person=reviewsecretary, email=reviewsecretary_email, group=team1)
|
|
|
|
u = User.objects.create(username="reviewsecretary3")
|
|
u.set_password("reviewsecretary3+password")
|
|
u.save()
|
|
reviewsecretary3 = Person.objects.create(name=u"Réview Secretary3", ascii="Review Secretary3", user=u)
|
|
reviewsecretary3_email = Email.objects.create(address="reviewsecretary3@example.com", person=reviewsecretary)
|
|
Role.objects.create(name_id="secr", person=reviewsecretary3, email=reviewsecretary3_email, group=team3)
|
|
|
|
return review_req
|
|
|