blob: d3fdbbf61b578865fb3e68f35fb4962a53fe11d4 [file] [log] [blame]
/**
*Licensed to the Apache Software Foundation (ASF) under one
*or more contributor license agreements. See the NOTICE file
*distributed with this work for additional information
*regarding copyright ownership. The ASF licenses this file
*to you under the Apache License, Version 2.0 (the
*"License"); you may not use this file except in compliance
*with the License. You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
*Unless required by applicable law or agreed to in writing,
*software distributed under the License is distributed on an
*"AS IS" BASIS, WITHOUT WARRANTIES OR CONDITIONS OF ANY
* KIND, either express or implied. See the License for the
*specific language governing permissions and limitations
*under the License.
*/
/*
* manifest_parser_test.cpp
*
* \date Feb 11, 2013
* \author <a href="mailto:dev@celix.apache.org">Apache Celix Project Team</a>
* \copyright Apache License, Version 2.0
*/
#include <stdlib.h>
#include <stdio.h>
#include <string.h>
#include "CppUTest/TestHarness.h"
#include "CppUTest/TestHarness_c.h"
#include "CppUTest/CommandLineTestRunner.h"
#include "CppUTestExt/MockSupport.h"
extern "C" {
#include "capability_private.h"
#include "requirement_private.h"
#include "constants.h"
#include "manifest_parser.h"
#include "attribute.h"
#include "celix_log.h"
framework_logger_pt logger = (framework_logger_pt) 0x42;
}
int main(int argc, char** argv) {
return RUN_ALL_TESTS(argc, argv);
}
static char* my_strdup(const char* s) {
if (s == NULL) {
return NULL;
}
size_t len = strlen(s);
char *d = (char*) calloc(len + 1, sizeof(char));
if (d == NULL) {
return NULL;
}
strncpy(d, s, len);
return d;
}
TEST_GROUP(manifest_parser) {
void setup(void) {
}
void teardown() {
mock().checkExpectations();
mock().clear();
}
};
TEST(manifest_parser, create){
module_pt owner = (module_pt) 0x01;
manifest_pt manifest = (manifest_pt) 0x02;
manifest_parser_pt parser;
char * service_name_key = my_strdup("service");
char * service_version_key = my_strdup("version");
//get generic bundle data
char * version_str = my_strdup("1.2.3");
char * bundle_name = my_strdup("Test_Bundle");
version_pt version = (version_pt) 0x03;
mock().expectOneCall("manifest_getValue")
.withParameter("name", OSGI_FRAMEWORK_BUNDLE_VERSION)
.andReturnValue(version_str);
mock().expectOneCall("version_createVersionFromString")
.withParameter("versionStr", version_str)
.withOutputParameterReturning("version", &version, sizeof(version));
mock().expectOneCall("manifest_getValue")
.withParameter("name", OSGI_FRAMEWORK_BUNDLE_SYMBOLICNAME)
.andReturnValue(bundle_name);
//create capabilities
char * export_header = my_strdup("export_service_name;version=\"4.5.6\",export_service_name2;version=\"6.5.4\"");
char * cap_name = my_strdup("export_service_name");
char * cap_name2 = my_strdup("export_service_name2");
char * cap_version_str = my_strdup("4.5.6");
char * cap_version_str2 = my_strdup("6.5.4");
version_pt cap_version = (version_pt) 0x0A;
version_pt cap_version2 = (version_pt) 0x0B;
mock().expectOneCall("manifest_getValue")
.withParameter("name", OSGI_FRAMEWORK_EXPORT_LIBRARY)
.andReturnValue(export_header);
mock().expectOneCall("version_createVersionFromString")
.withParameter("versionStr", cap_version_str)
.withOutputParameterReturning("version", &cap_version, sizeof(cap_version));
mock().expectOneCall("version_createVersionFromString")
.withParameter("versionStr", cap_version_str2)
.withOutputParameterReturning("version", &cap_version2, sizeof(cap_version2));
//create requirements
char * import_header = my_strdup("import_service_name;version=\"[7.8,9)\",import_service_name2;version=\"[9.8,7)\"");
char * req_name = my_strdup("import_service_name");
char * req_name2 = my_strdup("import_service_name2");
char * req_version_str = my_strdup("[7.8,9)");
char * req_version_str2 = my_strdup("[9.8,7)");
version_range_pt req_version_range = (version_range_pt) 0x12;
version_range_pt req_version_range2 = (version_range_pt) 0x13;
mock().expectOneCall("manifest_getValue")
.withParameter("name", OSGI_FRAMEWORK_IMPORT_LIBRARY)
.andReturnValue(import_header);
mock().expectOneCall("versionRange_parse")
.withParameter("rangeStr", req_version_str)
.withOutputParameterReturning("range", &req_version_range, sizeof(req_version_range));
mock().expectOneCall("versionRange_parse")
.withParameter("rangeStr", req_version_str2)
.withOutputParameterReturning("range", &req_version_range2, sizeof(req_version_range2));
//actual call to create
manifestParser_create(owner, manifest, &parser);
//test getters
capability_pt get_cap;
requirement_pt get_req;
version_pt version_clone = (version_pt) 0x14;
version_pt get_version;
linked_list_pt get_caps;
linked_list_pt get_reqs;
char* get_bundle_name;
celix_status_t status;
mock().expectOneCall("version_clone")
.withParameter("version", version)
.withOutputParameterReturning("clone", &version_clone, sizeof(version_clone));
status = manifestParser_getBundleVersion(parser, &get_version);
LONGS_EQUAL(CELIX_SUCCESS, status);
POINTERS_EQUAL(version_clone, get_version);
status = manifestParser_getCapabilities(parser, &get_caps);
LONGS_EQUAL(CELIX_SUCCESS, status);
LONGS_EQUAL(2, linkedList_size(get_caps));
//check for both capabilities, in no specific order
get_cap = (capability_pt)linkedList_get(get_caps, 0);
if (strcmp(get_cap->serviceName, cap_name) == 0){
POINTERS_EQUAL(cap_version, get_cap->version);
get_cap = (capability_pt)linkedList_get(get_caps, 1);
STRCMP_EQUAL(cap_name2, get_cap->serviceName);
POINTERS_EQUAL(cap_version2, get_cap->version);
} else {
STRCMP_EQUAL(cap_name2, get_cap->serviceName);
POINTERS_EQUAL(cap_version2, get_cap->version);
get_cap = (capability_pt)linkedList_get(get_caps, 1);
STRCMP_EQUAL(cap_name, get_cap->serviceName);
POINTERS_EQUAL(cap_version, get_cap->serviceName);
}
status = manifestParser_getRequirements(parser, &get_reqs);
LONGS_EQUAL(CELIX_SUCCESS, status);
LONGS_EQUAL(2, linkedList_size(get_reqs));
//check for both requirements, in no specific order
get_req = (requirement_pt)linkedList_get(get_reqs, 0);
if (strcmp(get_req->targetName, req_name) == 0){
POINTERS_EQUAL(req_version_range, get_req->versionRange);
get_req = (requirement_pt)linkedList_get(get_reqs, 1);
STRCMP_EQUAL(req_name2, get_req->targetName);
POINTERS_EQUAL(req_version_range2, get_req->versionRange);
} else {
STRCMP_EQUAL(req_name2, get_req->targetName);
POINTERS_EQUAL(req_version_range2, get_req->versionRange);
get_req = (requirement_pt)linkedList_get(get_reqs, 1);
STRCMP_EQUAL(req_name, get_req->targetName);
POINTERS_EQUAL(req_version_range, get_req->versionRange);
}
status = manifestParser_getAndDuplicateSymbolicName(parser, &get_bundle_name);
LONGS_EQUAL(CELIX_SUCCESS, status);
STRCMP_EQUAL(bundle_name, get_bundle_name);
//cleanup
mock().expectOneCall("version_destroy")
.withParameter("version", version);
manifestParser_destroy(parser);
mock().expectOneCall("version_destroy")
.withParameter("version", cap_version);
mock().expectOneCall("version_destroy")
.withParameter("version", cap_version2);
mock().expectOneCall("versionRange_destroy")
.withParameter("range", req_version_range);
mock().expectOneCall("versionRange_destroy")
.withParameter("range", req_version_range2);
capability_destroy((capability_pt) linkedList_get(get_caps, 0));
capability_destroy((capability_pt) linkedList_get(get_caps, 1));
requirement_destroy((requirement_pt) linkedList_get(get_reqs, 0));
requirement_destroy((requirement_pt) linkedList_get(get_reqs, 1));
linkedList_destroy(get_caps);
linkedList_destroy(get_reqs);
free(service_name_key);
free(service_version_key);
free(version_str);
free(bundle_name);
free(export_header);
free(cap_name);
free(cap_name2);
free(cap_version_str);
free(cap_version_str2);
free(import_header);
free(req_name);
free(req_name2);
free(req_version_str);
free(req_version_str2);
free(get_bundle_name);
}