mirror of
https://github.com/Kir-Antipov/mc-publish.git
synced 2025-01-22 10:04:45 +01:00
Added tests for generic-platform-uploader
This commit is contained in:
parent
bbcc4c4971
commit
b35f5822ed
1 changed files with 70 additions and 0 deletions
70
tests/unit/platforms/generic-platform-uploader.spec.ts
Normal file
70
tests/unit/platforms/generic-platform-uploader.spec.ts
Normal file
|
@ -0,0 +1,70 @@
|
||||||
|
import { PlatformType } from "@/platforms";
|
||||||
|
import { Logger } from "@/utils/logging";
|
||||||
|
import { SoftError } from "@/utils/errors";
|
||||||
|
import { FileInfo } from "@/utils/io";
|
||||||
|
import { SecureString } from "@/utils/security";
|
||||||
|
import { GenericPlatformUploadRequest, GenericPlatformUploader, GenericPlatformUploaderOptions } from "@/platforms/generic-platform-uploader";
|
||||||
|
|
||||||
|
class MockGenericPlatformUploader extends GenericPlatformUploader<GenericPlatformUploaderOptions, GenericPlatformUploadRequest, boolean> {
|
||||||
|
constructor(options?: GenericPlatformUploaderOptions) {
|
||||||
|
super(options);
|
||||||
|
}
|
||||||
|
|
||||||
|
get platform(): PlatformType {
|
||||||
|
return "" as PlatformType;
|
||||||
|
}
|
||||||
|
|
||||||
|
uploadCore(): Promise<boolean> {
|
||||||
|
return Promise.resolve(true);
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
function createLogger(): Logger {
|
||||||
|
return {
|
||||||
|
error: jest.fn(),
|
||||||
|
warn: jest.fn(),
|
||||||
|
info: jest.fn(),
|
||||||
|
debug: jest.fn(),
|
||||||
|
fatal: jest.fn(),
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
function createRequest(): GenericPlatformUploadRequest {
|
||||||
|
return {
|
||||||
|
token: SecureString.from("token"),
|
||||||
|
files: [FileInfo.of("file.txt")],
|
||||||
|
retryAttempts: 3,
|
||||||
|
retryDelay: 0,
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
describe("GenericPlatformUploader", () => {
|
||||||
|
describe("upload", () => {
|
||||||
|
test("retries if a soft error is thrown", async () => {
|
||||||
|
const request = createRequest();
|
||||||
|
const logger = createLogger();
|
||||||
|
const uploader = new MockGenericPlatformUploader({ logger });
|
||||||
|
jest.spyOn(uploader, "uploadCore").mockImplementationOnce(() => Promise.reject(new SoftError(true)));
|
||||||
|
jest.spyOn(uploader, "uploadCore").mockImplementationOnce(() => Promise.reject(new SoftError(true)));
|
||||||
|
|
||||||
|
await expect(uploader.upload(request)).resolves.toBe(true);
|
||||||
|
|
||||||
|
expect(logger.error).toHaveBeenCalledWith(expect.any(SoftError));
|
||||||
|
expect(uploader.uploadCore).toHaveBeenCalledWith(request);
|
||||||
|
expect(uploader.uploadCore).toHaveBeenCalledTimes(3);
|
||||||
|
});
|
||||||
|
|
||||||
|
test("doesn't retry if a non-soft error is thrown", async () => {
|
||||||
|
const request = createRequest();
|
||||||
|
const logger = createLogger();
|
||||||
|
const uploader = new MockGenericPlatformUploader({ logger });
|
||||||
|
jest.spyOn(uploader, "uploadCore").mockImplementationOnce(() => Promise.reject(new Error()));
|
||||||
|
jest.spyOn(uploader, "uploadCore").mockImplementationOnce(() => Promise.reject(new Error()));
|
||||||
|
|
||||||
|
await expect(uploader.upload(request)).rejects.toThrow(Error);
|
||||||
|
|
||||||
|
expect(uploader.uploadCore).toHaveBeenCalledWith(request);
|
||||||
|
expect(uploader.uploadCore).toHaveBeenCalledTimes(1);
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
Loading…
Reference in a new issue