/* * BioJava development code * * This code may be freely distributed and modified under the * terms of the GNU Lesser General Public Licence. This should * be distributed with the code. If you do not have a copy, * see: * * http://www.gnu.org/copyleft/lesser.html * * Copyright for this code is held jointly by the individual * authors. These should be listed in @author doc comments. * * For more information on the BioJava project and its aims, * or to join the biojava-l mailing list, visit the home page * at: * * http://www.biojava.org/ * */ package org.biojava.nbio.sequencing.io.fastq; import java.io.IOException; import java.io.InputStream; import java.net.URL; /** * Unit test for SangerFastqReader. */ public final class SangerFastqReaderTest extends AbstractFastqReaderTest { @Override public Fastq createFastq() { return new FastqBuilder() .withDescription("description") .withSequence("sequence") .withQuality("quality_") .withVariant(FastqVariant.FASTQ_SANGER) .build(); } @Override public FastqReader createFastqReader() { return new SangerFastqReader(); } @Override public FastqWriter createFastqWriter() { return new SangerFastqWriter(); } public void testValidateDescription() throws Exception { SangerFastqReader reader = new SangerFastqReader(); URL invalidDescription = getClass().getResource("sanger-invalid-description.fastq"); try { reader.read(invalidDescription); fail("read(invalidDescription) expected IOException"); } catch (IOException e) { assertTrue(e.getMessage().contains("description must begin with a '@' character")); } } public void testValidateRepeatDescription() throws Exception { SangerFastqReader reader = new SangerFastqReader(); URL invalidRepeatDescription = getClass().getResource("sanger-invalid-repeat-description.fastq"); try { reader.read(invalidRepeatDescription); fail("read(invalidRepeatDescription) expected IOException"); } catch (IOException e) { assertTrue(e.getMessage().contains("repeat description must match description")); } } public void testWrappingOriginal() throws Exception { FastqReader reader = createFastqReader(); InputStream inputStream = getClass().getResourceAsStream("wrapping_original_sanger.fastq"); Iterable<Fastq> iterable = reader.read(inputStream); assertNotNull(iterable); int count = 0; for (Fastq f : iterable) { assertNotNull(f); count++; } assertEquals(3, count); inputStream.close(); } public void testWrappingAsSanger() throws Exception { FastqReader reader = createFastqReader(); InputStream inputStream = getClass().getResourceAsStream("wrapping_as_sanger.fastq"); Iterable<Fastq> iterable = reader.read(inputStream); assertNotNull(iterable); int count = 0; for (Fastq f : iterable) { assertNotNull(f); count++; } assertEquals(3, count); inputStream.close(); } public void testFullRangeOriginal() throws Exception { FastqReader reader = createFastqReader(); InputStream inputStream = getClass().getResourceAsStream("sanger_full_range_original_sanger.fastq"); Iterable<Fastq> iterable = reader.read(inputStream); assertNotNull(iterable); int count = 0; for (Fastq f : iterable) { assertNotNull(f); count++; } assertEquals(2, count); inputStream.close(); } public void testFullRangeAsSanger() throws Exception { FastqReader reader = createFastqReader(); InputStream inputStream = getClass().getResourceAsStream("sanger_full_range_as_sanger.fastq"); Iterable<Fastq> iterable = reader.read(inputStream); assertNotNull(iterable); int count = 0; for (Fastq f : iterable) { assertNotNull(f); count++; } assertEquals(2, count); inputStream.close(); } public void testMiscDnaOriginal() throws Exception { FastqReader reader = createFastqReader(); InputStream inputStream = getClass().getResourceAsStream("misc_dna_original_sanger.fastq"); Iterable<Fastq> iterable = reader.read(inputStream); assertNotNull(iterable); int count = 0; for (Fastq f : iterable) { assertNotNull(f); count++; } assertEquals(4, count); inputStream.close(); } public void testMiscDnaAsSanger() throws Exception { FastqReader reader = createFastqReader(); InputStream inputStream = getClass().getResourceAsStream("misc_dna_as_sanger.fastq"); Iterable<Fastq> iterable = reader.read(inputStream); assertNotNull(iterable); int count = 0; for (Fastq f : iterable) { assertNotNull(f); count++; } assertEquals(4, count); inputStream.close(); } public void testMiscRnaOriginal() throws Exception { FastqReader reader = createFastqReader(); InputStream inputStream = getClass().getResourceAsStream("misc_rna_original_sanger.fastq"); Iterable<Fastq> iterable = reader.read(inputStream); assertNotNull(iterable); int count = 0; for (Fastq f : iterable) { assertNotNull(f); count++; } assertEquals(4, count); inputStream.close(); } public void testMiscRnaAsSanger() throws Exception { FastqReader reader = createFastqReader(); InputStream inputStream = getClass().getResourceAsStream("misc_rna_as_sanger.fastq"); Iterable<Fastq> iterable = reader.read(inputStream); assertNotNull(iterable); int count = 0; for (Fastq f : iterable) { assertNotNull(f); count++; } assertEquals(4, count); inputStream.close(); } public void testLongReadsOriginal() throws Exception { FastqReader reader = createFastqReader(); InputStream inputStream = getClass().getResourceAsStream("longreads_original_sanger.fastq"); Iterable<Fastq> iterable = reader.read(inputStream); assertNotNull(iterable); int count = 0; for (Fastq f : iterable) { assertNotNull(f); count++; } assertEquals(10, count); inputStream.close(); } public void testLongReadsAsSanger() throws Exception { FastqReader reader = createFastqReader(); InputStream inputStream = getClass().getResourceAsStream("longreads_as_sanger.fastq"); Iterable<Fastq> iterable = reader.read(inputStream); assertNotNull(iterable); int count = 0; for (Fastq f : iterable) { assertNotNull(f); count++; } assertEquals(10, count); inputStream.close(); } }