renovate/lib/util/sanitize.spec.ts

45 lines
1.3 KiB
TypeScript
Raw Normal View History

import {
addSecretForSanitizing,
clearSanitizedSecretsList,
sanitize,
} from './sanitize';
import { toBase64 } from './string';
2019-09-12 10:48:31 +00:00
describe('util/sanitize', () => {
2019-09-12 10:48:31 +00:00
beforeEach(() => {
clearSanitizedSecretsList();
2019-09-12 10:48:31 +00:00
});
it('sanitizes empty string', () => {
addSecretForSanitizing('');
expect(sanitize(null as never)).toBeNull();
expect(sanitize('')).toBe('');
2019-09-12 10:48:31 +00:00
});
2019-09-12 10:48:31 +00:00
it('sanitizes secrets from strings', () => {
const token = '123testtoken';
2019-09-12 10:48:31 +00:00
const username = 'userabc';
const password = 'password123';
addSecretForSanitizing(token, 'global');
const hashed = toBase64(`${username}:${password}`);
addSecretForSanitizing(hashed);
addSecretForSanitizing(password);
const input = `My token is ${token}, username is "${username}" and password is "${password}" (hashed: ${hashed})`;
const output =
'My token is **redacted**, username is "userabc" and password is "**redacted**" (hashed: **redacted**)';
expect(sanitize(input)).toBe(output);
const inputX2 = [input, input].join('\n');
const outputX2 = [output, output].join('\n');
expect(sanitize(inputX2)).toBe(outputX2);
2019-09-12 10:48:31 +00:00
});
it('sanitizes github app tokens', () => {
addSecretForSanitizing('x-access-token:abc123');
expect(sanitize(`hello ${toBase64('abc123')} world`)).toBe(
'hello **redacted** world'
);
});
2019-09-12 10:48:31 +00:00
});