From b490c9aeac0542ca48748e1f19cf4e4531f5599c Mon Sep 17 00:00:00 2001 From: Constantin Ross Date: Thu, 2 Jan 2025 16:13:22 +0100 Subject: [PATCH 1/4] refactor (bookmark): mark bookmark functions as deprecated --- src/Prismic/Api.php | 4 ++++ src/Prismic/ApiData.php | 9 +++++++-- 2 files changed, 11 insertions(+), 2 deletions(-) diff --git a/src/Prismic/Api.php b/src/Prismic/Api.php index 19987d12..92da2aa5 100644 --- a/src/Prismic/Api.php +++ b/src/Prismic/Api.php @@ -151,6 +151,8 @@ public function getRefFromLabel(string $label) :? Ref * Returns the list of all bookmarks on the repository. If you're looking * for a document from it's bookmark name, you should use the bookmark() function. * + * @deprecated 5.4.0 This method will no longer work after the 12 February 2025, as bookmarks are removed from the API. + * * @return array the array of bookmarks */ public function bookmarks() : array @@ -165,6 +167,8 @@ public function bookmarks() : array * Most starter projects embed a helper to query a document from their ID string, * which makes this even easier. * + * @deprecated 5.4.0 This method will no longer work after the 12 February 2025, as bookmarks are removed from the API. + * * @param string $name the bookmark name to use * * @return string|null the ID string for a given bookmark name diff --git a/src/Prismic/ApiData.php b/src/Prismic/ApiData.php index 335c898a..7d7f985c 100644 --- a/src/Prismic/ApiData.php +++ b/src/Prismic/ApiData.php @@ -16,6 +16,9 @@ class ApiData /** * An array of the available bookmarks + * + * @deprecated 5.4.0 + * * @var array */ private $bookmarks; @@ -66,7 +69,7 @@ class ApiData * A constructor to build the object when you've retrieved all the data you need. * * @param array $refs - * @param array $bookmarks + * @param array $bookmarks (deprecated since 5.4.0) * @param array $types * @param array $languages * @param array $tags @@ -131,7 +134,7 @@ function ($ref) { }, $json->refs ), - (array)$json->bookmarks, + isset($json->bookmarks) ? (array)$json->bookmarks : [], (array)$json->types, array_map( function ($language) { @@ -158,6 +161,8 @@ public function getRefs() : array /** * Get the bookmarks + * + * @deprecated 5.4.0 This method will no longer work after the 12 February 2025, as bookmarks are removed from the API. */ public function getBookmarks() : array { From f7879c6c44e2fb1931c7dee8c0b4be386dff6476 Mon Sep 17 00:00:00 2001 From: Constantin Ross Date: Thu, 2 Jan 2025 16:13:50 +0100 Subject: [PATCH 2/4] test (bookmark): test public api works without bookmarks in api response --- tests/Prismic/ApiDataTest.php | 8 + tests/Prismic/ApiTest.php | 19 +++ tests/fixtures/data-without-bookmarks.json | 165 +++++++++++++++++++++ 3 files changed, 192 insertions(+) create mode 100644 tests/fixtures/data-without-bookmarks.json diff --git a/tests/Prismic/ApiDataTest.php b/tests/Prismic/ApiDataTest.php index c03c3dd9..38ae2de9 100644 --- a/tests/Prismic/ApiDataTest.php +++ b/tests/Prismic/ApiDataTest.php @@ -36,6 +36,14 @@ public function testWithJsonStringThrowsExceptionForInvalidJson() ApiData::withJsonString('wtf?'); } + public function testApiDataWorksWithoutBookmarks(){ + $json = $this->getJsonFixture('data-without-bookmarks.json'); + $data = ApiData::withJsonString($json); + + $this->assertInstanceOf(ApiData::class, $data); + $this->assertEquals([], $data->getBookmarks()); + } + public function testApiDataHasExpectedValues() { $this->assertCount(3, $this->data->getRefs()); diff --git a/tests/Prismic/ApiTest.php b/tests/Prismic/ApiTest.php index b66de732..fd0a4861 100755 --- a/tests/Prismic/ApiTest.php +++ b/tests/Prismic/ApiTest.php @@ -201,6 +201,25 @@ public function testBookmarkReturnsCorrectDocumentId() $this->assertNull($api->bookmark('unknown-bookmark')); } + public function testApiWorksWithoutBookmarks() { + // Create an ApiData object without bookmarks + $data = $this->getJsonFixture('data-without-bookmarks.json'); + $apiData = ApiData::withJsonString($data); + + // Cache the data + $key = 'https://whatever.prismic.io/api/v2#My-Access-Token'; + $cachedData = serialize($apiData); + $this->cache->get($key)->willReturn($cachedData); + $this->httpClient->request()->shouldNotBeCalled(); + + $api = $this->getApi(); + + // Test that the bookmarks are empty + $this->assertEmpty($api->bookmarks()); + $this->assertNull($api->bookmark('about')); + $this->assertNull($api->bookmark('unknown-bookmark')); + } + public function testFormsReturnsOnlyFormInstances() { $api = $this->getApiWithDefaultData(); diff --git a/tests/fixtures/data-without-bookmarks.json b/tests/fixtures/data-without-bookmarks.json new file mode 100644 index 00000000..8616e123 --- /dev/null +++ b/tests/fixtures/data-without-bookmarks.json @@ -0,0 +1,165 @@ +{ + "refs": [ + { + "id": "master", + "ref": "UgjWQN_mqa8HvPJY", + "label": "Master", + "isMasterRef": true + }, + { + "id": "UkL0hcuvzYUANCrr", + "ref": "UgjWRd_mqbYHvPJa", + "label": "San Francisco Grand opening" + }, + { + "id": "SaGrandOpening2ndRef", + "ref": "SaGrandOpening2ndRef", + "label": "San Francisco Grand opening" + } + ], + "types": { + "blog-post": "Blog post", + "store": "Store", + "article": "Site-level article", + "selection": "Products selection", + "job-offer": "Job offer", + "product": "Product" + }, + "languages": [ + { + "id": "en-us", + "name": "English - United States" + }, + { + "id": "nl-nl", + "name": "Dutch - Netherlands" + }, + { + "id": "es-es", + "name": "Spanish - Spain (Traditional)" + }, + { + "id": "fr-fr", + "name": "French - France" + } + ], + "tags": ["Cupcake", "Pie", "Featured", "Macaron"], + "forms": { + "everything": { + "method": "GET", + "enctype": "application/x-www-form-urlencoded", + "action": "http://lesbonneschoses.prismic.io/api/v2/documents/search", + "fields": { + "ref": { + "type": "String" + }, + "q": { + "type": "String" + } + } + }, + "blogs": { + "name": "Blog Posts", + "method": "GET", + "rel": "collection", + "enctype": "application/x-www-form-urlencoded", + "action": "https://lesbonneschoses.prismic.io/api/v2/documents/search", + "fields": { + "ref": { + "type": "String", + "multiple": false + }, + "q": { + "default": "[[:d = any(document.type, [\"blog-post\"])]]", + "type": "String", + "multiple": true + }, + "lang": { + "type": "String", + "multiple": false + }, + "page": { + "type": "Integer", + "multiple": false, + "default": "1" + }, + "pageSize": { + "type": "Integer", + "multiple": false, + "default": "20" + }, + "after": { + "type": "String", + "multiple": false + }, + "fetch": { + "type": "String", + "multiple": false + }, + "fetchLinks": { + "type": "String", + "multiple": false + }, + "graphQuery": { + "type": "String", + "multiple": false + }, + "orderings": { + "type": "String", + "multiple": false + }, + "referer": { + "type": "String", + "multiple": false + }, + "access_token": { + "default": "a-permanent-access-token", + "type": "String", + "multiple": false + } + } + } + }, + "oauth_initiate": "http://lesbonneschoses.prismic.io/auth", + "oauth_token": "http://lesbonneschoses.prismic.io/auth/token", + "experiments" : { + "draft": [ + { + "id": "xxxxxxxxxxoGelsX", + "name": "Exp 2", + "variations": [ + { + "id": "VDUBBawGAKoGelsZ", + "label": "Base", + "ref": "VDUBBawGALAGelsa" + }, + { + "id": "VDUE-awGALAGemME", + "label": "var 1", + "ref": "VDUUmHIKAZQKk9uq" + } + ] + } + ], + "running": [ + { + "googleId": "_UQtin7EQAOH5M34RQq6Dg", + "id": "VDUBBawGAKoGelsX", + "name": "Exp 1", + "variations": [ + { + "id": "VDUBBawGAKoGelsZ", + "label": "Base", + "ref": "VDUBBawGALAGelsa" + }, + { + "id": "VDUE-awGALAGemME", + "label": "var 1", + "ref": "VDUUmHIKAZQKk9uq" + } + ] + } + ] + } + +} From 0040d924631095cf40c0082f1b5f9298cc7b0604 Mon Sep 17 00:00:00 2001 From: Constantin Ross Date: Thu, 2 Jan 2025 16:17:52 +0100 Subject: [PATCH 3/4] refactor (tests): ensure ci passes --- tests/Prismic/ApiDataTest.php | 3 ++- tests/Prismic/ApiTest.php | 3 ++- 2 files changed, 4 insertions(+), 2 deletions(-) diff --git a/tests/Prismic/ApiDataTest.php b/tests/Prismic/ApiDataTest.php index 38ae2de9..8ad394d5 100644 --- a/tests/Prismic/ApiDataTest.php +++ b/tests/Prismic/ApiDataTest.php @@ -36,7 +36,8 @@ public function testWithJsonStringThrowsExceptionForInvalidJson() ApiData::withJsonString('wtf?'); } - public function testApiDataWorksWithoutBookmarks(){ + public function testApiDataWorksWithoutBookmarks() + { $json = $this->getJsonFixture('data-without-bookmarks.json'); $data = ApiData::withJsonString($json); diff --git a/tests/Prismic/ApiTest.php b/tests/Prismic/ApiTest.php index fd0a4861..d7285751 100755 --- a/tests/Prismic/ApiTest.php +++ b/tests/Prismic/ApiTest.php @@ -201,7 +201,8 @@ public function testBookmarkReturnsCorrectDocumentId() $this->assertNull($api->bookmark('unknown-bookmark')); } - public function testApiWorksWithoutBookmarks() { + public function testApiWorksWithoutBookmarks() + { // Create an ApiData object without bookmarks $data = $this->getJsonFixture('data-without-bookmarks.json'); $apiData = ApiData::withJsonString($data); From 263d801073a37bea602be0e1fdf4bb617f932770 Mon Sep 17 00:00:00 2001 From: Constantin Ross Date: Thu, 2 Jan 2025 16:20:20 +0100 Subject: [PATCH 4/4] refactor (bookmark): split doc block line to pass ci max length --- src/Prismic/Api.php | 6 ++++-- src/Prismic/ApiData.php | 3 ++- 2 files changed, 6 insertions(+), 3 deletions(-) diff --git a/src/Prismic/Api.php b/src/Prismic/Api.php index 92da2aa5..2918d025 100644 --- a/src/Prismic/Api.php +++ b/src/Prismic/Api.php @@ -151,7 +151,8 @@ public function getRefFromLabel(string $label) :? Ref * Returns the list of all bookmarks on the repository. If you're looking * for a document from it's bookmark name, you should use the bookmark() function. * - * @deprecated 5.4.0 This method will no longer work after the 12 February 2025, as bookmarks are removed from the API. + * @deprecated 5.4.0 This method will no longer work after the 12 February 2025, + * as bookmarks are removed from the API. * * @return array the array of bookmarks */ @@ -167,7 +168,8 @@ public function bookmarks() : array * Most starter projects embed a helper to query a document from their ID string, * which makes this even easier. * - * @deprecated 5.4.0 This method will no longer work after the 12 February 2025, as bookmarks are removed from the API. + * @deprecated 5.4.0 This method will no longer work after the 12 February 2025, + * as bookmarks are removed from the API. * * @param string $name the bookmark name to use * diff --git a/src/Prismic/ApiData.php b/src/Prismic/ApiData.php index 7d7f985c..4bab2119 100644 --- a/src/Prismic/ApiData.php +++ b/src/Prismic/ApiData.php @@ -162,7 +162,8 @@ public function getRefs() : array /** * Get the bookmarks * - * @deprecated 5.4.0 This method will no longer work after the 12 February 2025, as bookmarks are removed from the API. + * @deprecated 5.4.0 This method will no longer work after the 12 February 2025, + * as bookmarks are removed from the API. */ public function getBookmarks() : array {