2024-10-07 08:28:30 +02:00
|
|
|
import { describe, expect, test, vi } from 'vitest';
|
|
|
|
|
2021-10-29 17:33:05 +02:00
|
|
|
import { EncryptionMethod, createSalt } from '../src/crypt3';
|
2020-08-19 20:27:35 +02:00
|
|
|
|
2024-10-07 08:28:30 +02:00
|
|
|
vi.mock('../src/crypto-utils', async (importOriginal) => ({
|
|
|
|
...(await importOriginal<typeof import('../src/crypto-utils')>()),
|
|
|
|
randomBytes: (len: number): { toString: () => string } => {
|
|
|
|
return {
|
|
|
|
toString: (): string => '/UEGzD0RxSNDZA=='.substring(0, len),
|
|
|
|
};
|
|
|
|
},
|
|
|
|
}));
|
2020-08-19 20:27:35 +02:00
|
|
|
|
|
|
|
describe('createSalt', () => {
|
|
|
|
test('should match with the correct salt type', () => {
|
2021-01-31 00:41:33 +02:00
|
|
|
expect(createSalt(EncryptionMethod.crypt)).toEqual('/U');
|
|
|
|
expect(createSalt(EncryptionMethod.md5)).toEqual('$1$/UEGzD0RxS');
|
|
|
|
expect(createSalt(EncryptionMethod.blowfish)).toEqual('$2a$/UEGzD0RxS');
|
|
|
|
expect(createSalt(EncryptionMethod.sha256)).toEqual('$5$/UEGzD0RxS');
|
|
|
|
expect(createSalt(EncryptionMethod.sha512)).toEqual('$6$/UEGzD0RxS');
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
|
|
|
|
test('should fails on unkwon type', () => {
|
|
|
|
expect(function () {
|
2021-01-31 00:41:33 +02:00
|
|
|
createSalt('bad' as any);
|
2020-08-19 20:27:35 +02:00
|
|
|
}).toThrow(/Unknown salt type at crypt3.createSalt: bad/);
|
|
|
|
});
|
|
|
|
|
|
|
|
test('should generate legacy crypt salt by default', () => {
|
2021-01-31 00:41:33 +02:00
|
|
|
expect(createSalt()).toEqual(createSalt(EncryptionMethod.crypt));
|
2020-08-19 20:27:35 +02:00
|
|
|
});
|
|
|
|
});
|