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