summaryrefslogtreecommitdiffstats
path: root/src/test/java/org/openslx/imagemaster/util/Sha512CryptTest.java
diff options
context:
space:
mode:
Diffstat (limited to 'src/test/java/org/openslx/imagemaster/util/Sha512CryptTest.java')
-rw-r--r--src/test/java/org/openslx/imagemaster/util/Sha512CryptTest.java38
1 files changed, 38 insertions, 0 deletions
diff --git a/src/test/java/org/openslx/imagemaster/util/Sha512CryptTest.java b/src/test/java/org/openslx/imagemaster/util/Sha512CryptTest.java
new file mode 100644
index 0000000..af26b4c
--- /dev/null
+++ b/src/test/java/org/openslx/imagemaster/util/Sha512CryptTest.java
@@ -0,0 +1,38 @@
+package org.openslx.imagemaster.util;
+
+import static org.junit.jupiter.api.Assertions.assertEquals;
+import static org.junit.jupiter.api.Assertions.assertTrue;
+
+import java.util.stream.Stream;
+
+import org.junit.jupiter.params.ParameterizedTest;
+import org.junit.jupiter.params.provider.Arguments;
+import org.junit.jupiter.params.provider.MethodSource;
+
+public class Sha512CryptTest
+{
+ @ParameterizedTest
+ @MethodSource( "providePlainAndCryptText" )
+ public void testSha512Crypt( final String plainText, final String cryptText )
+ {
+ final String resultCryptText = Sha512Crypt.Sha512_crypt( plainText, cryptText, 0 );
+
+ assertEquals( cryptText, resultCryptText );
+ assertTrue( Sha512Crypt.verifyPassword( plainText, cryptText ) );
+ }
+
+ private static Stream<Arguments> providePlainAndCryptText()
+ {
+ // @formatter:off
+ return Stream.of(
+ Arguments.of( "Hello world!", "$6$saltstring$svn8UoSVapNtMuq1ukKS4tPQd8iKwSMHWjl/O817G3uBnIFNjnQJuesI68u4OTLiBFdcbYEdFCoEOfaS35inz1" ),
+ Arguments.of( "geheim", "$6$xxxxxxxx$wuSdyeOvQXjj/nNoWnjjo.6OxUWrQFRIj019kh1cDpun6l6cpr3ywSrBprYRYZXcm4Kv9lboCEFI3GzBkdNAz/" ),
+ Arguments.of( "Hello world!", "$6$rounds=10000$saltstringsaltst$OW1/O6BYHV6BcXZu8QVeXbDWra3Oeqh0sbHbbMCVNSnCM/UrjmM0Dp8vOuZeHBy/YTBmSK6H9qs/y3RnOaw5v." ),
+ Arguments.of( "This is just a test", "$6$rounds=5000$toolongsaltstrin$lQ8jolhgVRVhY4b5pZKaysCLi0QBxGoNeKQzQ3glMhwllF7oGDZxUhx1yxdYcz/e1JSbq3y6JMxxl8audkUEm0" ),
+ Arguments.of( "a very much longer text to encrypt. This one even stretches over morethan one line.", "$6$rounds=1400$anotherlongsalts$POfYwTEok97VWcjxIiSOjiykti.o/pQs.wPvMxQ6Fm7I6IoYN3CmLs66x9t0oSwbtEW7o7UmJEiDwGqd8p4ur1" ),
+ Arguments.of( "we have a short salt string but not a short password", "$6$rounds=77777$short$WuQyW2YR.hBNpjjRhpYD/ifIw05xdfeEyQoMxIXbkvr0gge1a1x3yRULJ5CCaUeOxFmtlcGZelFl5CxtgfiAc0" ),
+ Arguments.of( "a short string", "$6$rounds=123456$asaltof16chars..$BtCwjqMJGx5hrJhZywWvt0RLE8uZ4oPwcelCjmw2kSYu.Ec6ycULevoBK25fs2xXgMNrCzIMVcgEJAstJeonj1" ),
+ Arguments.of( "the minimum number is still observed", "$6$rounds=1000$roundstoolow$kUMsbe306n21p9R.FRkW3IGn.S9NPN0x50YhH1xhLsPuWGsUSklZt58jaTfF4ZEQpyUNGc0dqbpBYYBaHHrsX." ) );
+ // @formatter:on
+ }
+}