summaryrefslogtreecommitdiffstats
path: root/src/test/java
diff options
context:
space:
mode:
authorMartin Spielmann <martin.spielmann@pingunaut.com>2017-01-01 20:22:06 +0100
committerMartin Spielmann <martin.spielmann@pingunaut.com>2017-01-01 21:41:11 +0100
commit15782f62ba134006a2f92f65d10f0713e8ad85a0 (patch)
tree67812daad922bce54dc8b8c7f43c1204991d24d2 /src/test/java
parent99b4a1898f0c3533062263cda18b456f099ee2cf (diff)
downloadgitblit-15782f62ba134006a2f92f65d10f0713e8ad85a0.tar.gz
gitblit-15782f62ba134006a2f92f65d10f0713e8ad85a0.zip
Added possibility to use secure hashes to store passwords
Addresses #1166
Diffstat (limited to 'src/test/java')
-rw-r--r--src/test/java/com/gitblit/utils/SecurePasswordHashUtilsTest.java63
1 files changed, 63 insertions, 0 deletions
diff --git a/src/test/java/com/gitblit/utils/SecurePasswordHashUtilsTest.java b/src/test/java/com/gitblit/utils/SecurePasswordHashUtilsTest.java
new file mode 100644
index 00000000..f687bda6
--- /dev/null
+++ b/src/test/java/com/gitblit/utils/SecurePasswordHashUtilsTest.java
@@ -0,0 +1,63 @@
+package com.gitblit.utils;
+
+import static org.junit.Assert.*;
+
+import org.junit.Before;
+import org.junit.Test;
+
+public class SecurePasswordHashUtilsTest {
+
+ private static final String STORED_PASSWORD = "PBKDF2WITHHMACSHA256:2d7d3ccaa277787f288e9f929247361bfc83607c6a8447bf496267512e360ba0a97b3114937213b23230072517d65a2e00695a1cbc47a732510840817f22c1bc";
+ private static final byte[] STORED_SALT_BYTES = new byte[]{45, 125, 60, -54, -94, 119, 120, 127, 40, -114, -97, -110, -110, 71, 54, 27, -4, -125, 96, 124, 106, -124, 71, -65, 73, 98, 103, 81, 46, 54, 11, -96};
+ private static final byte[] STORED_HASH_BYTES = new byte[]{-87, 123, 49, 20, -109, 114, 19, -78, 50, 48, 7, 37, 23, -42, 90, 46, 0, 105, 90, 28, -68, 71, -89, 50, 81, 8, 64, -127, 127, 34, -63, -68};
+
+ private SecurePasswordHashUtils utils;
+
+ @Before
+ public void init(){
+ utils = SecurePasswordHashUtils.get();
+ }
+
+ @Test
+ public void testGetNextSalt() {
+ assertEquals(32, utils.getNextSalt().length);
+ }
+
+ @Test
+ public void testHash() {
+ byte[] hash = utils.hash("foo".toCharArray(), STORED_SALT_BYTES);
+ assertArrayEquals(STORED_HASH_BYTES, hash);
+ }
+
+ @Test
+ public void testIsPasswordCorrectCharArrayByteArrayByteArray() {
+ assertTrue(utils.isPasswordCorrect("foo".toCharArray(), STORED_SALT_BYTES, STORED_HASH_BYTES));
+ assertFalse(utils.isPasswordCorrect("bar".toCharArray(), STORED_SALT_BYTES, STORED_HASH_BYTES));
+ }
+
+ @Test
+ public void testCreateNewStorableHashFromPassword() {
+ String newPwHash = utils.createStoredPasswordFromPassword("foo");
+ assertTrue(newPwHash.startsWith(SecurePasswordHashUtils.PBKDF2WITHHMACSHA256_TYPE));
+ }
+
+ @Test
+ public void testGetSaltFromStoredPassword() {
+ byte[] saltFromStoredPassword = utils.getSaltFromStoredPassword(STORED_PASSWORD);
+ assertArrayEquals(STORED_SALT_BYTES, saltFromStoredPassword);
+
+ }
+
+ @Test
+ public void testGetHashFromStoredPassword() {
+ byte[] hashFromStoredPassword = utils.getHashFromStoredPassword(STORED_PASSWORD);
+ assertArrayEquals(STORED_HASH_BYTES, hashFromStoredPassword);
+ }
+
+ @Test
+ public void testIsPasswordCorrectCharArrayString() {
+ assertTrue(utils.isPasswordCorrect("foo".toCharArray(), STORED_PASSWORD));
+ assertFalse(utils.isPasswordCorrect("bar".toCharArray(), STORED_PASSWORD));
+ }
+
+}