[go: up one dir, main page]

sha2 0.3.0

SHA-2 hash functions
Documentation
#![no_std]
#[macro_use]
extern crate crypto_tests;
extern crate sha2;

use crypto_tests::hash::{Test, main_test, one_million_a};

#[test]
fn sha2_224_main() {
    let tests = new_tests!("sha224/test1", "sha224/test2", "sha224/test3");
    main_test::<sha2::Sha224>(&tests);
}

#[test]
fn sha2_256_main() {
    let tests = new_tests!("sha256/test1", "sha256/test2", "sha256/test3");
    main_test::<sha2::Sha256>(&tests);
}

#[test]
fn sha2_384_main() {
    let tests = new_tests!("sha384/test1", "sha384/test2", "sha384/test3");
    main_test::<sha2::Sha384>(&tests);
}

#[test]
fn sha2_512_main() {
    let tests = new_tests!("sha512/test1", "sha512/test2", "sha512/test3");
    main_test::<sha2::Sha512>(&tests);
}

#[test]
fn sha2_512_trunc_256_main() {
    let tests = new_tests!("sha512_256/test1", "sha512_256/test2", "sha512_256/test3");
    main_test::<sha2::Sha512Trunc256>(&tests);
}

#[test]
fn sha2_512_trunc_224_main() {
    let tests = new_tests!("sha512_224/test1", "sha512_224/test2", "sha512_224/test3");
    main_test::<sha2::Sha512Trunc224>(&tests);
}

#[test]
fn sha2_256_1million_a() {
    let output = include_bytes!("data/sha256/one_million_a.output.bin");
    one_million_a::<sha2::Sha256>(output);
}

#[test]
fn sha2_512_1million_a() {
    let output = include_bytes!("data/sha512/one_million_a.output.bin");
    one_million_a::<sha2::Sha512>(output);
}