summaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorChristopher Ng <chrng8@gmail.com>2022-04-06 20:13:47 +0000
committerChristopher Ng <chrng8@gmail.com>2022-04-07 00:44:06 +0000
commit32fc848fcff1ec3a31a198735930fde5b4c194f2 (patch)
tree4230750ddfc820dad1007b6f55e27f0e7e87af23
parent3fb420115d8754208498c374170ad6839029392d (diff)
downloadnextcloud-server-32fc848fcff1ec3a31a198735930fde5b4c194f2.tar.gz
nextcloud-server-32fc848fcff1ec3a31a198735930fde5b4c194f2.zip
Test avatar migration
Signed-off-by: Christopher Ng <chrng8@gmail.com>
-rw-r--r--apps/settings/tests/UserMigration/AccountMigratorTest.php67
-rw-r--r--apps/settings/tests/UserMigration/assets/account-complex.jpgbin0 -> 1063519 bytes
-rw-r--r--apps/settings/tests/UserMigration/assets/account.pngbin0 -> 913877 bytes
3 files changed, 58 insertions, 9 deletions
diff --git a/apps/settings/tests/UserMigration/AccountMigratorTest.php b/apps/settings/tests/UserMigration/AccountMigratorTest.php
index 1ad68dbd341..74455bc91e1 100644
--- a/apps/settings/tests/UserMigration/AccountMigratorTest.php
+++ b/apps/settings/tests/UserMigration/AccountMigratorTest.php
@@ -30,6 +30,7 @@ use OCA\Settings\AppInfo\Application;
use OCA\Settings\UserMigration\AccountMigrator;
use OCP\Accounts\IAccountManager;
use OCP\AppFramework\App;
+use OCP\IAvatarManager;
use OCP\IUserManager;
use OCP\UserMigration\IExportDestination;
use OCP\UserMigration\IImportSource;
@@ -45,6 +46,8 @@ class AccountMigratorTest extends TestCase {
private IUserManager $userManager;
+ private IAvatarManager $avatarManager;
+
private AccountMigrator $migrator;
/** @var IImportSource|MockObject */
@@ -60,11 +63,14 @@ class AccountMigratorTest extends TestCase {
private const REGEX_ACCOUNT_FILE = '/^' . Application::APP_ID . '\/' . '[a-z]+\.json' . '$/';
+ private const REGEX_AVATAR_FILE = '/^' . Application::APP_ID . '\/' . 'avatar\.(jpg|png)' . '$/';
+
protected function setUp(): void {
$app = new App(Application::APP_ID);
$container = $app->getContainer();
$this->userManager = $container->get(IUserManager::class);
+ $this->avatarManager = $container->get(IAvatarManager::class);
$this->migrator = $container->get(AccountMigrator::class);
$this->importSource = $this->createMock(IImportSource::class);
@@ -74,14 +80,23 @@ class AccountMigratorTest extends TestCase {
public function dataImportExportAccount(): array {
return array_map(
- fn (string $filename) => [
- UUIDUtil::getUUID(),
- json_decode(file_get_contents(self::ASSETS_DIR . $filename), true, 512, JSON_THROW_ON_ERROR),
- ],
- array_diff(
- scandir(self::ASSETS_DIR),
- // Exclude current and parent directories
- ['.', '..'],
+ function (string $filename) {
+ $dataPath = self::ASSETS_DIR . $filename;
+ $avatarBasename = pathinfo($filename, PATHINFO_FILENAME);
+ $avatarPath = self::ASSETS_DIR . (file_exists(self::ASSETS_DIR . "$avatarBasename.jpg") ? "$avatarBasename.jpg" : "$avatarBasename.png");
+ return [
+ UUIDUtil::getUUID(),
+ json_decode(file_get_contents($dataPath), true, 512, JSON_THROW_ON_ERROR),
+ $avatarPath,
+ ];
+ },
+ array_filter(
+ array_diff(
+ scandir(self::ASSETS_DIR),
+ // Exclude current and parent directories
+ ['.', '..'],
+ ),
+ fn (string $filename) => pathinfo($filename, PATHINFO_EXTENSION) === 'json',
),
);
}
@@ -89,8 +104,9 @@ class AccountMigratorTest extends TestCase {
/**
* @dataProvider dataImportExportAccount
*/
- public function testImportExportAccount(string $userId, array $importData): void {
+ public function testImportExportAccount(string $userId, array $importData, string $avatarPath): void {
$user = $this->userManager->createUser($userId, 'topsecretpassword');
+ $avatarExt = pathinfo($avatarPath, PATHINFO_EXTENSION);
$exportData = $importData;
// Verification status of email will be set to in progress on import so we set the export data to reflect that
$exportData[IAccountManager::PROPERTY_EMAIL]['verified'] = IAccountManager::VERIFICATION_IN_PROGRESS;
@@ -107,14 +123,47 @@ class AccountMigratorTest extends TestCase {
->with($this->matchesRegularExpression(self::REGEX_ACCOUNT_FILE))
->willReturn(json_encode($importData));
+ $this->importSource
+ ->expects($this->once())
+ ->method('getFolderListing')
+ ->with(Application::APP_ID . '/')
+ ->willReturn(["avatar.$avatarExt"]);
+
+ $this->importSource
+ ->expects($this->once())
+ ->method('getFileAsStream')
+ ->with($this->matchesRegularExpression(self::REGEX_AVATAR_FILE))
+ ->willReturn(fopen($avatarPath, 'r'));
+
$this->migrator->import($user, $this->importSource, $this->output);
+ $importedAvatar = $this->avatarManager->getAvatar($user->getUID());
+ $this->assertTrue($importedAvatar->isCustomAvatar());
+
+ /**
+ * Avatar images are re-encoded on import therefore JPEG images which use lossy compression cannot be checked for equality
+ * @see https://github.com/nextcloud/server/blob/9644b7e505dc90a1e683f77ad38dc6dc4e90fa2f/lib/private/legacy/OC_Image.php#L383-L390
+ */
+
+ if ($avatarExt !== 'jpg') {
+ $this->assertStringEqualsFile(
+ $avatarPath,
+ $importedAvatar->getFile(-1)->getContent(),
+ );
+ }
+
$this->exportDestination
->expects($this->once())
->method('addFileContents')
->with($this->matchesRegularExpression(self::REGEX_ACCOUNT_FILE), json_encode($exportData))
->willReturn(true);
+ $this->exportDestination
+ ->expects($this->once())
+ ->method('addFileAsStream')
+ ->with($this->matchesRegularExpression(self::REGEX_AVATAR_FILE), $this->isType('resource'))
+ ->willReturn(true);
+
$this->migrator->export($user, $this->exportDestination, $this->output);
}
}
diff --git a/apps/settings/tests/UserMigration/assets/account-complex.jpg b/apps/settings/tests/UserMigration/assets/account-complex.jpg
new file mode 100644
index 00000000000..bece3675c11
--- /dev/null
+++ b/apps/settings/tests/UserMigration/assets/account-complex.jpg
Binary files differ
diff --git a/apps/settings/tests/UserMigration/assets/account.png b/apps/settings/tests/UserMigration/assets/account.png
new file mode 100644
index 00000000000..12226f14334
--- /dev/null
+++ b/apps/settings/tests/UserMigration/assets/account.png
Binary files differ