From 06a6d5e1af940086e6f64f0efdd7c0f7bbcfb3a6 Mon Sep 17 00:00:00 2001 From: Shubhadeep Das Date: Fri, 7 Oct 2022 10:28:04 +0530 Subject: [PATCH 1/2] Added e2e tests for tag.deleted webhook --- .../__snapshots__/tags.test.js.snap | 40 +++++++++++++++ ghost/core/test/e2e-webhooks/tags.test.js | 51 +++++++++++++++++-- 2 files changed, 88 insertions(+), 3 deletions(-) diff --git a/ghost/core/test/e2e-webhooks/__snapshots__/tags.test.js.snap b/ghost/core/test/e2e-webhooks/__snapshots__/tags.test.js.snap index ac06a496442..0a20f5787d2 100644 --- a/ghost/core/test/e2e-webhooks/__snapshots__/tags.test.js.snap +++ b/ghost/core/test/e2e-webhooks/__snapshots__/tags.test.js.snap @@ -40,3 +40,43 @@ Object { }, } `; + +exports[`tag.* events tag.deleted event is triggered 1: [headers] 1`] = ` +Object { + "accept-encoding": "gzip, deflate", + "content-length": Any, + "content-type": "application/json", + "content-version": StringMatching /v\\\\d\\+\\\\\\.\\\\d\\+/, + "user-agent": StringMatching /Ghost\\\\/\\\\d\\+\\\\\\.\\\\d\\+\\\\\\.\\\\d\\+\\\\s\\\\\\(https:\\\\/\\\\/github\\.com\\\\/TryGhost\\\\/Ghost\\\\\\)/, +} +`; + +exports[`tag.* events tag.deleted event is triggered 2: [body] 1`] = ` +Object { + "tag": Object { + "current": Object {}, + "previous": Object { + "accent_color": null, + "canonical_url": null, + "codeinjection_foot": null, + "codeinjection_head": null, + "created_at": StringMatching /\\\\d\\{4\\}-\\\\d\\{2\\}-\\\\d\\{2\\}T\\\\d\\{2\\}:\\\\d\\{2\\}:\\\\d\\{2\\}\\\\\\.000Z/, + "description": Any, + "feature_image": null, + "id": StringMatching /\\[a-f0-9\\]\\{24\\}/, + "meta_description": null, + "meta_title": null, + "name": "Test Tag 2", + "og_description": null, + "og_image": null, + "og_title": null, + "slug": "test-tag-2", + "twitter_description": null, + "twitter_image": null, + "twitter_title": null, + "updated_at": StringMatching /\\\\d\\{4\\}-\\\\d\\{2\\}-\\\\d\\{2\\}T\\\\d\\{2\\}:\\\\d\\{2\\}:\\\\d\\{2\\}\\\\\\.000Z/, + "visibility": "public", + }, + }, +} +`; diff --git a/ghost/core/test/e2e-webhooks/tags.test.js b/ghost/core/test/e2e-webhooks/tags.test.js index 9e1ad54932e..79b650008dc 100644 --- a/ghost/core/test/e2e-webhooks/tags.test.js +++ b/ghost/core/test/e2e-webhooks/tags.test.js @@ -5,8 +5,7 @@ const tagSnapshot = { created_at: anyISODateTime, description: anyString, id: anyObjectId, - updated_at: anyISODateTime, - url: anyLocalURL + updated_at: anyISODateTime }; describe('tag.* events', function () { @@ -56,7 +55,53 @@ describe('tag.* events', function () { }) .matchBodySnapshot({ tag: { - current: tagSnapshot + current: {...tagSnapshot, url: anyLocalURL} + } + }); + }); + + it('tag.deleted event is triggered', async function () { + const webhookURL = 'https://test-webhook-receiver.com/tag-deleted/'; + await webhookMockReceiver.mock(webhookURL); + await fixtureManager.insertWebhook({ + event: 'tag.deleted', + url: webhookURL + }); + + const res = await adminAPIAgent + .post('tags/') + .body({ + tags: [{ + name: 'Test Tag 2', + slug: 'test-tag-2', + description: 'Test description' + }] + }) + .expectStatus(201); + + const id = res.body.tags[0].id; + + await adminAPIAgent + .delete('tags/' + id) + .expectStatus(204); + + await webhookMockReceiver.receivedRequest(); + + webhookMockReceiver + .matchHeaderSnapshot({ + 'content-version': anyContentVersion, + 'content-length': anyNumber, + 'user-agent': anyGhostAgent + }) + .matchBodySnapshot({ + tag: { + current: {}, + previous: { + created_at: anyISODateTime, + description: anyString, + id: anyObjectId, + updated_at: anyISODateTime + } } }); }); From e42284717aca7defa0cd8aab199e1c2cc1fb6eb0 Mon Sep 17 00:00:00 2001 From: Shubhadeep Das Date: Fri, 7 Oct 2022 10:39:05 +0530 Subject: [PATCH 2/2] minor refactor --- ghost/core/test/e2e-webhooks/tags.test.js | 7 +------ 1 file changed, 1 insertion(+), 6 deletions(-) diff --git a/ghost/core/test/e2e-webhooks/tags.test.js b/ghost/core/test/e2e-webhooks/tags.test.js index 79b650008dc..95aa658a265 100644 --- a/ghost/core/test/e2e-webhooks/tags.test.js +++ b/ghost/core/test/e2e-webhooks/tags.test.js @@ -96,12 +96,7 @@ describe('tag.* events', function () { .matchBodySnapshot({ tag: { current: {}, - previous: { - created_at: anyISODateTime, - description: anyString, - id: anyObjectId, - updated_at: anyISODateTime - } + previous: tagSnapshot } }); });