Skip to content

Commit

Permalink
add tests
Browse files Browse the repository at this point in the history
  • Loading branch information
devketanpro committed Apr 5, 2024
1 parent a5b99e0 commit bc1a1b8
Showing 1 changed file with 103 additions and 0 deletions.
103 changes: 103 additions & 0 deletions server/planning/events/events_tests.py
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,7 @@
from planning.common import format_address, POST_STATE
from planning.item_lock import LockService
from planning.events.events import generate_recurring_dates
from werkzeug.exceptions import BadRequest


class EventTestCase(TestCase):
Expand Down Expand Up @@ -596,3 +597,105 @@ def test_new_planning_is_published_when_adding_to_published_event(self):
planning_item = planning_service.find_one(req=None, _id=planning_id)
self.assertIsNotNone(planning_item)
self.assertEqual(planning_item["pubstatus"], POST_STATE.USABLE)

def test_related_planning_item_validation_on_post(self):
"""
check planning item fields validation
if validation fails, plannning item is not posted.
"""
events_service = get_resource_service("events")
planning_service = get_resource_service("planning")

with self.app.app_context():
self.app.data.insert(
"planning_types",
[
{
"_id": "event",
"name": "event",
"editor": {"related_plannings": {"enabled": True}},
"schema": {"related_plannings": {"planning_auto_publish": True}},
},
{
"_id": "planning",
"name": "planning",
"editor": {"slugline": {"enabled": True}},
"schema": {"slugline": {"required": True}},
},
],
)

event_id = events_service.post(
[
{
"type": "event",
"occur_status": {
"qcode": "eocstat:eos5",
"name": "Planned, occurs certainly",
"label": "Planned, occurs certainly",
},
"dates": {
"start": datetime(2099, 11, 21, 11, 00, 00, tzinfo=pytz.UTC),
"end": datetime(2099, 11, 21, 12, 00, 00, tzinfo=pytz.UTC),
"tz": "Australia/Sydney",
},
"state": "draft",
"name": "Foo event one",
}
]
)[0]
planning_id = planning_service.post(
[
{
"planning_date": datetime(2099, 11, 21, 12, 00, 00, tzinfo=pytz.UTC),
"name": "foo planning 1",
"type": "planning",
"event_item": event_id,
}
]
)[0]
try:
get_resource_service("events_post").post(
[
{
"event": event_id,
"pubstatus": "usable",
"update_method": "single",
}
]
)
except BadRequest as e:
self.assertEqual(str(e), "400 Bad Request: ['Related planning : SLUGLINE is a required field']")

planning_item = planning_service.find_one(req=None, _id=planning_id)
self.assertEqual(planning_item["state"], "draft")

# try to re-post an event.
try:
get_resource_service("events_post").post(
[
{
"event": event_id,
"pubstatus": "usable",
"update_method": "single",
}
]
)
except BadRequest as e:
self.assertEqual(str(e), "400 Bad Request: ['Related planning : SLUGLINE is a required field']")

# udpate slugline
planning_service.patch(planning_id, {"slugline": "update slug"})

get_resource_service("events_post").post(
[
{
"event": event_id,
"pubstatus": "usable",
"update_method": "single",
}
]
)
planning_item = planning_service.find_one(req=None, _id=planning_id)
self.assertIsNotNone(planning_item)
self.assertEqual(planning_item["state"], "scheduled")

0 comments on commit bc1a1b8

Please sign in to comment.