8282-testToMaster #1057

Merged
alexm merged 215 commits from 8282-testToMaster into master 2024-12-10 06:23:36 +00:00
2 changed files with 23 additions and 12 deletions
Showing only changes of commit 43f94ede64 - Show all commits

View File

@ -9,7 +9,7 @@ const token = getTokenMultimedia();
export async function downloadFile(id, model = 'dms', urlPath = '/downloadFile', url) { export async function downloadFile(id, model = 'dms', urlPath = '/downloadFile', url) {
const appUrl = (await getUrl('', 'lilium')).replace('/#/', ''); const appUrl = (await getUrl('', 'lilium')).replace('/#/', '');
const response = await axios.get( const response = await axios.get(
url ?? `${appUrl}/api/${model}/${id}${urlPath}?access_token=${token}`, url ?? `${appUrl}/${model}/${id}${urlPath}?access_token=${token}`,
{ responseType: 'blob' } { responseType: 'blob' }
); );

View File

@ -1,25 +1,36 @@
import { vi, describe, expect, it } from 'vitest'; import { vi, describe, expect, it, beforeAll, afterAll } from 'vitest';
import { axios } from 'app/test/vitest/helper'; import { axios } from 'app/test/vitest/helper';
import { downloadFile } from 'src/composables/downloadFile'; import { downloadFile } from 'src/composables/downloadFile';
import { useSession } from 'src/composables/useSession'; import { useSession } from 'src/composables/useSession';
const session = useSession(); const session = useSession();
const token = session.getToken(); const token = session.getToken();
describe('downloadFile', () => { describe('downloadFile', () => {
const baseUrl = 'http://localhost:9000';
let defaulCreateObjectURL;
beforeAll(() => {
defaulCreateObjectURL = window.URL.createObjectURL;
window.URL.createObjectURL = vi.fn(() => 'blob:http://localhost:9000/blob-id');
});
afterAll(() => (window.URL.createObjectURL = defaulCreateObjectURL));
it('should open a new window to download the file', async () => { it('should open a new window to download the file', async () => {
const url = 'http://localhost:9000'; const res = {
data: new Blob(['file content'], { type: 'application/octet-stream' }),
vi.spyOn(axios, 'get').mockResolvedValueOnce({ data: url }); headers: { 'content-disposition': 'attachment; filename="test-file.txt"' },
};
const mockWindowOpen = vi.spyOn(window, 'open'); vi.spyOn(axios, 'get').mockImplementation((url) => {
if (url == 'Urls/getUrl') return Promise.resolve({ data: baseUrl });
else if (url.includes('downloadFile')) return Promise.resolve(res);
});
await downloadFile(1); await downloadFile(1);
expect(mockWindowOpen).toHaveBeenCalledWith( expect(axios.get).toHaveBeenCalledWith(
`${url}/api/dms/1/downloadFile?access_token=${token}` `${baseUrl}/dms/1/downloadFile?access_token=${token}`,
{ responseType: 'blob' }
); );
mockWindowOpen.mockRestore();
}); });
}); });