13eeedb5d1
SHA-1 is weak and we need to transition to a new hash function. For some time, we have referred to this new function as NewHash. Recently, we decided to pick SHA-256 as NewHash. The reasons behind the choice of SHA-256 are outlined in the thread starting at [1] and in the commit history for the hash function transition document. Add a basic implementation of SHA-256 based off libtomcrypt, which is in the public domain. Optimize it and restructure it to meet our coding standards. Pull in the update and final functions from the SHA-1 block implementation, as we know these function correctly with all compilers. This implementation is slower than SHA-1, but more performant implementations will be introduced in future commits. Wire up SHA-256 in the list of hash algorithms, and add a test that the algorithm works correctly. Note that with this patch, it is still not possible to switch to using SHA-256 in Git. Additional patches are needed to prepare the code to handle a larger hash algorithm and further test fixes are needed. [1] https://public-inbox.org/git/20180609224913.GC38834@genre.crustytoothpaste.net/ Signed-off-by: brian m. carlson <sandals@crustytoothpaste.net> Signed-off-by: Junio C Hamano <gitster@pobox.com>
56 lines
2.6 KiB
Bash
Executable File
56 lines
2.6 KiB
Bash
Executable File
#!/bin/sh
|
|
|
|
test_description='test basic hash implementation'
|
|
. ./test-lib.sh
|
|
|
|
|
|
test_expect_success 'test basic SHA-1 hash values' '
|
|
test-tool sha1 </dev/null >actual &&
|
|
grep da39a3ee5e6b4b0d3255bfef95601890afd80709 actual &&
|
|
printf "a" | test-tool sha1 >actual &&
|
|
grep 86f7e437faa5a7fce15d1ddcb9eaeaea377667b8 actual &&
|
|
printf "abc" | test-tool sha1 >actual &&
|
|
grep a9993e364706816aba3e25717850c26c9cd0d89d actual &&
|
|
printf "message digest" | test-tool sha1 >actual &&
|
|
grep c12252ceda8be8994d5fa0290a47231c1d16aae3 actual &&
|
|
printf "abcdefghijklmnopqrstuvwxyz" | test-tool sha1 >actual &&
|
|
grep 32d10c7b8cf96570ca04ce37f2a19d84240d3a89 actual &&
|
|
perl -e "$| = 1; print q{aaaaaaaaaa} for 1..100000;" | \
|
|
test-tool sha1 >actual &&
|
|
grep 34aa973cd4c4daa4f61eeb2bdbad27316534016f actual &&
|
|
printf "blob 0\0" | test-tool sha1 >actual &&
|
|
grep e69de29bb2d1d6434b8b29ae775ad8c2e48c5391 actual &&
|
|
printf "blob 3\0abc" | test-tool sha1 >actual &&
|
|
grep f2ba8f84ab5c1bce84a7b441cb1959cfc7093b7f actual &&
|
|
printf "tree 0\0" | test-tool sha1 >actual &&
|
|
grep 4b825dc642cb6eb9a060e54bf8d69288fbee4904 actual
|
|
'
|
|
|
|
test_expect_success 'test basic SHA-256 hash values' '
|
|
test-tool sha256 </dev/null >actual &&
|
|
grep e3b0c44298fc1c149afbf4c8996fb92427ae41e4649b934ca495991b7852b855 actual &&
|
|
printf "a" | test-tool sha256 >actual &&
|
|
grep ca978112ca1bbdcafac231b39a23dc4da786eff8147c4e72b9807785afee48bb actual &&
|
|
printf "abc" | test-tool sha256 >actual &&
|
|
grep ba7816bf8f01cfea414140de5dae2223b00361a396177a9cb410ff61f20015ad actual &&
|
|
printf "message digest" | test-tool sha256 >actual &&
|
|
grep f7846f55cf23e14eebeab5b4e1550cad5b509e3348fbc4efa3a1413d393cb650 actual &&
|
|
printf "abcdefghijklmnopqrstuvwxyz" | test-tool sha256 >actual &&
|
|
grep 71c480df93d6ae2f1efad1447c66c9525e316218cf51fc8d9ed832f2daf18b73 actual &&
|
|
# Try to exercise the chunking code by turning autoflush on.
|
|
perl -e "$| = 1; print q{aaaaaaaaaa} for 1..100000;" | \
|
|
test-tool sha256 >actual &&
|
|
grep cdc76e5c9914fb9281a1c7e284d73e67f1809a48a497200e046d39ccc7112cd0 actual &&
|
|
perl -e "$| = 1; print q{abcdefghijklmnopqrstuvwxyz} for 1..100000;" | \
|
|
test-tool sha256 >actual &&
|
|
grep e406ba321ca712ad35a698bf0af8d61fc4dc40eca6bdcea4697962724ccbde35 actual &&
|
|
printf "blob 0\0" | test-tool sha256 >actual &&
|
|
grep 473a0f4c3be8a93681a267e3b1e9a7dcda1185436fe141f7749120a303721813 actual &&
|
|
printf "blob 3\0abc" | test-tool sha256 >actual &&
|
|
grep c1cf6e465077930e88dc5136641d402f72a229ddd996f627d60e9639eaba35a6 actual &&
|
|
printf "tree 0\0" | test-tool sha256 >actual &&
|
|
grep 6ef19b41225c5369f1c104d45d8d85efa9b057b53b14b4b9b939dd74decc5321 actual
|
|
'
|
|
|
|
test_done
|