/// /// @file TestSBMLDocument.cs /// @brief SBMLDocument unit tests /// @author Frank Bergmann (Csharp conversion) /// @author Akiya Jouraku (Csharp conversion) /// @author Ben Bornstein /// /// $Id: TestSBMLDocument.cs 8982 2009-02-02 22:13:53Z ajouraku $ /// $HeadURL: https://sbml.svn.sourceforge.net/svnroot/sbml/trunk/libsbml/src/bindings/csharp/test/sbml/TestSBMLDocument.cs $ /// /// This test file was converted from src/sbml/test/TestSBMLDocument.c /// with the help of conversion sciprt (ctest_converter.pl). /// /// */ namespace LibSBMLCSTest { using libsbml; using System.IO; public class TestSBMLDocument { public class AssertionError : System.Exception { public AssertionError() : base() { } } static void assertTrue(bool condition) { if (condition == true) { return; } throw new AssertionError(); } static void assertEquals(object a, object b) { if ( (a == null) && (b == null) ) { return; } else if (a.Equals(b)) { return; } throw new AssertionError(); } static void assertNotEquals(object a, object b) { if ( (a == null) && (b == null) ) { throw new AssertionError(); } else if (a.Equals(b)) { throw new AssertionError(); } } static void assertEquals(bool a, bool b) { if ( a == b ) { return; } throw new AssertionError(); } static void assertNotEquals(bool a, bool b) { if ( a != b ) { return; } throw new AssertionError(); } static void assertEquals(int a, int b) { if ( a == b ) { return; } throw new AssertionError(); } static void assertNotEquals(int a, int b) { if ( a != b ) { return; } throw new AssertionError(); } public void test_SBMLDocument_create() { SBMLDocument d = new SBMLDocument(); assertTrue( d.getTypeCode() == libsbml.SBML_DOCUMENT ); assertTrue( d.getNotes() == null ); assertTrue( d.getAnnotation() == null ); assertTrue( d.getLevel() == 2 ); assertTrue( d.getVersion() == 4 ); assertTrue( d.getNumErrors() == 0 ); d = null; } public void test_SBMLDocument_createWith() { SBMLDocument d = new SBMLDocument(1,2); assertTrue( d.getTypeCode() == libsbml.SBML_DOCUMENT ); assertTrue( d.getNotes() == null ); assertTrue( d.getAnnotation() == null ); assertTrue( d.getLevel() == 1 ); assertTrue( d.getVersion() == 2 ); assertTrue( d.getNumErrors() == 0 ); d = null; } public void test_SBMLDocument_free_NULL() { } public void test_SBMLDocument_setLevelAndVersion() { SBMLDocument d = new SBMLDocument(); d.setLevelAndVersion(2,2); Model m1 = new Model(); d.setModel(m1); assertTrue( d.setLevelAndVersion(2,3) == true ); assertTrue( d.setLevelAndVersion(2,1) == true ); assertTrue( d.setLevelAndVersion(1,2) == true ); assertTrue( d.setLevelAndVersion(1,1) == false ); d = null; } public void test_SBMLDocument_setLevelAndVersion_Error() { SBMLDocument d = new SBMLDocument(); d.setLevelAndVersion(2,1); Model m1 = new Model(); Unit u = new Unit(); u.setKind(libsbml.UnitKind_forName("mole")); u.setOffset(3.2); UnitDefinition ud = new UnitDefinition(); ud.addUnit(u); m1.addUnitDefinition(ud); d.setModel(m1); assertTrue( d.setLevelAndVersion(2,2) == false ); assertTrue( d.setLevelAndVersion(2,3) == false ); assertTrue( d.setLevelAndVersion(1,2) == false ); assertTrue( d.setLevelAndVersion(1,1) == false ); d = null; } public void test_SBMLDocument_setLevelAndVersion_UnitsError() { SBMLDocument d = new SBMLDocument(); d.setLevelAndVersion(2,4); Model m1 = d.createModel(); Compartment c = m1.createCompartment(); c.setId( "c"); Parameter p = m1.createParameter(); p.setId( "p"); p.setUnits( "mole"); Rule r = m1.createAssignmentRule(); r.setVariable( "c"); r.setFormula( "p*p"); assertTrue( d.setLevelAndVersion(2,2) == true ); assertTrue( d.setLevelAndVersion(2,3) == true ); assertTrue( d.setLevelAndVersion(1,2) == true ); assertTrue( d.setLevelAndVersion(1,1) == false ); d = null; } public void test_SBMLDocument_setLevelAndVersion_Warning() { SBMLDocument d = new SBMLDocument(); d.setLevelAndVersion(2,2); Model m1 = new Model(); (m1).setSBOTerm(2); d.setModel(m1); assertTrue( d.setLevelAndVersion(2,3) == true ); assertTrue( d.setLevelAndVersion(2,1) == true ); assertTrue( d.setLevelAndVersion(1,2) == true ); assertTrue( d.setLevelAndVersion(1,1) == false ); d = null; } public void test_SBMLDocument_setModel() { SBMLDocument d = new SBMLDocument(); Model m1 = new Model(); Model m2 = new Model(); assertEquals(d.getModel(),null); d.setModel(m1); assertNotEquals(d.getModel(),m1); d.setModel(d.getModel()); assertNotEquals(d.getModel(),m1); d.setModel(m2); assertNotEquals(d.getModel(),m2); d = null; } } }