tests/testthat/test_adjust_seq.r

test_that("Input arguments are handled correctly.", {
  
  ##################################
  # test 1
  # make sure triple 0s are skipped
  t1_seq = strsplit("ATGATGATG", "")[[1]]
  t1_path =strsplit("111000112111", "")[[1]]
  t1_expected_seq = "ATGATATG"
  
  t1_frame_dat = list(framed_seq = "ATGATGATG",
                      framed_vec = t1_seq,
                      trimmed_seq = t1_seq,
                      removed_lead = NULL,
                      removed_end = NULL,
                      seq_start = 1,
                      seq_end = length(t1_seq),
                      path_start = 1 ,
                      path_end = length(t1_path),
                      front = NULL)
  
  t1_adj_out = adj_seq(t1_frame_dat, t1_path, censor_length = 0)
  t1_adj_seq = paste(t1_adj_out[[1]], collapse = "")
  #t1_adj_seq == t1_expected_seq
  expect_equal(t1_adj_seq ,  t1_expected_seq)
  
  #test where the censor extends past the end of the sequence
  t1_expected_seq2 = "A-------"
  
  t1_adj_out = adj_seq(t1_frame_dat, t1_path, censor_length = 4)
  t1_adj_seq = paste(t1_adj_out[[1]], collapse = "")
  #t1_adj_seq == t1_expected_seq2
  expect_equal(t1_adj_seq ,  t1_expected_seq2)
  
  
  
  ##################################
  #test 2
  #make sure inserts are handled in the correct locaiton
  t2_seq = strsplit("AAAATGATGATG", "")[[1]]
  t2_path =strsplit("111101111110", "")[[1]]
  t2_expected_seq = "AAAAT-GATGATG-"
  
  t2_frame_dat = list(framed_seq = "AAAATGATGATG",
                      framed_vec = t2_seq,
                      trimmed_seq = t2_seq,
                      removed_lead = NULL,
                      removed_end = NULL,
                      seq_start = 1,
                      seq_end = length(t2_seq),
                      path_start = 1 ,
                      path_end = length(t2_path),
                      front = NULL)
  
  t2_adj_out = adj_seq(t2_frame_dat, t2_path, censor_length = 0)
  t2_adj_seq = paste(t2_adj_out[[1]], collapse = "")
  #t2_adj_seq == t2_expected_seq
  expect_equal(t2_adj_seq ,  t2_expected_seq)
  
  t2_expected_seq2 = "AAA-----TGA---"
  # org:                   ^       ^
  #flanks:               ^^ ^^   ^^
  t2_adj_out = adj_seq(t2_frame_dat, t2_path, censor_length = 2)
  t2_adj_seq = paste(t2_adj_out[[1]], collapse = "")
  #t2_adj_seq == t2_expected_seq2
  expect_equal(t2_adj_seq ,  t2_expected_seq2)
  
  
  ##################################
  #test 3
  # make sure deletes are handled in the correct location
  t3_seq = strsplit("ATGATGATG", "")[[1]]
  t3_path =strsplit("111211111", "")[[1]]
  t3_expected_seq = "ATGTGATG"
  
  t3_frame_dat = list(framed_seq = "ATGATGATG",
                      framed_vec = t3_seq,
                      trimmed_seq = t3_seq,
                      removed_lead = NULL,
                      removed_end = NULL,
                      seq_start = 1,
                      seq_end = length(t3_seq),
                      path_start = 1 ,
                      path_end = length(t3_path),
                      front = NULL)
  
  t3_adj_out = adj_seq(t3_frame_dat, t3_path, censor_length = 0)
  t3_adj_seq = paste(t3_adj_out[[1]], collapse = "")
  #t3_adj_seq == t3_expected_seq
  expect_equal(t3_adj_seq ,  t3_expected_seq)
  
  t3_expected_seq2 = "AT--GATG"
  
  t3_adj_out = adj_seq(t3_frame_dat, t3_path, censor_length = 1)
  t3_adj_seq = paste(t3_adj_out[[1]], collapse = "")
  #t3_adj_seq == t3_expected_seq2
  expect_equal(t3_adj_seq ,  t3_expected_seq2)
    
  #bp number 20 is a missing but the 0 is at position 19 - this may be a bug in the original aphid program
  #but its predictable so I'll build around it... for now
  #maybe email Dr. wilkinson and let him know, then you can adjust the adj_seq algorithm to not to add a match as part of the first placeholder add
           "ctctacttgatttttggtgcatgagcaggaatagttggaatagctttaagtttactaattcgcgctgaactaggtcaacccggatctcttttaggggatgatcagatttataatgtgatcgtaaccgcccatgcctttgtaataatcttttttatggttatacctgtaataattggtggctttggcaattgacttgttcctttaataattggtgcaccagatatagcattccctcgaataaataatataagtttctggcttcttcctccttcgttcttacttctcctggcctccgcaggagtagaagctggagcaggaaccggatgaactgtatatcctcctttagcaggtaatttagcacatgctggcccctctgttgatttagccatcttttcccttcatttggccggtatctcatcaattttagcctctattaattttattacaactattattaatataaaacccccaactatttctcaatatcaaacaccattatttgtttgatctattcttatcaccactgttcttctactccttgctctccctgttcttgcagccggaattacaatattattaacagaccgcaacctcaacactacattctttgaccccgcagggggaggggacccaattctctatcaacactta"
  t4_seq = "ctctacttgatttttggtgatgagcaggaatagttggaatagctttaagtttactaattcgcgctgaactaggtcaacccggatctcttttaggggatgatcagatttataatgtgatcgtaaccgcccatgcctttgtaataatcttttttatggttatacctgtaataattggtggctttggcaattgacttgttcctttaataattggtgcaccagatatagcattccctcgaataaataatataagtttctggcttcttcctccttcgttcttacttctcctggcctccgcaggagtagaagctggagcaggaaccggatgaactgtatatcctcctttagcaggtaatttagcacatgctggcccctctgttgatttagccatcttttcccttcatttggccggtatctcatcaattttagcctctattaattttattacaactattattaatataaaacccccaactatttctcaatatcaaacaccattatttgtttgatctattcttatcaccactgttcttctactccttgctctccctgttcttgcagccggaattacaatattattaacagaccgcaacctcaacactacattctttgaccccgcagggggaggggacccaattctctatcaacactta"
        "000111111111111111111011111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111110001111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111111"
  t4_ri="---ctctacttgatttttgg-----gagcaggaatagttggaatagctttaagtttactaattcgcgctgaactaggtcaacccggatctcttttaggggatgatcagatttataatgtgatcgtaaccgcccatgcctttgtaataatcttttttatggttatacctgtaataattggtggctttggcaattgacttgttcctttaataattggtgcaccagatatagcattccctcgaataaataatataagtttctggcttcttcctccttcgttcttacttctcctggcctccgcaggagtagaagctggagcaggaaccggatgaactgtatatcctcctttagcaggtaatttagcacatgctggcccctctgttgatttagccatcttttcccttcatttggccggtatctcatcaattttagcctctattaattttattacaactattattaatataaaacccccaactatttctcaatatcaaacaccattatttgtttgatctattcttatcaccactgttcttctactccttgctctccctgttcttgcagccggaattacaatattattaacagaccgcaacctcaacactacattctttgaccccgcagggggaggggacccaattctctatcaacactta"
        "---ctctacttgatttttgg-----gagcaggaatagttggaatagctttaagtttactaattcgcgctgaactaggtcaacccggatctcttttaggggatgatcagatttataatgtgatcgtaaccgcccatgcctttgtaataatcttttttatggttatacctgtaataattggtggctttggcaattgacttgttcctttaataattggtgcaccagatatagcattccctcgaataaataatataagtttctggcttcttcctccttcgttcttacttctcctggcctccgcaggagtagaagctggagcaggaaccggatgaactgtatatcctcctttagcaggtaatttagcacatgctggcccctctgttgatttagccatcttttcccttcatttggccggtatctcatcaattttagcctctattaattttattacaactattattaatataaaacccccaactatttctcaatatcaaacaccattatttgtttgatctattcttatcaccactgttcttctactccttgctctccctgttcttgcagccggaattacaatattattaacagaccgcaacctcaacactacattctttgaccccgcagggggaggggacccaattctctatcaacactta"
  t4_ex = DNAseq(t4_seq, name= 'test4')
  t4_ex = frame(t4_ex)
  t4_ex = adjust(t4_ex , censor_length = 2)
  t4_out = paste(t4_ex$adjusted_sequence, collapse = "")
  #t4_ri == t4_out
  expect_equal(t4_ri, t4_out)
  
  }) 

Try the debar package in your browser

Any scripts or data that you put into this service are public.

debar documentation built on May 29, 2024, 2:02 a.m.