2009-12-02 09:40:33 +00:00
|
|
|
<?php
|
2016-06-15 16:03:16 +12:00
|
|
|
|
2016-10-14 14:30:05 +13:00
|
|
|
namespace SilverStripe\Security\Tests;
|
|
|
|
|
2016-06-15 16:03:16 +12:00
|
|
|
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\Security;
|
2016-08-19 10:51:35 +12:00
|
|
|
use SilverStripe\Dev\SapphireTest;
|
2022-11-15 18:20:54 +13:00
|
|
|
use SilverStripe\Security\MemberAuthenticator\MemberAuthenticator;
|
2016-08-19 10:51:35 +12:00
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
class MemberCsvBulkLoaderTest extends SapphireTest
|
|
|
|
{
|
|
|
|
protected static $fixture_file = 'MemberCsvBulkLoaderTest.yml';
|
|
|
|
|
2021-10-27 15:39:47 +13:00
|
|
|
protected function setUp(): void
|
2018-12-02 23:04:34 +00:00
|
|
|
{
|
|
|
|
parent::setUp();
|
2024-10-02 14:38:21 +13:00
|
|
|
Member::set_password_validator(null);
|
2018-12-02 23:04:34 +00:00
|
|
|
}
|
|
|
|
|
2016-12-16 17:34:21 +13:00
|
|
|
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);
|
2016-12-16 17:34:21 +13:00
|
|
|
$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);
|
2016-12-16 17:34:21 +13:00
|
|
|
$updated = $results->Updated()->toArray();
|
2022-04-14 13:12:59 +12:00
|
|
|
$this->assertEquals(count($updated ?? []), 1);
|
2016-12-16 17:34:21 +13:00
|
|
|
$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();
|
2020-04-20 18:58:09 +01:00
|
|
|
$loader->setGroups([$existinggroup]);
|
2016-12-16 17:34:21 +13:00
|
|
|
|
|
|
|
$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') ?? []));
|
2016-12-16 17:34:21 +13:00
|
|
|
$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') ?? []));
|
2016-12-16 17:34:21 +13:00
|
|
|
$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,
|
2020-04-20 18:58:09 +01:00
|
|
|
[
|
2016-12-16 17:34:21 +13:00
|
|
|
'"Group"."Code"' => 'newgroup'
|
2020-04-20 18:58:09 +01:00
|
|
|
]
|
2016-12-16 17:34:21 +13:00
|
|
|
);
|
|
|
|
$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') ?? []));
|
2016-12-16 17:34:21 +13:00
|
|
|
$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') ?? []));
|
2016-12-16 17:34:21 +13:00
|
|
|
$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');
|
2016-12-16 17:34:21 +13:00
|
|
|
$this->assertTrue($result->isValid());
|
|
|
|
}
|
2012-03-24 16:04:52 +13:00
|
|
|
}
|