HEX
Server: Apache/2.4.52 (Ubuntu)
System: Linux ip-172-31-4-197 6.8.0-1036-aws #38~22.04.1-Ubuntu SMP Fri Aug 22 15:44:33 UTC 2025 x86_64
User: ubuntu (1000)
PHP: 7.4.33
Disabled: pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Upload Files
File: /var/www/api-management/node_modules/bcrypt/test/repetitions.test.js
const bcrypt = require('../bcrypt');

const EXPECTED = 2500; //number of times to iterate these tests.)

test('salt_length', () => {
    expect.assertions(EXPECTED);

    return Promise.all(Array.from({length: EXPECTED},
        () => bcrypt.genSalt(10)
            .then(salt => expect(salt).toHaveLength(29))));
})

test('test_hash_length', () => {
    expect.assertions(EXPECTED);
    const SALT = '$2a$04$TnjywYklQbbZjdjBgBoA4e';
    return Promise.all(Array.from({length: EXPECTED},
        () => bcrypt.hash('test', SALT)
            .then(hash => expect(hash).toHaveLength(60))));
})

test('test_compare', () => {
    expect.assertions(EXPECTED);
    const HASH = '$2a$04$TnjywYklQbbZjdjBgBoA4e9G7RJt9blgMgsCvUvus4Iv4TENB5nHy';
    return Promise.all(Array.from({length: EXPECTED},
        () => bcrypt.compare('test', HASH)
            .then(match => expect(match).toEqual(true))));
})

test('test_hash_and_compare', () => {
    expect.assertions(EXPECTED * 3);
    const salt = bcrypt.genSaltSync(4)

    return Promise.all(Array.from({length: EXPECTED},
        () => {
            const password = 'secret' + Math.random();
            return bcrypt.hash(password, salt)
                .then(hash => {
                    expect(hash).toHaveLength(60);
                    const goodCompare = bcrypt.compare(password, hash).then(res => expect(res).toEqual(true));
                    const badCompare = bcrypt.compare('bad' + password, hash).then(res => expect(res).toEqual(false));

                    return Promise.all([goodCompare, badCompare]);
                });
        }));
}, 10000);