-
Notifications
You must be signed in to change notification settings - Fork 4
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
5 changed files
with
172 additions
and
2 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,20 @@ | ||
import pytest | ||
|
||
import pandas as pd | ||
|
||
from countess.plugins.csv import LoadCsvPlugin | ||
from countess.core.logger import MultiprocessLogger | ||
|
||
logger = MultiprocessLogger() | ||
|
||
def test_load_csv(): | ||
|
||
plugin = LoadCsvPlugin() | ||
|
||
plugin.set_parameter('files.0.filename', 'tests/input1.csv') | ||
|
||
|
||
output_df = next(plugin.load_file(0, logger)) | ||
|
||
assert list(output_df.columns) == ['thing', 'count'] | ||
assert len(output_df) == 4 |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,122 @@ | ||
import pytest | ||
|
||
import pandas as pd | ||
|
||
from countess.plugins.mutagenize import MutagenizePlugin | ||
from countess.core.logger import MultiprocessLogger | ||
|
||
logger = MultiprocessLogger() | ||
|
||
def test_mutagenize_mutate(): | ||
|
||
plugin = MutagenizePlugin() | ||
plugin.set_parameter('sequence', 'GATTACA') | ||
plugin.set_parameter('mutate', True) | ||
|
||
output_df = next(plugin.load_file(0, logger)) | ||
output = list(output_df['sequence']) | ||
|
||
assert len(output) == 21 | ||
|
||
|
||
def test_mutagenize_insert(): | ||
|
||
plugin = MutagenizePlugin() | ||
plugin.set_parameter('sequence', 'GATTACA') | ||
plugin.set_parameter('mutate', False) | ||
plugin.set_parameter('insert', True) | ||
|
||
output_df = next(plugin.load_file(0, logger)) | ||
output = list(output_df['sequence']) | ||
|
||
assert len(output) == 32 | ||
|
||
|
||
def test_mutagenize_insert3(): | ||
|
||
plugin = MutagenizePlugin() | ||
plugin.set_parameter('sequence', 'GATTACA') | ||
plugin.set_parameter('mutate', False) | ||
plugin.set_parameter('ins3', True) | ||
|
||
output_df = next(plugin.load_file(0, logger)) | ||
output = list(output_df['sequence']) | ||
|
||
assert len(output) == 512 | ||
|
||
def test_mutagenize_insert_dedup(): | ||
|
||
plugin = MutagenizePlugin() | ||
plugin.set_parameter('sequence', 'GATTACA') | ||
plugin.set_parameter('mutate', False) | ||
plugin.set_parameter('insert', True) | ||
plugin.set_parameter('remove', True) | ||
|
||
output_df = next(plugin.load_file(0, logger)) | ||
|
||
assert len(output_df) == 25 | ||
|
||
|
||
def test_mutagenize_insert3_dedup(): | ||
|
||
plugin = MutagenizePlugin() | ||
plugin.set_parameter('sequence', 'GATTACA') | ||
plugin.set_parameter('mutate', False) | ||
plugin.set_parameter('ins3', True) | ||
plugin.set_parameter('remove', True) | ||
|
||
output_df = next(plugin.load_file(0, logger)) | ||
|
||
assert len(output_df) == 400 | ||
|
||
def test_mutagenize_delete(): | ||
|
||
plugin = MutagenizePlugin() | ||
plugin.set_parameter('sequence', 'GATTACA') | ||
plugin.set_parameter('mutate', False) | ||
plugin.set_parameter('delete', True) | ||
|
||
output_df = next(plugin.load_file(0, logger)) | ||
output = list(output_df['sequence']) | ||
|
||
assert len(output) == 7 | ||
|
||
|
||
def test_mutagenize_del3(): | ||
|
||
plugin = MutagenizePlugin() | ||
plugin.set_parameter('sequence', 'GATTACA') | ||
plugin.set_parameter('mutate', False) | ||
plugin.set_parameter('del3', True) | ||
|
||
output_df = next(plugin.load_file(0, logger)) | ||
output = list(output_df['sequence']) | ||
|
||
assert len(output) == 5 | ||
|
||
def test_mutagenize_delete_dedup(): | ||
|
||
plugin = MutagenizePlugin() | ||
plugin.set_parameter('sequence', 'GATTACA') | ||
plugin.set_parameter('mutate', False) | ||
plugin.set_parameter('delete', True) | ||
plugin.set_parameter('remove', True) | ||
|
||
output_df = next(plugin.load_file(0, logger)) | ||
|
||
assert len(output_df) == 6 | ||
|
||
|
||
def test_mutagenize_del3_dedup(): | ||
|
||
plugin = MutagenizePlugin() | ||
plugin.set_parameter('sequence', 'GATTACA') | ||
plugin.set_parameter('mutate', False) | ||
plugin.set_parameter('del3', True) | ||
plugin.set_parameter('remove', True) | ||
|
||
output_df = next(plugin.load_file(0, logger)) | ||
|
||
assert len(output_df) == 4 | ||
|
||
|
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,29 @@ | ||
import pytest | ||
|
||
import pandas as pd | ||
|
||
from countess.plugins.variant import VariantPlugin | ||
from countess.core.logger import MultiprocessLogger | ||
|
||
logger = MultiprocessLogger() | ||
|
||
def test_variant_ref_column(): | ||
|
||
input_df = pd.DataFrame([ | ||
{ 'ref': 'TACACACAG', 'seq': 'TACAGACAG' }, | ||
{ 'ref': 'ATGGTTGGTTC', 'seq': "ATGGTTGGTGGTTCG" } | ||
]) | ||
|
||
plugin = VariantPlugin() | ||
plugin.set_parameter('column', 'seq') | ||
plugin.set_parameter('reference', 'ref') | ||
plugin.set_parameter('output', 'out') | ||
|
||
plugin.prepare(['test'], None) | ||
|
||
output_df = plugin.process_dataframe(input_df, logger) | ||
|
||
output = output_df.to_records() | ||
|
||
assert output[0]['out'] == 'g.5C>G' | ||
assert output[1]['out'] == 'g.[7_9dup;11_12insG]' |