File: developer.rst

package info (click to toggle)
python-pysam 0.7.7-1~bpo70%2B1
  • links: PTS, VCS
  • area: main
  • in suites: wheezy-backports
  • size: 11,096 kB
  • sloc: ansic: 25,638; python: 3,882; makefile: 157; sh: 12
file content (75 lines) | stat: -rw-r--r-- 1,806 bytes parent folder | download | duplicates (2)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
*****************
Developer's guide
*****************

Code organization
*****************

The top level directory is organized in the following 
directories:

pysam
   Code specific to pysam

samtools
   Original and unmodified source code from :term:`csamtools`. Use 
   :file:`setup.py` to obtain the latest code.

tests
   Examples and data for testing

Importing :term:`csamtools`
***************************

Running :file:`setup.py` will import the csamtools source code. 
The command::

   python setup.py import PATH

where ``PATH`` points to a :term:`csamtools` source directory. For example::

   python setup.py import ~/samtools-0.1.6

Note that files will not be overwritten. To import all anew, 
delete all :file:`*.c` and :file:`*.h` files in the :file:`samtools`
directory first. 

Unit testing
************

Unit tests are currently in the script :file:`pysam_test.py`. 

Unit tests for the python methods
---------------------------------

Few implemented yet. This will require also writing functionality,
hence postponed

Unit tests for the command line interface
-----------------------------------------

The current suite of tests compare the binary files of selected
samtools commands against running the same commands from within
the pysam module. The general expectation is that the files
are binary identical given that most of the code is
from :term:`csamtools` anyway. However, differences might be
found if the installed :term:`csamtools` version is different
from the one wrapped with pysam.

The tests create files in the current test directory. They
are modeled on the example given within the :term:`csamtools`
distribution. Two files are required in the working directory
of the test script:

1. :file:`ex1.fa`: a fasta file
2. :file:`ex1.sam.gz`: a sam file