mirror of
https://github.com/bitwarden/browser
synced 2025-01-08 16:33:38 +01:00
da47992a22
* Add item decryption to encryptService * Create multithreadEncryptService subclass to handle web workers * Create encryption web worker * Refactor cipherService to use new interface * Update dependencies
74 lines
3.2 KiB
TypeScript
74 lines
3.2 KiB
TypeScript
// eslint-disable-next-line no-restricted-imports
|
|
import { Arg, Substitute, SubstituteOf } from "@fluffy-spoon/substitute";
|
|
|
|
import { ApiService } from "@bitwarden/common/abstractions/api.service";
|
|
import { CryptoService } from "@bitwarden/common/abstractions/crypto.service";
|
|
import { EncryptService } from "@bitwarden/common/abstractions/encrypt.service";
|
|
import { FileUploadService } from "@bitwarden/common/abstractions/fileUpload.service";
|
|
import { I18nService } from "@bitwarden/common/abstractions/i18n.service";
|
|
import { LogService } from "@bitwarden/common/abstractions/log.service";
|
|
import { SearchService } from "@bitwarden/common/abstractions/search.service";
|
|
import { SettingsService } from "@bitwarden/common/abstractions/settings.service";
|
|
import { StateService } from "@bitwarden/common/abstractions/state.service";
|
|
import { Cipher } from "@bitwarden/common/models/domain/cipher";
|
|
import { EncArrayBuffer } from "@bitwarden/common/models/domain/enc-array-buffer";
|
|
import { EncString } from "@bitwarden/common/models/domain/enc-string";
|
|
import { SymmetricCryptoKey } from "@bitwarden/common/models/domain/symmetric-crypto-key";
|
|
import { CipherService } from "@bitwarden/common/services/cipher.service";
|
|
|
|
const ENCRYPTED_TEXT = "This data has been encrypted";
|
|
const ENCRYPTED_BYTES = Substitute.for<EncArrayBuffer>();
|
|
|
|
describe("Cipher Service", () => {
|
|
let cryptoService: SubstituteOf<CryptoService>;
|
|
let stateService: SubstituteOf<StateService>;
|
|
let settingsService: SubstituteOf<SettingsService>;
|
|
let apiService: SubstituteOf<ApiService>;
|
|
let fileUploadService: SubstituteOf<FileUploadService>;
|
|
let i18nService: SubstituteOf<I18nService>;
|
|
let searchService: SubstituteOf<SearchService>;
|
|
let logService: SubstituteOf<LogService>;
|
|
let encryptService: SubstituteOf<EncryptService>;
|
|
|
|
let cipherService: CipherService;
|
|
|
|
beforeEach(() => {
|
|
cryptoService = Substitute.for<CryptoService>();
|
|
stateService = Substitute.for<StateService>();
|
|
settingsService = Substitute.for<SettingsService>();
|
|
apiService = Substitute.for<ApiService>();
|
|
fileUploadService = Substitute.for<FileUploadService>();
|
|
i18nService = Substitute.for<I18nService>();
|
|
searchService = Substitute.for<SearchService>();
|
|
logService = Substitute.for<LogService>();
|
|
encryptService = Substitute.for<EncryptService>();
|
|
|
|
cryptoService.encryptToBytes(Arg.any(), Arg.any()).resolves(ENCRYPTED_BYTES);
|
|
cryptoService.encrypt(Arg.any(), Arg.any()).resolves(new EncString(ENCRYPTED_TEXT));
|
|
|
|
cipherService = new CipherService(
|
|
cryptoService,
|
|
settingsService,
|
|
apiService,
|
|
fileUploadService,
|
|
i18nService,
|
|
() => searchService,
|
|
logService,
|
|
stateService,
|
|
encryptService
|
|
);
|
|
});
|
|
|
|
it("attachments upload encrypted file contents", async () => {
|
|
const fileName = "filename";
|
|
const fileData = new Uint8Array(10).buffer;
|
|
cryptoService.getOrgKey(Arg.any()).resolves(new SymmetricCryptoKey(new Uint8Array(32).buffer));
|
|
|
|
await cipherService.saveAttachmentRawWithServer(new Cipher(), fileName, fileData);
|
|
|
|
fileUploadService
|
|
.received(1)
|
|
.uploadCipherAttachment(Arg.any(), Arg.any(), new EncString(ENCRYPTED_TEXT), ENCRYPTED_BYTES);
|
|
});
|
|
});
|