mirror of
https://github.com/mattermost/mattermost.git
synced 2026-02-09 22:03:39 -05:00
The production password hasher uses PBKDF2 with 600,000 iterations, which is slow especially when combined with race detection. This adds a fast test hasher (work factor 1) that can be used during tests to speed up user creation. The fast hasher is only available in non-production builds via build tags, ensuring it cannot be used in production.
86 lines
2.3 KiB
Go
86 lines
2.3 KiB
Go
// Copyright (c) 2015-present Mattermost, Inc. All Rights Reserved.
|
|
// See LICENSE.txt for license information.
|
|
|
|
//go:build !production
|
|
|
|
package hashers
|
|
|
|
import (
|
|
"testing"
|
|
|
|
"github.com/stretchr/testify/require"
|
|
)
|
|
|
|
func TestSetTestHasher(t *testing.T) {
|
|
// Ensure testHasher starts as nil
|
|
SetTestHasher(nil)
|
|
|
|
// Hash should work with nil testHasher (uses latestHasher)
|
|
hash1, err := Hash("password")
|
|
require.NoError(t, err)
|
|
require.NotEmpty(t, hash1)
|
|
|
|
// Set a fast test hasher
|
|
fastHasher := FastTestHasher()
|
|
SetTestHasher(fastHasher)
|
|
defer SetTestHasher(nil)
|
|
|
|
// Hash should now use the fast test hasher
|
|
hash2, err := Hash("password")
|
|
require.NoError(t, err)
|
|
require.NotEmpty(t, hash2)
|
|
|
|
// Verify the hash was generated with different parameters
|
|
// The fast hasher uses work factor 1, so the hash should contain w=1
|
|
require.Contains(t, hash2, "w=1")
|
|
|
|
// Verify the password can be verified against the hash
|
|
hasher, phc, err := GetHasherFromPHCString(hash2)
|
|
require.NoError(t, err)
|
|
require.NoError(t, hasher.CompareHashAndPassword(phc, "password"))
|
|
require.Error(t, hasher.CompareHashAndPassword(phc, "wrongpassword"))
|
|
}
|
|
|
|
func TestFastTestHasher(t *testing.T) {
|
|
hasher := FastTestHasher()
|
|
require.NotNil(t, hasher)
|
|
|
|
// Verify it's a PBKDF2 hasher with work factor 1
|
|
pbkdf2Hasher, ok := hasher.(PBKDF2)
|
|
require.True(t, ok, "FastTestHasher should return a PBKDF2 hasher")
|
|
require.Equal(t, 1, pbkdf2Hasher.workFactor)
|
|
|
|
// Test that it produces valid hashes
|
|
hash, err := hasher.Hash("testpassword")
|
|
require.NoError(t, err)
|
|
require.Contains(t, hash, "w=1")
|
|
|
|
// Verify the hash can be validated
|
|
parsedHasher, phc, err := GetHasherFromPHCString(hash)
|
|
require.NoError(t, err)
|
|
require.NoError(t, parsedHasher.CompareHashAndPassword(phc, "testpassword"))
|
|
}
|
|
|
|
func TestGetLatestHasher(t *testing.T) {
|
|
// Ensure testHasher starts as nil
|
|
SetTestHasher(nil)
|
|
|
|
// Without test hasher, should return latestHasher
|
|
require.Equal(t, latestHasher, getLatestHasher())
|
|
|
|
// Set a fast test hasher
|
|
fastHasher := FastTestHasher()
|
|
SetTestHasher(fastHasher)
|
|
defer SetTestHasher(nil)
|
|
|
|
// With test hasher set, should return the test hasher
|
|
require.Equal(t, fastHasher, getLatestHasher())
|
|
require.NotEqual(t, latestHasher, getLatestHasher())
|
|
}
|
|
|
|
func BenchmarkFastTestHasher(b *testing.B) {
|
|
hasher := FastTestHasher()
|
|
for b.Loop() {
|
|
_, _ = hasher.Hash("password")
|
|
}
|
|
}
|