mirror of
https://github.com/silverstripe/silverstripe-framework
synced 2024-10-22 14:05:37 +02:00
Merge branch '4.9' into 4
This commit is contained in:
commit
43b005e396
@ -27,6 +27,7 @@ use SilverStripe\Security\Permission;
|
||||
use SilverStripe\Security\RememberLoginHash;
|
||||
use SilverStripe\Security\Security;
|
||||
use SilverStripe\Security\Tests\MemberTest\FieldsExtension;
|
||||
use SilverStripe\SessionManager\Models\LoginSession;
|
||||
|
||||
class MemberTest extends FunctionalTest
|
||||
{
|
||||
@ -1198,19 +1199,22 @@ class MemberTest extends FunctionalTest
|
||||
]
|
||||
);
|
||||
$this->assertEquals(
|
||||
RememberLoginHash::get()->filter(['MemberID'=>$m1->ID, 'DeviceID'=>$firstHash->DeviceID])->count(),
|
||||
1
|
||||
1,
|
||||
RememberLoginHash::get()->filter(['MemberID'=>$m1->ID, 'DeviceID'=>$firstHash->DeviceID])->count()
|
||||
);
|
||||
|
||||
// If session-manager module is installed then logout_across_devices is modified so skip
|
||||
if (!class_exists(LoginSession::class)) {
|
||||
// Logging out from any device when all login hashes should be removed
|
||||
RememberLoginHash::config()->update('logout_across_devices', true);
|
||||
Injector::inst()->get(IdentityStore::class)->logIn($m1, true);
|
||||
$this->get('Security/logout', $this->session());
|
||||
$this->assertEquals(
|
||||
RememberLoginHash::get()->filter('MemberID', $m1->ID)->count(),
|
||||
0
|
||||
0,
|
||||
RememberLoginHash::get()->filter('MemberID', $m1->ID)->count()
|
||||
);
|
||||
}
|
||||
}
|
||||
|
||||
public function testCanDelete()
|
||||
{
|
||||
|
@ -5,6 +5,7 @@ namespace SilverStripe\Security\Tests;
|
||||
use SilverStripe\Dev\SapphireTest;
|
||||
use SilverStripe\Security\Member;
|
||||
use SilverStripe\Security\RememberLoginHash;
|
||||
use SilverStripe\SessionManager\Models\LoginSession;
|
||||
|
||||
class RememberLoginHashTest extends SapphireTest
|
||||
{
|
||||
@ -49,6 +50,10 @@ class RememberLoginHashTest extends SapphireTest
|
||||
*/
|
||||
public function testClear(bool $logoutAcrossDevices, string $deviceId, array $expected, array $unexpected)
|
||||
{
|
||||
// If session-manager module is installed then logout_across_devices is modified so skip
|
||||
if (class_exists(LoginSession::class)) {
|
||||
$this->markTestSkipped();
|
||||
}
|
||||
RememberLoginHash::config()->set('logout_across_devices', $logoutAcrossDevices);
|
||||
|
||||
RememberLoginHash::clear(
|
||||
@ -75,6 +80,10 @@ class RememberLoginHashTest extends SapphireTest
|
||||
|
||||
public function testGetSetLogoutAcrossDevices()
|
||||
{
|
||||
// If session-manager module is installed then logout_across_devices is modified so skip
|
||||
if (class_exists(LoginSession::class)) {
|
||||
$this->markTestSkipped();
|
||||
}
|
||||
// set config directly
|
||||
RememberLoginHash::config()->set('logout_across_devices', true);
|
||||
$this->assertTrue(RememberLoginHash::getLogoutAcrossDevices());
|
||||
|
Loading…
Reference in New Issue
Block a user