launchpad-reviewers team mailing list archive
-
launchpad-reviewers team
-
Mailing list archive
-
Message #27609
[Merge] ~jugmac00/launchpad:SignedCodeOfConduct.affirmed-cant-be-None-anymore into launchpad:db-devel
jugmac00 has proposed merging ~jugmac00/launchpad:SignedCodeOfConduct.affirmed-cant-be-None-anymore into launchpad:db-devel.
Commit message:
update signedcodeofconduct.affirmed
Requested reviews:
Launchpad code reviewers (launchpad-reviewers)
For more details, see:
https://code.launchpad.net/~jugmac00/launchpad/+git/launchpad/+merge/410430
--
Your team Launchpad code reviewers is requested to review the proposed merge of ~jugmac00/launchpad:SignedCodeOfConduct.affirmed-cant-be-None-anymore into launchpad:db-devel.
diff --git a/database/schema/patch-2210-37-0.sql b/database/schema/patch-2210-37-0.sql
new file mode 100644
index 0000000..25fa1ba
--- /dev/null
+++ b/database/schema/patch-2210-37-0.sql
@@ -0,0 +1 @@
+UPDATE signedcodeofconduct ALTER COLUMN affirmed boolean NOT NULL;
diff --git a/lib/lp/registry/model/codeofconduct.py b/lib/lp/registry/model/codeofconduct.py
index 2c19f99..65db887 100644
--- a/lib/lp/registry/model/codeofconduct.py
+++ b/lib/lp/registry/model/codeofconduct.py
@@ -199,7 +199,7 @@ class SignedCodeOfConduct(StormBase):
active = Bool(name='active', allow_none=False, default=False)
- affirmed = Bool(name='affirmed', allow_none=True, default=False,)
+ affirmed = Bool(name='affirmed', allow_none=False, default=False,)
version = Unicode(name='version', allow_none=True, default=None)
diff --git a/lib/lp/registry/tests/test_codeofconduct.py b/lib/lp/registry/tests/test_codeofconduct.py
index 049515c..916c78c 100644
--- a/lib/lp/registry/tests/test_codeofconduct.py
+++ b/lib/lp/registry/tests/test_codeofconduct.py
@@ -5,6 +5,7 @@
from textwrap import dedent
+from storm.exceptions import NoneError
from testtools.matchers import (
ContainsDict,
Equals,
@@ -16,6 +17,7 @@ from lp.registry.interfaces.codeofconduct import (
ICodeOfConductSet,
ISignedCodeOfConductSet,
)
+from lp.registry.model.codeofconduct import SignedCodeOfConduct
from lp.services.config import config
from lp.services.gpg.handler import PymeSignature
from lp.services.gpg.interfaces import (
@@ -242,3 +244,26 @@ class TestSignedCodeOfConductSet(TestCaseWithFactory):
u"You have already affirmed the current Code of Conduct.",
getUtility(ISignedCodeOfConductSet).affirmAndStore(
user, current.content))
+
+
+class TestSignedCodeOfConduct(TestCaseWithFactory):
+ layer = ZopelessDatabaseLayer
+
+ def test_affirmed_cant_be_instantiated_with_none(self):
+ self.assertRaises(
+ NoneError,
+ SignedCodeOfConduct,
+ owner=self.factory.makePerson(),
+ affirmed=None
+ )
+
+ def test_affirmed_cant_be_none(self):
+ coc = SignedCodeOfConduct(owner=self.factory.makePerson())
+ # workaround as teststools prevents using `with self.assertRaises`
+ def set_affirmed_to_none():
+ coc.affirmed = None
+
+ self.assertRaises(
+ NoneError,
+ set_affirmed_to_none
+ )
diff --git a/lib/lp/scripts/garbo.py b/lib/lp/scripts/garbo.py
index ce28426..e2471dc 100644
--- a/lib/lp/scripts/garbo.py
+++ b/lib/lp/scripts/garbo.py
@@ -75,7 +75,6 @@ from lp.code.model.revision import (
)
from lp.oci.model.ocirecipebuild import OCIFile
from lp.registry.interfaces.person import IPersonSet
-from lp.registry.model.codeofconduct import SignedCodeOfConduct
from lp.registry.model.person import Person
from lp.registry.model.product import Product
from lp.registry.model.sourcepackagename import SourcePackageName
@@ -1765,29 +1764,6 @@ class PopulateSnapBuildStoreRevision(TunableLoop):
transaction.commit()
-class PopulateSignedCodeOfConductAffirmed(TunableLoop):
- """Populates SignedCodeOfConduct.affirmed if not set"""
-
- maximum_chunk_size = 5000
-
- def __init__(self, log, abort_time=None):
- super().__init__(log, abort_time)
- self.store = IMasterStore(SignedCodeOfConduct)
-
- def findSignedCodeOfConducts(self):
- return self.store.find(
- SignedCodeOfConduct,
- SignedCodeOfConduct.affirmed == None
- )
-
- def isDone(self):
- return self.findSignedCodeOfConducts().is_empty()
-
- def __call__(self, chunk_size):
- self.findSignedCodeOfConducts()[:chunk_size].set(affirmed=False)
- transaction.commit()
-
-
class BaseDatabaseGarbageCollector(LaunchpadCronScript):
"""Abstract base class to run a collection of TunableLoops."""
script_name = None # Script name for locking and database user. Override.
@@ -2048,7 +2024,6 @@ class HourlyDatabaseGarbageCollector(BaseDatabaseGarbageCollector):
GitRepositoryPruner,
RevisionCachePruner,
UnusedSessionPruner,
- PopulateSignedCodeOfConductAffirmed,
]
experimental_tunable_loops = []
diff --git a/lib/lp/scripts/tests/test_garbo.py b/lib/lp/scripts/tests/test_garbo.py
index c539bf7..a700663 100644
--- a/lib/lp/scripts/tests/test_garbo.py
+++ b/lib/lp/scripts/tests/test_garbo.py
@@ -84,7 +84,6 @@ from lp.registry.enums import (
from lp.registry.interfaces.accesspolicy import IAccessPolicySource
from lp.registry.interfaces.person import IPersonSet
from lp.registry.interfaces.teammembership import TeamMembershipStatus
-from lp.registry.model.codeofconduct import SignedCodeOfConduct
from lp.registry.model.commercialsubscription import CommercialSubscription
from lp.registry.model.teammembership import TeamMembership
from lp.scripts.garbo import (
@@ -97,7 +96,6 @@ from lp.scripts.garbo import (
load_garbo_job_state,
LoginTokenPruner,
OpenIDConsumerAssociationPruner,
- PopulateSignedCodeOfConductAffirmed,
PopulateSnapBuildStoreRevision,
ProductVCSPopulator,
save_garbo_job_state,
@@ -2047,21 +2045,6 @@ class TestGarbo(FakeAdapterMixin, TestCaseWithFactory):
switch_dbuser('testadmin')
self.assertEqual(build1._store_upload_revision, 1)
- def test_PopulateSignedCodeOfConductAffirmed(self):
- switch_dbuser('testadmin')
- populator = PopulateSignedCodeOfConductAffirmed(log=None)
- for _ in range(5):
- person = self.factory.makePerson()
- SignedCodeOfConduct(owner=person).affirmed = None
-
- result_set = populator.findSignedCodeOfConducts()
- self.assertGreater(result_set.count(), 0)
-
- self.runHourly()
-
- result_set = populator.findSignedCodeOfConducts()
- self.assertTrue(result_set.is_empty())
-
class TestGarboTasks(TestCaseWithFactory):
layer = LaunchpadZopelessLayer