|
3 | 3 | import uuid |
4 | 4 |
|
5 | 5 | import mock |
| 6 | +from django.db.models import Exists |
| 7 | +from django.db.models import OuterRef |
6 | 8 | from django.urls import reverse |
7 | 9 | from le_utils.constants import content_kinds |
8 | 10 |
|
|
14 | 16 | from contentcuration.tests.viewsets.base import generate_create_event |
15 | 17 | from contentcuration.tests.viewsets.base import generate_delete_event |
16 | 18 | from contentcuration.tests.viewsets.base import generate_deploy_channel_event |
| 19 | +from contentcuration.tests.viewsets.base import generate_publish_channel_event |
17 | 20 | from contentcuration.tests.viewsets.base import generate_sync_channel_event |
18 | 21 | from contentcuration.tests.viewsets.base import generate_update_event |
19 | 22 | from contentcuration.tests.viewsets.base import SyncTestMixin |
| 23 | +from contentcuration.viewsets.channel import _unpublished_changes_query |
20 | 24 | from contentcuration.viewsets.sync.constants import CHANNEL |
21 | 25 |
|
22 | 26 |
|
@@ -374,6 +378,19 @@ def test_deploy_with_staging_tree_None(self): |
374 | 378 | self.assertNotEqual(modified_channel.main_tree, channel.staging_tree) |
375 | 379 | self.assertNotEqual(modified_channel.previous_tree, channel.main_tree) |
376 | 380 |
|
| 381 | + def test_publish_does_not_make_publishable(self): |
| 382 | + user = testdata.user() |
| 383 | + channel = models.Channel.objects.create(actor_id=user.id, **self.channel_metadata) |
| 384 | + channel.editors.add(user) |
| 385 | + |
| 386 | + self.sync_changes( |
| 387 | + [ |
| 388 | + generate_publish_channel_event(channel.id) |
| 389 | + ] |
| 390 | + ) |
| 391 | + |
| 392 | + self.assertEqual(_unpublished_changes_query(channel).count(), 0) |
| 393 | + |
377 | 394 |
|
378 | 395 | class CRUDTestCase(StudioAPITestCase): |
379 | 396 | @property |
@@ -466,3 +483,134 @@ def test_admin_restore_channel(self): |
466 | 483 | channel = models.Channel.objects.get(id=channel.id) |
467 | 484 | self.assertFalse(channel.deleted) |
468 | 485 | self.assertEqual(1, channel.history.filter(actor=user, action=channel_history.RECOVERY).count()) |
| 486 | + |
| 487 | + |
| 488 | +class UnpublishedChangesQueryTestCase(StudioAPITestCase): |
| 489 | + def test_unpublished_changes_query_with_channel_object(self): |
| 490 | + channel = testdata.channel() |
| 491 | + user = testdata.user() |
| 492 | + models.Change.create_change(generate_update_event(channel.id, CHANNEL, {"name": "new name"}, channel_id=channel.id), created_by_id=user.id) |
| 493 | + models.Change.create_change(generate_publish_channel_event(channel.id), created_by_id=user.id) |
| 494 | + models.Change.create_change(generate_update_event(channel.id, CHANNEL, {"name": "new name 2"}, channel_id=channel.id), created_by_id=user.id) |
| 495 | + |
| 496 | + queryset = _unpublished_changes_query(channel) |
| 497 | + self.assertEqual(queryset.count(), 1) |
| 498 | + self.assertEqual(queryset[0].kwargs["mods"]["name"], "new name 2") |
| 499 | + |
| 500 | + def test_unpublished_changes_query_with_channel_object_none_since_publish(self): |
| 501 | + channel = testdata.channel() |
| 502 | + user = testdata.user() |
| 503 | + models.Change.create_change(generate_update_event(channel.id, CHANNEL, {"name": "new name"}, channel_id=channel.id), created_by_id=user.id) |
| 504 | + models.Change.create_change(generate_update_event(channel.id, CHANNEL, {"name": "new name 2"}, channel_id=channel.id), created_by_id=user.id) |
| 505 | + models.Change.create_change(generate_publish_channel_event(channel.id), created_by_id=user.id) |
| 506 | + |
| 507 | + queryset = _unpublished_changes_query(channel) |
| 508 | + self.assertEqual(queryset.count(), 0) |
| 509 | + |
| 510 | + def test_unpublished_changes_query_with_channel_object_no_publishable_since_publish(self): |
| 511 | + channel = testdata.channel() |
| 512 | + user = testdata.user() |
| 513 | + models.Change.create_change(generate_update_event(channel.id, CHANNEL, {"name": "new name"}, channel_id=channel.id), created_by_id=user.id) |
| 514 | + models.Change.create_change(generate_publish_channel_event(channel.id), created_by_id=user.id) |
| 515 | + models.Change.create_change( |
| 516 | + generate_update_event( |
| 517 | + channel.id, |
| 518 | + CHANNEL, |
| 519 | + {"name": "new name 2"}, |
| 520 | + channel_id=channel.id |
| 521 | + ), |
| 522 | + created_by_id=user.id, |
| 523 | + unpublishable=True, |
| 524 | + ) |
| 525 | + |
| 526 | + queryset = _unpublished_changes_query(channel) |
| 527 | + self.assertEqual(queryset.count(), 0) |
| 528 | + |
| 529 | + def test_unpublished_changes_query_with_channel_object_no_publishable_since_publish_if_publish_fails_through_error(self): |
| 530 | + channel = testdata.channel() |
| 531 | + user = testdata.user() |
| 532 | + channel.main_tree = None |
| 533 | + channel.save() |
| 534 | + models.Change.create_change(generate_publish_channel_event(channel.id), created_by_id=user.id) |
| 535 | + |
| 536 | + queryset = _unpublished_changes_query(channel) |
| 537 | + self.assertEqual(queryset.count(), 0) |
| 538 | + |
| 539 | + def test_unpublished_changes_query_with_channel_object_no_publishable_since_publish_if_publish_fails_because_incomplete(self): |
| 540 | + channel = testdata.channel() |
| 541 | + user = testdata.user() |
| 542 | + channel.main_tree.complete = False |
| 543 | + channel.save() |
| 544 | + models.Change.create_change(generate_publish_channel_event(channel.id), created_by_id=user.id) |
| 545 | + |
| 546 | + queryset = _unpublished_changes_query(channel) |
| 547 | + self.assertEqual(queryset.count(), 0) |
| 548 | + |
| 549 | + def test_unpublished_changes_query_with_outerref(self): |
| 550 | + channel = testdata.channel() |
| 551 | + user = testdata.user() |
| 552 | + models.Change.create_change(generate_update_event(channel.id, CHANNEL, {"name": "new name"}, channel_id=channel.id), created_by_id=user.id) |
| 553 | + models.Change.create_change(generate_publish_channel_event(channel.id), created_by_id=user.id) |
| 554 | + models.Change.create_change(generate_update_event(channel.id, CHANNEL, {"name": "new name 2"}, channel_id=channel.id), created_by_id=user.id) |
| 555 | + |
| 556 | + outer_ref = OuterRef("id") |
| 557 | + unpublished_changes = _unpublished_changes_query(outer_ref) |
| 558 | + channels = models.Channel.objects.filter(pk=channel.pk).annotate(unpublished_changes=Exists(unpublished_changes)) |
| 559 | + self.assertTrue(channels[0].unpublished_changes) |
| 560 | + |
| 561 | + def test_unpublished_changes_query_with_outerref_none_since_publish(self): |
| 562 | + channel = testdata.channel() |
| 563 | + user = testdata.user() |
| 564 | + models.Change.create_change(generate_update_event(channel.id, CHANNEL, {"name": "new name"}, channel_id=channel.id), created_by_id=user.id) |
| 565 | + models.Change.create_change(generate_update_event(channel.id, CHANNEL, {"name": "new name 2"}, channel_id=channel.id), created_by_id=user.id) |
| 566 | + models.Change.create_change(generate_publish_channel_event(channel.id), created_by_id=user.id) |
| 567 | + |
| 568 | + outer_ref = OuterRef("id") |
| 569 | + unpublished_changes = _unpublished_changes_query(outer_ref) |
| 570 | + channels = models.Channel.objects.filter(pk=channel.pk).annotate(unpublished_changes=Exists(unpublished_changes)) |
| 571 | + self.assertFalse(channels[0].unpublished_changes) |
| 572 | + |
| 573 | + def test_unpublished_changes_query_with_outerref_no_publishable_since_publish(self): |
| 574 | + channel = testdata.channel() |
| 575 | + user = testdata.user() |
| 576 | + models.Change.create_change(generate_update_event(channel.id, CHANNEL, {"name": "new name"}, channel_id=channel.id), created_by_id=user.id) |
| 577 | + models.Change.create_change(generate_publish_channel_event(channel.id), created_by_id=user.id) |
| 578 | + models.Change.create_change( |
| 579 | + generate_update_event( |
| 580 | + channel.id, |
| 581 | + CHANNEL, |
| 582 | + {"name": "new name 2"}, |
| 583 | + channel_id=channel.id |
| 584 | + ), |
| 585 | + created_by_id=user.id, |
| 586 | + unpublishable=True |
| 587 | + ) |
| 588 | + |
| 589 | + outer_ref = OuterRef("id") |
| 590 | + unpublished_changes = _unpublished_changes_query(outer_ref) |
| 591 | + channels = models.Channel.objects.filter(pk=channel.pk).annotate(unpublished_changes=Exists(unpublished_changes)) |
| 592 | + self.assertFalse(channels[0].unpublished_changes) |
| 593 | + |
| 594 | + def test_unpublished_changes_query_no_publishable_since_publish_if_publish_fails_through_error(self): |
| 595 | + channel = testdata.channel() |
| 596 | + user = testdata.user() |
| 597 | + channel.main_tree = None |
| 598 | + channel.save() |
| 599 | + models.Change.create_change(generate_publish_channel_event(channel.id), created_by_id=user.id) |
| 600 | + |
| 601 | + outer_ref = OuterRef("id") |
| 602 | + unpublished_changes = _unpublished_changes_query(outer_ref) |
| 603 | + channels = models.Channel.objects.filter(pk=channel.pk).annotate(unpublished_changes=Exists(unpublished_changes)) |
| 604 | + self.assertFalse(channels[0].unpublished_changes) |
| 605 | + |
| 606 | + def test_unpublished_changes_query_no_publishable_since_publish_if_publish_fails_because_incomplete(self): |
| 607 | + channel = testdata.channel() |
| 608 | + user = testdata.user() |
| 609 | + channel.main_tree.complete = False |
| 610 | + channel.save() |
| 611 | + models.Change.create_change(generate_publish_channel_event(channel.id), created_by_id=user.id) |
| 612 | + |
| 613 | + outer_ref = OuterRef("id") |
| 614 | + unpublished_changes = _unpublished_changes_query(outer_ref) |
| 615 | + channels = models.Channel.objects.filter(pk=channel.pk).annotate(unpublished_changes=Exists(unpublished_changes)) |
| 616 | + self.assertFalse(channels[0].unpublished_changes) |
0 commit comments