silverstripe-framework/tests/php/Security/MemberCsvBulkLoaderTest.php

116 lines
4.3 KiB
PHP
Raw Normal View History

<?php
2016-10-14 14:30:05 +13:00
namespace SilverStripe\Security\Tests;
use SilverStripe\Dev\Deprecation;
use SilverStripe\ORM\DataObject;
2016-10-14 14:30:05 +13:00
use SilverStripe\Security\Group;
2016-06-23 11:37:22 +12:00
use SilverStripe\Security\MemberCsvBulkLoader;
use SilverStripe\Security\Member;
use SilverStripe\Security\PasswordValidator;
2016-06-23 11:37:22 +12:00
use SilverStripe\Security\Security;
use SilverStripe\Dev\SapphireTest;
2022-11-15 18:20:54 +13:00
use SilverStripe\Security\MemberAuthenticator\MemberAuthenticator;
class MemberCsvBulkLoaderTest extends SapphireTest
{
protected static $fixture_file = 'MemberCsvBulkLoaderTest.yml';
protected function setUp(): void
{
parent::setUp();
Deprecation::withSuppressedNotice(
fn() => PasswordValidator::singleton()
->setMinLength(0)
->setTestNames([])
);
}
public function testNewImport()
{
$loader = new MemberCsvBulkLoader();
$results = $loader->load(__DIR__ . '/MemberCsvBulkLoaderTest/MemberCsvBulkLoaderTest.csv');
$created = $results->Created()->toArray();
2022-04-14 13:12:59 +12:00
$this->assertEquals(count($created ?? []), 2);
$this->assertEquals($created[0]->Email, 'author1@test.com');
$this->assertEquals($created[1]->Email, 'author2@test.com');
}
public function testOverwriteExistingImport()
{
$author1 = new Member();
$author1->FirstName = 'author1_first_old';
$author1->Email = 'author1@test.com';
$author1->write();
$loader = new MemberCsvBulkLoader();
$results = $loader->load(__DIR__ . '/MemberCsvBulkLoaderTest/MemberCsvBulkLoaderTest.csv');
$created = $results->Created()->toArray();
2022-04-14 13:12:59 +12:00
$this->assertEquals(count($created ?? []), 1);
$updated = $results->Updated()->toArray();
2022-04-14 13:12:59 +12:00
$this->assertEquals(count($updated ?? []), 1);
$this->assertEquals($created[0]->Email, 'author2@test.com');
$this->assertEquals($updated[0]->Email, 'author1@test.com');
$this->assertEquals($updated[0]->FirstName, 'author1_first');
}
public function testAddToPredefinedGroups()
{
$existinggroup = $this->objFromFixture(Group::class, 'existinggroup');
$loader = new MemberCsvBulkLoader();
$loader->setGroups([$existinggroup]);
$results = $loader->load(__DIR__ . '/MemberCsvBulkLoaderTest/MemberCsvBulkLoaderTest.csv');
$created = $results->Created()->toArray();
2022-04-14 13:12:59 +12:00
$this->assertEquals(1, count($created[0]->Groups()->column('ID') ?? []));
$this->assertContains($existinggroup->ID, $created[0]->Groups()->column('ID'));
2022-04-14 13:12:59 +12:00
$this->assertEquals(1, count($created[1]->Groups()->column('ID') ?? []));
$this->assertContains($existinggroup->ID, $created[1]->Groups()->column('ID'));
}
public function testAddToCsvColumnGroupsByCode()
{
$existinggroup = $this->objFromFixture(Group::class, 'existinggroup');
$loader = new MemberCsvBulkLoader();
$results = $loader->load(__DIR__ . '/MemberCsvBulkLoaderTest/MemberCsvBulkLoaderTest_withGroups.csv');
$newgroup = DataObject::get_one(
Group::class,
[
'"Group"."Code"' => 'newgroup'
]
);
$this->assertEquals($newgroup->Title, 'newgroup');
$created = $results->Created()->toArray();
2022-04-14 13:12:59 +12:00
$this->assertEquals(1, count($created[0]->Groups()->column('ID') ?? []));
$this->assertContains($existinggroup->ID, $created[0]->Groups()->column('ID'));
2022-04-14 13:12:59 +12:00
$this->assertEquals(2, count($created[1]->Groups()->column('ID') ?? []));
$this->assertContains($existinggroup->ID, $created[1]->Groups()->column('ID'));
$this->assertContains($newgroup->ID, $created[1]->Groups()->column('ID'));
}
public function testCleartextPasswordsAreHashedWithDefaultAlgo()
{
$loader = new MemberCsvBulkLoader();
$results = $loader->load(__DIR__ . '/MemberCsvBulkLoaderTest/MemberCsvBulkLoaderTest_cleartextpws.csv');
$member = $results->Created()->First();
$memberID = $member->ID;
DataObject::flush_and_destroy_cache();
$member = DataObject::get_by_id(Member::class, $memberID);
$this->assertEquals(Security::config()->password_encryption_algorithm, $member->getField('PasswordEncryption'));
2022-11-15 18:20:54 +13:00
$auth = new MemberAuthenticator();
$result = $auth->checkPassword($member, 'mypassword');
$this->assertTrue($result->isValid());
}
}