From e116df999cfa1605365dbba6c9d6b540ef945f3d Mon Sep 17 00:00:00 2001 From: Steve Boyd Date: Thu, 24 Nov 2022 17:35:13 +1300 Subject: [PATCH] API Stop using deprecated API --- tests/php/Store/SessionStoreTest.php | 10 ++++++++-- 1 file changed, 8 insertions(+), 2 deletions(-) diff --git a/tests/php/Store/SessionStoreTest.php b/tests/php/Store/SessionStoreTest.php index 27e27106..3962794d 100644 --- a/tests/php/Store/SessionStoreTest.php +++ b/tests/php/Store/SessionStoreTest.php @@ -7,15 +7,21 @@ use SilverStripe\ORM\Connect\Database; use SilverStripe\ORM\DB; use SilverStripe\Security\Member; +use SilverStripe\Dev\Deprecation; class SessionStoreTest extends SapphireTest { public function testSerializeThrowsExceptionOnFailure() { + if (Deprecation::isEnabled()) { + $this->markTestSkipped('Test calls deprecated code'); + } $this->expectException(\RuntimeException::class); $this->expectExceptionMessageMatches('/possibly incorrectly encoded/'); $store = new SessionStore($this->createMock(Member::class)); $store->setState(['some binary' => random_bytes(32)]); + // changing this to __serialize() won't cause RunTimeException to + // be thrown because __serialize() does not use json_encode() $store->serialize(); } @@ -83,7 +89,7 @@ public function testDatabaseIsNotAccessedOnDeserialise() $member = new Member(); $member->ID = 1; $store = new SessionStore($member); - $serialised = $store->serialize(); + $serialised = $store->__serialize(); // Replace the DB connection with a mock $connection = DB::get_conn(); @@ -97,7 +103,7 @@ public function testDatabaseIsNotAccessedOnDeserialise() DB::set_conn($database); // Replicate the deserialisation that happens on session start - $store->unserialize($serialised); + $store->__unserialize($serialised); // Finish the test and allow mock assertions to fail the test DB::set_conn($connection);