--- a
+++ b/test/run_test.sh
@@ -0,0 +1,110 @@
+#!/bin/bash
+set -e
+
+test_dir="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null && pwd )"
+neusomatic_dir="$( dirname ${test_dir} )"
+
+cd ${test_dir}
+mkdir -p example
+cd example
+if [ ! -f Homo_sapiens.GRCh37.75.dna.chromosome.22.fa ]
+then
+	if [ ! -f Homo_sapiens.GRCh37.75.dna.chromosome.22.fa.gz ]
+	then
+		wget ftp://ftp.ensembl.org/pub/release-75//fasta/homo_sapiens/dna/Homo_sapiens.GRCh37.75.dna.chromosome.22.fa.gz
+	fi
+	gunzip -f Homo_sapiens.GRCh37.75.dna.chromosome.22.fa.gz
+fi
+if [ ! -f Homo_sapiens.GRCh37.75.dna.chromosome.22.fa.fai ]
+then
+	samtools faidx Homo_sapiens.GRCh37.75.dna.chromosome.22.fa
+fi
+rm -rf work_standalone
+#Stand-alone NeuSomatic test 
+python ${neusomatic_dir}/neusomatic/python/preprocess.py \
+	--mode call \
+	--reference Homo_sapiens.GRCh37.75.dna.chromosome.22.fa \
+	--region_bed ${test_dir}/region.bed \
+	--tumor_bam ${test_dir}/tumor.bam \
+	--normal_bam ${test_dir}/normal.bam \
+	--work work_standalone \
+	--scan_maf 0.05 \
+	--min_mapq 10 \
+	--snp_min_af 0.05 \
+	--snp_min_bq 20 \
+	--snp_min_ao 10 \
+	--ins_min_af 0.05 \
+	--del_min_af 0.05 \
+	--num_threads 1 \
+	--scan_alignments_binary ${neusomatic_dir}/neusomatic/bin/scan_alignments
+
+CUDA_VISIBLE_DEVICES= python ${neusomatic_dir}/neusomatic/python/call.py \
+		--candidates_tsv work_standalone/dataset/*/candidates*.tsv \
+		--reference Homo_sapiens.GRCh37.75.dna.chromosome.22.fa \
+		--out work_standalone \
+		--checkpoint ${neusomatic_dir}/neusomatic/models/NeuSomatic_v0.1.0_standalone_Dream3_70purity.pth \
+		--num_threads 1 \
+		--batch_size 100
+
+python ${neusomatic_dir}/neusomatic/python/postprocess.py \
+		--reference Homo_sapiens.GRCh37.75.dna.chromosome.22.fa \
+		--tumor_bam ${test_dir}/tumor.bam \
+		--pred_vcf work_standalone/pred.vcf \
+		--candidates_vcf work_standalone/work_tumor/filtered_candidates.vcf \
+		--output_vcf work_standalone/NeuSomatic_standalone.vcf \
+		--work work_standalone 
+
+
+rm -rf work_ensemble
+#Ensemble NeuSomatic test 
+python ${neusomatic_dir}/neusomatic/python/preprocess.py \
+	--mode call \
+	--reference Homo_sapiens.GRCh37.75.dna.chromosome.22.fa \
+	--region_bed ${test_dir}/region.bed \
+	--tumor_bam ${test_dir}/tumor.bam \
+	--normal_bam ${test_dir}/normal.bam \
+	--work work_ensemble \
+	--scan_maf 0.05 \
+	--min_mapq 10 \
+	--snp_min_af 0.05 \
+	--snp_min_bq 20 \
+	--snp_min_ao 10 \
+	--ins_min_af 0.05 \
+	--del_min_af 0.05 \
+	--num_threads 1 \
+	--ensemble_tsv ${test_dir}/ensemble.tsv \
+	--scan_alignments_binary ${neusomatic_dir}/neusomatic/bin/scan_alignments
+
+CUDA_VISIBLE_DEVICES= python ${neusomatic_dir}/neusomatic/python/call.py \
+		--candidates_tsv work_ensemble/dataset/*/candidates*.tsv \
+		--reference Homo_sapiens.GRCh37.75.dna.chromosome.22.fa \
+		--out work_ensemble \
+		--checkpoint ${neusomatic_dir}/neusomatic/models/NeuSomatic_v0.1.0_ensemble_Dream3_70purity.pth \
+		--num_threads 1 \
+		--ensemble \
+		--batch_size 100
+
+python ${neusomatic_dir}/neusomatic/python/postprocess.py \
+		--reference Homo_sapiens.GRCh37.75.dna.chromosome.22.fa \
+		--tumor_bam ${test_dir}/tumor.bam \
+		--pred_vcf work_ensemble/pred.vcf \
+		--candidates_vcf work_ensemble/work_tumor/filtered_candidates.vcf \
+		--ensemble_tsv ${test_dir}/ensemble.tsv \
+		--output_vcf work_ensemble/NeuSomatic_ensemble.vcf \
+		--work work_ensemble 
+
+
+cd ..
+
+file1=${test_dir}/example/work_standalone/NeuSomatic_standalone.vcf
+file2=${test_dir}/NeuSomatic_standalone.vcf
+
+cmp --silent $file1 $file2 && echo "### NeuSomatic stand-alone: SUCCESS! ###" \
+|| echo "### NeuSomatic stand-alone FAILED: Files ${file1} and ${file2} Are Different! ###"
+
+
+file1=${test_dir}/example/work_ensemble/NeuSomatic_ensemble.vcf
+file2=${test_dir}/NeuSomatic_ensemble.vcf
+
+cmp --silent $file1 $file2 && echo "### NeuSomatic ensemble: SUCCESS! ###" \
+|| echo "### NeuSomatic ensemble FAILED: Files ${file1} and ${file2} Are Different! ###"