1 /**
2  * @file    TestL3v2EMExtension.cpp
3  * @brief   TestL3v2EMExtension unit tests
4  * @author  Sarah M Keating
5  *
6  * <!--------------------------------------------------------------------------
7  * This file is part of libSBML.  Please visit http://sbml.org for more
8  * information about SBML, and the latest version of libSBML.
9  *
10  * Copyright (C) 2020 jointly by the following organizations:
11  *     1. California Institute of Technology, Pasadena, CA, USA
12  *     2. University of Heidelberg, Heidelberg, Germany
13  *     3. University College London, London, UK
14  *
15  * Copyright (C) 2019 jointly by the following organizations:
16  *     1. California Institute of Technology, Pasadena, CA, USA
17  *     2. University of Heidelberg, Heidelberg, Germany
18  *
19  * Copyright (C) 2013-2018 jointly by the following organizations:
20  *     1. California Institute of Technology, Pasadena, CA, USA
21  *     2. EMBL European Bioinformatics Institute (EMBL-EBI), Hinxton, UK
22  *     3. University of Heidelberg, Heidelberg, Germany
23  *
24  * Copyright (C) 2009-2011 jointly by the following organizations:
25  *     1. California Institute of Technology, Pasadena, CA, USA
26  *     2. EMBL European Bioinformatics Institute (EMBL-EBI), Hinxton, UK
27  *
28  * Copyright (C) 2006-2008 by the California Institute of Technology,
29  *     Pasadena, CA, USA
30  *
31  * Copyright (C) 2002-2005 jointly by the following organizations:
32  *     1. California Institute of Technology, Pasadena, CA, USA
33  *     2. Japan Science and Technology Agency, Japan
34  *
35  * This library is free software; you can redistribute it and/or modify it
36  * under the terms of the GNU Lesser General Public License as published by
37  * the Free Software Foundation.  A copy of the license agreement is provided
38  * in the file named "LICENSE.txt" included with this software distribution
39  * and also available online as http://sbml.org/software/libsbml/license.html
40  * ---------------------------------------------------------------------- -->*/
41 
42 #include <limits>
43 
44 #include <iostream>
45 #include <check.h>
46 #include <sbml/common/extern.h>
47 #include <sbml/packages/l3v2extendedmath/common/L3v2extendedmathExtensionTypes.h>
48 #include <sbml/extension/SBMLExtensionRegistry.h>
49 #include <sbml/SBMLTypeCodes.h>
50 #include <string>
51 
52 /** @cond doxygenIgnored */
53 
54 using namespace std;
55 LIBSBML_CPP_NAMESPACE_USE
56 
57 /** @endcond doxygenIgnored */
58 
59 
60 CK_CPPSTART
61 
62 static L3v2extendedmathExtension* G;
63 static L3v2extendedmathPkgNamespaces* GNS;
64 static string L3V2EM_XMLNS_L3V1V1;
65 static string CORE_XMLNS_L2V4;
66 static string L3V2EM_PACKAGE_NAME;
67 
68 void
L3v2EMExtensionTest_setup(void)69 L3v2EMExtensionTest_setup (void)
70 {
71   try
72   {
73     G = new L3v2extendedmathExtension();
74     GNS = new L3v2extendedmathPkgNamespaces();
75     L3V2EM_PACKAGE_NAME = G->getName();
76     L3V2EM_XMLNS_L3V1V1 = GNS->getURI();
77     CORE_XMLNS_L2V4 = SBMLNamespaces::getSBMLNamespaceURI(2, 4);
78   }
79   catch(...)
80   {
81     fail("Failed to create a L3v2extendedmathExtension object");
82   }
83 }
84 
85 
86 void
L3v2EMExtensionTest_teardown(void)87 L3v2EMExtensionTest_teardown (void)
88 {
89   delete G;
90   delete GNS;
91 }
92 
93 
START_TEST(test_L3v2EMExtension_getName)94 START_TEST (test_L3v2EMExtension_getName)
95 {
96   fail_unless(G->getName() == "l3v2extendedmath");
97   fail_unless(G->getName() == L3V2EM_PACKAGE_NAME);
98 }
99 END_TEST
100 
101 
START_TEST(test_L3v2EMExtension_getURI)102 START_TEST (test_L3v2EMExtension_getURI)
103 {
104   fail_unless(G->getURI(3,1,1) == L3V2EM_XMLNS_L3V1V1);
105   fail_unless(G->getURI(2,1,1) == "");
106   fail_unless(G->getURI(4,1,1) == "");
107 }
108 END_TEST
109 
110 
START_TEST(test_L3v2EMExtension_getLevelVersion)111 START_TEST (test_L3v2EMExtension_getLevelVersion)
112 {
113   fail_unless(G->getLevel(L3V2EM_XMLNS_L3V1V1) == 3);
114   fail_unless(G->getLevel(CORE_XMLNS_L2V4)             == 0);
115   fail_unless(G->getLevel("")                          == 0);
116 
117   fail_unless(G->getVersion(L3V2EM_XMLNS_L3V1V1) == 1);
118   fail_unless(G->getVersion(CORE_XMLNS_L2V4)             == 0);
119   fail_unless(G->getVersion("")                          == 0);
120 
121   fail_unless(G->getPackageVersion(L3V2EM_XMLNS_L3V1V1) == 1);
122   fail_unless(G->getPackageVersion(CORE_XMLNS_L2V4)             == 0);
123   fail_unless(G->getPackageVersion("")                          == 0);
124 }
125 END_TEST
126 
127 
START_TEST(test_L3v2EMExtension_getSBMLExtensionNamespaces)128 START_TEST (test_L3v2EMExtension_getSBMLExtensionNamespaces)
129 {
130   L3v2extendedmathPkgNamespaces *l3v2extendedmathns;
131   l3v2extendedmathns = static_cast<L3v2extendedmathPkgNamespaces*>(G->getSBMLExtensionNamespaces(L3V2EM_XMLNS_L3V1V1));
132 
133   fail_unless(l3v2extendedmathns->getLevel()          == 3);
134   fail_unless(l3v2extendedmathns->getVersion()        == 1);
135   fail_unless(l3v2extendedmathns->getPackageVersion() == 1);
136 
137   delete l3v2extendedmathns;
138   l3v2extendedmathns = static_cast<L3v2extendedmathPkgNamespaces*>(G->getSBMLExtensionNamespaces(""));
139 
140   fail_unless(l3v2extendedmathns == NULL);
141 }
142 END_TEST
143 
144 
START_TEST(test_L3v2EMExtension_copy)145 START_TEST(test_L3v2EMExtension_copy)
146 {
147   L3v2extendedmathExtension *g2 = new L3v2extendedmathExtension(*G);
148 
149   fail_unless(g2->getName() == "l3v2extendedmath");
150   fail_unless(g2->getName() == L3V2EM_PACKAGE_NAME);
151 
152   fail_unless(g2->getURI(3,1,1) == L3V2EM_XMLNS_L3V1V1);
153   fail_unless(g2->getURI(2,1,1) == "");
154   fail_unless(g2->getURI(4,1,1) == "");
155 
156   fail_unless(g2->getLevel(L3V2EM_XMLNS_L3V1V1) == 3);
157   fail_unless(g2->getLevel(CORE_XMLNS_L2V4)             == 0);
158   fail_unless(g2->getLevel("")                          == 0);
159 
160   fail_unless(g2->getVersion(L3V2EM_XMLNS_L3V1V1) == 1);
161   fail_unless(g2->getVersion(CORE_XMLNS_L2V4)             == 0);
162   fail_unless(g2->getVersion("")                          == 0);
163 
164   fail_unless(g2->getPackageVersion(L3V2EM_XMLNS_L3V1V1) == 1);
165   fail_unless(g2->getPackageVersion(CORE_XMLNS_L2V4)             == 0);
166   fail_unless(g2->getPackageVersion("")                          == 0);
167 
168   delete g2;
169 }
170 END_TEST
171 
172 
START_TEST(test_L3v2EMExtension_assignment)173 START_TEST(test_L3v2EMExtension_assignment)
174 {
175   L3v2extendedmathExtension* g2 = new L3v2extendedmathExtension();
176 
177   (*g2) = (*G);
178 
179   fail_unless(g2->getName() == "l3v2extendedmath");
180   fail_unless(g2->getName() == L3V2EM_PACKAGE_NAME);
181 
182   fail_unless(g2->getURI(3,1,1) == L3V2EM_XMLNS_L3V1V1);
183   fail_unless(g2->getURI(2,1,1) == "");
184   fail_unless(g2->getURI(4,1,1) == "");
185 
186   fail_unless(g2->getLevel(L3V2EM_XMLNS_L3V1V1) == 3);
187   fail_unless(g2->getLevel(CORE_XMLNS_L2V4)             == 0);
188   fail_unless(g2->getLevel("")                          == 0);
189 
190   fail_unless(g2->getVersion(L3V2EM_XMLNS_L3V1V1) == 1);
191   fail_unless(g2->getVersion(CORE_XMLNS_L2V4)             == 0);
192   fail_unless(g2->getVersion("")                          == 0);
193 
194   fail_unless(g2->getPackageVersion(L3V2EM_XMLNS_L3V1V1) == 1);
195   fail_unless(g2->getPackageVersion(CORE_XMLNS_L2V4)             == 0);
196   fail_unless(g2->getPackageVersion("")                          == 0);
197 
198   delete g2;
199 }
200 END_TEST
201 
202 
START_TEST(test_L3v2EMExtension_clone)203 START_TEST(test_L3v2EMExtension_clone)
204 {
205   L3v2extendedmathExtension* g2 = G->clone();
206 
207   fail_unless(g2->getName() == "l3v2extendedmath");
208   fail_unless(g2->getName() == L3V2EM_PACKAGE_NAME);
209 
210   fail_unless(g2->getURI(3,1,1) == L3V2EM_XMLNS_L3V1V1);
211   fail_unless(g2->getURI(2,1,1) == "");
212   fail_unless(g2->getURI(4,1,1) == "");
213 
214   fail_unless(g2->getLevel(L3V2EM_XMLNS_L3V1V1) == 3);
215   fail_unless(g2->getLevel(CORE_XMLNS_L2V4)             == 0);
216   fail_unless(g2->getLevel("")                          == 0);
217 
218   fail_unless(g2->getVersion(L3V2EM_XMLNS_L3V1V1) == 1);
219   fail_unless(g2->getVersion(CORE_XMLNS_L2V4)             == 0);
220   fail_unless(g2->getVersion("")                          == 0);
221 
222   fail_unless(g2->getPackageVersion(L3V2EM_XMLNS_L3V1V1) == 1);
223   fail_unless(g2->getPackageVersion(CORE_XMLNS_L2V4)             == 0);
224   fail_unless(g2->getPackageVersion("")                          == 0);
225 
226   delete g2;
227 }
228 END_TEST
229 
230 
START_TEST(test_L3v2EMExtension_registry)231 START_TEST(test_L3v2EMExtension_registry)
232 {
233   const SBMLExtension* sbext = SBMLExtensionRegistry::getInstance().getExtension("l3v2extendedmath");
234 
235   fail_unless(sbext != NULL);
236 
237   fail_unless(sbext->getName() == "l3v2extendedmath");
238   fail_unless(sbext->getName() == L3V2EM_PACKAGE_NAME);
239 
240   fail_unless(sbext->getURI(3,1,1) == L3V2EM_XMLNS_L3V1V1);
241   fail_unless(sbext->getURI(2,1,1) == "");
242   fail_unless(sbext->getURI(4,1,1) == "");
243 
244   fail_unless(sbext->getLevel(L3V2EM_XMLNS_L3V1V1) == 3);
245   fail_unless(sbext->getLevel(CORE_XMLNS_L2V4)             == 0);
246   fail_unless(sbext->getLevel("")                          == 0);
247 
248   fail_unless(sbext->getVersion(L3V2EM_XMLNS_L3V1V1) == 1);
249   fail_unless(sbext->getVersion(CORE_XMLNS_L2V4)             == 0);
250   fail_unless(sbext->getVersion("")                          == 0);
251 
252   fail_unless(sbext->getPackageVersion(L3V2EM_XMLNS_L3V1V1) == 1);
253   fail_unless(sbext->getPackageVersion(CORE_XMLNS_L2V4)             == 0);
254   fail_unless(sbext->getPackageVersion("")                          == 0);
255 
256   delete sbext;
257 }
258 END_TEST
259 
260 
261 Suite *
create_suite_L3v2EMExtension(void)262 create_suite_L3v2EMExtension (void)
263 {
264   Suite *suite = suite_create("L3v2EMExtension");
265   TCase *tcase = tcase_create("L3v2EMExtension");
266 
267   tcase_add_checked_fixture(tcase, L3v2EMExtensionTest_setup, L3v2EMExtensionTest_teardown);
268 
269   tcase_add_test( tcase, test_L3v2EMExtension_getName         );
270   tcase_add_test( tcase, test_L3v2EMExtension_getURI          );
271   tcase_add_test( tcase, test_L3v2EMExtension_getLevelVersion );
272   tcase_add_test( tcase, test_L3v2EMExtension_getSBMLExtensionNamespaces);
273   tcase_add_test( tcase, test_L3v2EMExtension_copy            );
274   tcase_add_test( tcase, test_L3v2EMExtension_assignment      );
275   tcase_add_test( tcase, test_L3v2EMExtension_clone           );
276   tcase_add_test( tcase, test_L3v2EMExtension_registry        );
277 
278   suite_add_tcase(suite, tcase);
279 
280   return suite;
281 }
282 
283 
284 CK_CPPEND
285