File: TestMMcifOrganismParsing.java

package info (click to toggle)
biojava6-live 6.1.0%2Bdfsg-4
  • links: PTS, VCS
  • area: main
  • in suites: bookworm
  • size: 109,220 kB
  • sloc: java: 245,626; xml: 27,410; python: 64; makefile: 39; sh: 31
file content (115 lines) | stat: -rw-r--r-- 2,796 bytes parent folder | download | duplicates (3)
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
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
/*
 *                    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/
 *
 * created at Aug 12, 2013
 * Author: ap3
 */

package org.biojava.nbio.structure.io;


import org.biojava.nbio.structure.EntityInfo;
import org.biojava.nbio.structure.EntityType;
import org.biojava.nbio.structure.Structure;
import org.biojava.nbio.structure.StructureException;
import org.biojava.nbio.structure.StructureIO;
import org.biojava.nbio.structure.align.util.AtomCache;
import org.junit.BeforeClass;
import org.junit.Ignore;
import org.junit.Test;

import java.io.IOException;

import static org.junit.Assert.assertEquals;
import static org.junit.Assert.assertNotNull;
import static org.junit.Assert.assertTrue;


public class TestMMcifOrganismParsing {



	@BeforeClass
	public static void setUp() throws Exception {

		AtomCache cache = new AtomCache();
		cache.setFiletype(StructureFiletype.CIF);
		StructureIO.setAtomCache(cache);
	}

        @Ignore("The test requires the network")
	@Test
	public void test1STP() throws IOException, StructureException{
		String pdbId = "1stp";

		checkPDB(pdbId, "1895");

	}

	// removed this test, since entity 3 of 1a4w has no organism tax_id
	public void test1a4w() throws IOException, StructureException{
		String pdbId = "1a4w";

		checkPDB(pdbId, "9606");

	}

        @Ignore("The test requires the network")
	@Test
	public void test4hhb() throws IOException, StructureException{
		String pdbId = "4hhb";

		checkPDB(pdbId, "9606");

	}

        @Ignore("The test requires the network")
	@Test
	public void test3ZD6() throws IOException, StructureException {
		// a PDB ID that contains a synthetic entity
		String pdbId = "3zd6";

		checkPDB(pdbId, "9606");

	}


	private void checkPDB(String pdbId, String organismTaxId) throws IOException, StructureException {
		Structure s = StructureIO.getStructure(pdbId);

		assertNotNull(s.getEntityInfos());
		assertTrue(s.getEntityInfos().size() > 0);

		for ( EntityInfo c : s.getEntityInfos()) {
			if(EntityType.POLYMER.equals(c.getType())) {
				assertNotNull(c.getOrganismTaxId());
				if(pdbId.equals("3zd6")){
					if(c.getMolId()==2) {
						assertEquals(c.getOrganismTaxId(), "32630");
						continue;
					}
				}
				assertEquals(c.getOrganismTaxId(), organismTaxId);

			}
		}

	}

}