* Compares the contents of the fasta and view at a specified location.
*
* @param loc
*/
protected void validateLocation( GenomeLoc loc ) {
Shard shard = new MockLocusShard(genomeLocParser,Collections.singletonList(loc));
GenomeLocusIterator shardIterator = new GenomeLocusIterator(genomeLocParser,loc);
LocusShardDataProvider dataProvider = new LocusShardDataProvider(shard, null, genomeLocParser, loc, null, sequenceFile, null);
LocusReferenceView view = new LocusReferenceView(dataProvider);
while (shardIterator.hasNext()) {
GenomeLoc locus = shardIterator.next();
ReferenceSequence expectedAsSeq = sequenceFile.getSubsequenceAt(locus.getContig(), locus.getStart(), locus.getStop());
char expected = Character.toUpperCase(StringUtil.bytesToString(expectedAsSeq.getBases()).charAt(0));
char actual = view.getReferenceContext(locus).getBaseAsChar();
Assert.assertEquals(actual, expected, String.format("Value of base at position %s in shard %s does not match expected", locus.toString(), shard.getGenomeLocs())
);
}
}