Skip to content

Commit

Permalink
fix(cli): fix broken --album on Windows.
Browse files Browse the repository at this point in the history
Extract folder names via system function to avoid the difference between / and \ on Windows.
  • Loading branch information
fky2015 committed Jun 25, 2024
1 parent 5912fcc commit 317f010
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 4 deletions.
15 changes: 15 additions & 0 deletions cli/src/commands/asset.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
import { describe, it, expect } from 'vitest';
import { getAlbumName, UploadOptionsDto } from 'src/commands/asset';
import { platform } from 'node:os'

describe('Unit function tests', () => {
it('should return a non-undefined value', () => {
if (platform() === 'win32') // This is meaningless for Unix systems.
expect(getAlbumName('D:\\test\\Filename.txt', {} as UploadOptionsDto)).toBe('test')

Check failure on line 8 in cli/src/commands/asset.spec.ts

View workflow job for this annotation

GitHub Actions / CLI

Expected { after 'if' condition

Check failure on line 8 in cli/src/commands/asset.spec.ts

View workflow job for this annotation

GitHub Actions / CLI

`String.raw` should be used to avoid escaping `\`
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');
})
});
10 changes: 6 additions & 4 deletions cli/src/commands/asset.ts
Original file line number Diff line number Diff line change
Expand Up @@ -25,7 +25,7 @@ const s = (count: number) => (count === 1 ? '' : 's');
type AssetBulkUploadCheckResults = Array<AssetBulkUploadCheckResult & { id: string }>;
type Asset = { id: string; filepath: string };

interface UploadOptionsDto {
export interface UploadOptionsDto {
recursive?: boolean;
ignore?: string;
dryRun?: boolean;
Expand Down Expand Up @@ -346,7 +346,9 @@ const updateAlbums = async (assets: Asset[], options: UploadOptionsDto) => {
}
};

const getAlbumName = (filepath: string, options: UploadOptionsDto) => {
const folderName = os.platform() === 'win32' ? filepath.split('\\').at(-2) : filepath.split('/').at(-2);
return options.albumName ?? folderName;
// `filepath` valid format:
// - Windows: `D:\\test\\Filename.txt` or `D:/test/Filename.txt`
// - Unix: `/test/Filename.txt`
export const getAlbumName = (filepath: string, options: UploadOptionsDto) => {
return options.albumName ?? path.basename(path.dirname(filepath));
};

0 comments on commit 317f010

Please sign in to comment.