mirror of
https://github.com/immich-app/immich.git
synced 2025-01-23 20:22:45 +01:00
fix(cli): fix broken --album on Windows. (#10626)
Extract folder names via system function to avoid the difference between / and \ on Windows.
This commit is contained in:
parent
7f5a3e5adb
commit
a3c3619811
2 changed files with 25 additions and 5 deletions
cli/src/commands
19
cli/src/commands/asset.spec.ts
Normal file
19
cli/src/commands/asset.spec.ts
Normal file
|
@ -0,0 +1,19 @@
|
||||||
|
import { platform } from 'node:os';
|
||||||
|
import { UploadOptionsDto, getAlbumName } from 'src/commands/asset';
|
||||||
|
import { describe, expect, it } from 'vitest';
|
||||||
|
|
||||||
|
describe('Unit function tests', () => {
|
||||||
|
it('should return a non-undefined value', () => {
|
||||||
|
if (platform() === 'win32') {
|
||||||
|
// This is meaningless for Unix systems.
|
||||||
|
expect(getAlbumName(String.raw`D:\test\Filename.txt`, {} as UploadOptionsDto)).toBe('test');
|
||||||
|
}
|
||||||
|
expect(getAlbumName('D:/parentfolder/test/Filename.txt', {} as UploadOptionsDto)).toBe('test');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('has higher priority to return `albumName` in `options`', () => {
|
||||||
|
expect(getAlbumName('/parentfolder/test/Filename.txt', { albumName: 'example' } as UploadOptionsDto)).toBe(
|
||||||
|
'example',
|
||||||
|
);
|
||||||
|
});
|
||||||
|
});
|
|
@ -15,7 +15,6 @@ import { Presets, SingleBar } from 'cli-progress';
|
||||||
import { chunk } from 'lodash-es';
|
import { chunk } from 'lodash-es';
|
||||||
import { Stats, createReadStream } from 'node:fs';
|
import { Stats, createReadStream } from 'node:fs';
|
||||||
import { stat, unlink } from 'node:fs/promises';
|
import { stat, unlink } from 'node:fs/promises';
|
||||||
import os from 'node:os';
|
|
||||||
import path, { basename } from 'node:path';
|
import path, { basename } from 'node:path';
|
||||||
import { BaseOptions, authenticate, crawl, sha1 } from 'src/utils';
|
import { BaseOptions, authenticate, crawl, sha1 } from 'src/utils';
|
||||||
|
|
||||||
|
@ -25,7 +24,7 @@ const s = (count: number) => (count === 1 ? '' : 's');
|
||||||
type AssetBulkUploadCheckResults = Array<AssetBulkUploadCheckResult & { id: string }>;
|
type AssetBulkUploadCheckResults = Array<AssetBulkUploadCheckResult & { id: string }>;
|
||||||
type Asset = { id: string; filepath: string };
|
type Asset = { id: string; filepath: string };
|
||||||
|
|
||||||
interface UploadOptionsDto {
|
export interface UploadOptionsDto {
|
||||||
recursive?: boolean;
|
recursive?: boolean;
|
||||||
ignore?: string;
|
ignore?: string;
|
||||||
dryRun?: boolean;
|
dryRun?: boolean;
|
||||||
|
@ -346,7 +345,9 @@ const updateAlbums = async (assets: Asset[], options: UploadOptionsDto) => {
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|
||||||
const getAlbumName = (filepath: string, options: UploadOptionsDto) => {
|
// `filepath` valid format:
|
||||||
const folderName = os.platform() === 'win32' ? filepath.split('\\').at(-2) : filepath.split('/').at(-2);
|
// - Windows: `D:\\test\\Filename.txt` or `D:/test/Filename.txt`
|
||||||
return options.albumName ?? folderName;
|
// - Unix: `/test/Filename.txt`
|
||||||
|
export const getAlbumName = (filepath: string, options: UploadOptionsDto) => {
|
||||||
|
return options.albumName ?? path.basename(path.dirname(filepath));
|
||||||
};
|
};
|
||||||
|
|
Loading…
Reference in a new issue