mirror of
https://github.com/MillironX/nf-core_modules.git
synced 2025-01-18 02:46:13 -05:00
Merge pull request #47 from stevekm/fastqc-unit-test
move md5 function to lib dir and symlink to fastqc test dir, rename m…
This commit is contained in:
commit
6dfb9f02c9
3 changed files with 39 additions and 38 deletions
34
lib/checksum.groovy
Normal file
34
lib/checksum.groovy
Normal file
|
@ -0,0 +1,34 @@
|
||||||
|
import java.security.MessageDigest
|
||||||
|
private static String getMD5(File file) throws IOException
|
||||||
|
{
|
||||||
|
// https://howtodoinjava.com/java/io/how-to-generate-sha-or-md5-file-checksum-hash-in-java/
|
||||||
|
//Get file input stream for reading the file content
|
||||||
|
FileInputStream fis = new FileInputStream(file);
|
||||||
|
|
||||||
|
//Create byte array to read data in chunks
|
||||||
|
byte[] byteArray = new byte[1024];
|
||||||
|
int bytesCount = 0;
|
||||||
|
|
||||||
|
//Read file data and update in message digest
|
||||||
|
def digest = MessageDigest.getInstance("MD5")
|
||||||
|
while ((bytesCount = fis.read(byteArray)) != -1) {
|
||||||
|
digest.update(byteArray, 0, bytesCount);
|
||||||
|
};
|
||||||
|
|
||||||
|
//close the stream; We don't need it now.
|
||||||
|
fis.close();
|
||||||
|
|
||||||
|
//Get the hash's bytes
|
||||||
|
byte[] bytes = digest.digest();
|
||||||
|
|
||||||
|
//This bytes[] has bytes in decimal format;
|
||||||
|
//Convert it to hexadecimal format
|
||||||
|
StringBuilder sb = new StringBuilder();
|
||||||
|
for(int i=0; i< bytes.length ;i++)
|
||||||
|
{
|
||||||
|
sb.append(Integer.toString((bytes[i] & 0xff) + 0x100, 16).substring(1));
|
||||||
|
}
|
||||||
|
|
||||||
|
//return complete hash
|
||||||
|
return sb.toString();
|
||||||
|
}
|
1
software/fastqc/test/lib
Symbolic link
1
software/fastqc/test/lib
Symbolic link
|
@ -0,0 +1 @@
|
||||||
|
../../../lib
|
|
@ -1,5 +1,5 @@
|
||||||
#!/usr/bin/env nextflow
|
#!/usr/bin/env nextflow
|
||||||
import java.security.MessageDigest
|
import checksum
|
||||||
nextflow.preview.dsl = 2
|
nextflow.preview.dsl = 2
|
||||||
|
|
||||||
params.out_dir = "test_output"
|
params.out_dir = "test_output"
|
||||||
|
@ -8,40 +8,6 @@ params.publish_dir_mode = "copy"
|
||||||
|
|
||||||
include { FASTQC } from '../main.nf'
|
include { FASTQC } from '../main.nf'
|
||||||
|
|
||||||
|
|
||||||
private static String getFileChecksum(MessageDigest digest, File file) throws IOException
|
|
||||||
{
|
|
||||||
// https://howtodoinjava.com/java/io/how-to-generate-sha-or-md5-file-checksum-hash-in-java/
|
|
||||||
//Get file input stream for reading the file content
|
|
||||||
FileInputStream fis = new FileInputStream(file);
|
|
||||||
|
|
||||||
//Create byte array to read data in chunks
|
|
||||||
byte[] byteArray = new byte[1024];
|
|
||||||
int bytesCount = 0;
|
|
||||||
|
|
||||||
//Read file data and update in message digest
|
|
||||||
while ((bytesCount = fis.read(byteArray)) != -1) {
|
|
||||||
digest.update(byteArray, 0, bytesCount);
|
|
||||||
};
|
|
||||||
|
|
||||||
//close the stream; We don't need it now.
|
|
||||||
fis.close();
|
|
||||||
|
|
||||||
//Get the hash's bytes
|
|
||||||
byte[] bytes = digest.digest();
|
|
||||||
|
|
||||||
//This bytes[] has bytes in decimal format;
|
|
||||||
//Convert it to hexadecimal format
|
|
||||||
StringBuilder sb = new StringBuilder();
|
|
||||||
for(int i=0; i< bytes.length ;i++)
|
|
||||||
{
|
|
||||||
sb.append(Integer.toString((bytes[i] & 0xff) + 0x100, 16).substring(1));
|
|
||||||
}
|
|
||||||
|
|
||||||
//return complete hash
|
|
||||||
return sb.toString();
|
|
||||||
}
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Test if FASTQC runs with single-end data
|
* Test if FASTQC runs with single-end data
|
||||||
*/
|
*/
|
||||||
|
@ -52,7 +18,7 @@ workflow test_single_end {
|
||||||
|
|
||||||
// test that the output looks as expected
|
// test that the output looks as expected
|
||||||
FASTQC.out.html.map { name, is_single_end, html_file ->
|
FASTQC.out.html.map { name, is_single_end, html_file ->
|
||||||
html_hash = getFileChecksum(MessageDigest.getInstance("MD5"), new File("${html_file}"));
|
html_hash = checksum.getMD5(new File("${html_file}"));
|
||||||
|
|
||||||
assert name == "test_single_end"
|
assert name == "test_single_end"
|
||||||
assert is_single_end == true
|
assert is_single_end == true
|
||||||
|
@ -82,8 +48,8 @@ workflow test_paired_end {
|
||||||
html_r1 = html_files[0]
|
html_r1 = html_files[0]
|
||||||
html_r2 = html_files[1]
|
html_r2 = html_files[1]
|
||||||
|
|
||||||
html_r1_hash = getFileChecksum(MessageDigest.getInstance("MD5"), new File("${html_r1}"));
|
html_r1_hash = checksum.getMD5(new File("${html_r1}"));
|
||||||
html_r2_hash = getFileChecksum(MessageDigest.getInstance("MD5"), new File("${html_r2}"));
|
html_r2_hash = checksum.getMD5(new File("${html_r2}"));
|
||||||
|
|
||||||
assert name == "test_R"
|
assert name == "test_R"
|
||||||
assert is_single_end == false
|
assert is_single_end == false
|
||||||
|
|
Loading…
Add table
Reference in a new issue