Ram Gandikota
/
ABCD
A metronome using the FRDM K64F board
mbed-client/test/mbedclient/utest/stub/m2mbase_stub.cpp
- Committer:
- ram54288
- Date:
- 2017-05-14
- Revision:
- 0:a7a43371b306
File content as of revision 0:a7a43371b306:
/* * Copyright (c) 2015 ARM Limited. All rights reserved. * SPDX-License-Identifier: Apache-2.0 * Licensed 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. */ #include "m2mbase_stub.h" #include "m2mstringbufferbase_stub.h" #include <assert.h> uint8_t m2mbase_stub::uint8_value; uint16_t m2mbase_stub::uint16_value; uint32_t m2mbase_stub::uint32_value; uint16_t m2mbase_stub::int_value; int32_t m2mbase_stub::name_id_value; bool m2mbase_stub::bool_value; const char *m2mbase_stub::string_value; const char *m2mbase_stub::object_instance_name; const char *m2mbase_stub::resource_name; const char *m2mbase_stub::resource_name_inst; M2MBase::BaseType m2mbase_stub::base_type; M2MBase::Operation m2mbase_stub::operation; M2MBase::Mode m2mbase_stub::mode_value; M2MBase::Observation m2mbase_stub::observation_level_value; void *m2mbase_stub::void_value; M2MObservationHandler *m2mbase_stub::observe; M2MReportHandler *m2mbase_stub::report; bool m2mbase_stub::is_value_updated_function_set; uint8_t *m2mbase_stub::object_inst_token; uint32_t m2mbase_stub::object_inst_token_len; uint8_t *m2mbase_stub::object_token; uint32_t m2mbase_stub::object_token_len; uint8_t *m2mbase_stub::resource_token; uint32_t m2mbase_stub::resource_token_len; sn_nsdl_dynamic_resource_parameters_s *m2mbase_stub::nsdl_resource; bool m2mbase_stub::find_resource; int32_t m2mbase_stub::ret_counter; void m2mbase_stub::clear() { int_value = 0; uint8_value = 0; uint16_value = 0; uint32_value = 0; string_value = NULL; object_instance_name = NULL; resource_name = NULL; resource_name_inst = NULL; name_id_value = -1; mode_value = M2MBase::Static; base_type = M2MBase::Object; observation_level_value = M2MBase::None; bool_value = false; m2mbase_stub::operation = M2MBase::NOT_ALLOWED; void_value = NULL; observe = NULL; report = NULL; is_value_updated_function_set = false; object_token = NULL; object_token_len = 0; resource_token = NULL; resource_token_len = 0; object_inst_token = NULL; object_inst_token_len = 0; find_resource = false; ret_counter = 0; } M2MBase::M2MBase(const String& resource_name, M2MBase::Mode mode, const String &resource_type, char *path, bool external_blockwise_store) : _sn_resource(NULL), _report_handler(NULL), _observation_handler(NULL), _token(NULL), _function_pointer(NULL), _observation_number(0), _token_length(0), _observation_level(M2MBase::None), _is_under_observation(false) { } M2MBase::M2MBase(const lwm2m_parameters_s *s): _sn_resource((lwm2m_parameters_s*) s), _report_handler(NULL), _observation_handler(NULL), _token(NULL), _function_pointer(NULL), _observation_number(0), _token_length(0), _observation_level(M2MBase::None), _is_under_observation(false) { } M2MBase::~M2MBase() { } void M2MBase::set_operation(M2MBase::Operation opr) { m2mbase_stub::operation = opr; } void M2MBase::set_interface_description(const String &/*desc*/) { } void M2MBase::set_resource_type(const String &/*res_type*/) { } void M2MBase::set_interface_description(const char */*desc*/) { } void M2MBase::set_resource_type(const char */*res_type*/) { } void M2MBase::set_coap_content_type(const uint8_t /*con_type*/) { } void M2MBase::set_instance_id(const uint16_t /*inst_id*/) { } void M2MBase::set_observation_number(const uint16_t /*observation_number*/) { } void M2MBase::set_max_age(const uint32_t /*max_age*/) { } M2MBase::Operation M2MBase::operation() const { return m2mbase_stub::operation; } const char* M2MBase::name() const { return m2mbase_stub::string_value; } int32_t M2MBase::name_id() const { return m2mbase_stub::name_id_value; } uint16_t M2MBase::instance_id() const { return m2mbase_stub::int_value; } const char* M2MBase::interface_description() const { return m2mbase_stub::string_value; } const char* M2MBase::resource_type() const { return m2mbase_stub::string_value; } uint8_t M2MBase::coap_content_type() const { return m2mbase_stub::uint8_value; } uint32_t M2MBase::max_age() const { return m2mbase_stub::uint32_value; } void M2MBase::set_observable(bool /*observable*/) { } void M2MBase::add_observation_level(M2MBase::Observation) { } void M2MBase::remove_observation_level(M2MBase::Observation) { } void M2MBase::set_under_observation(bool /*observed*/, M2MObservationHandler */*handler*/) { } void M2MBase::set_observation_token(const uint8_t */*token*/, const uint8_t /*length*/) { } bool M2MBase::is_observable() const { return m2mbase_stub::bool_value; } M2MBase::Observation M2MBase::observation_level() const { return m2mbase_stub::observation_level_value; } void M2MBase::get_observation_token(uint8_t *&token, uint32_t &length) { length = 0; if(token) { free(token); token = NULL; } if (m2mbase_stub::find_resource) { if (m2mbase_stub::ret_counter == 1) { token = (uint8_t *)malloc(m2mbase_stub::object_inst_token_len); if(token) { length = m2mbase_stub::object_inst_token_len; memcpy((uint8_t *)token, (uint8_t *)m2mbase_stub::object_inst_token, length); } } else if (m2mbase_stub::ret_counter == 2) { token = (uint8_t *)malloc(m2mbase_stub::resource_token_len); if(token) { length = m2mbase_stub::resource_token_len; memcpy((uint8_t *)token, (uint8_t *)m2mbase_stub::resource_token, length); } } else { token = (uint8_t *)malloc(m2mbase_stub::object_token_len); if(token) { length = m2mbase_stub::object_token_len; memcpy((uint8_t *)token, (uint8_t *)m2mbase_stub::object_token, length); } } m2mbase_stub::ret_counter++; } else { token = (uint8_t *)malloc(m2mbase_stub::object_token_len); if(token) { length = m2mbase_stub::object_token_len; memcpy((uint8_t *)token, (uint8_t *)m2mbase_stub::object_token, length); } } } void M2MBase::set_base_type(M2MBase::BaseType /*type*/) { } M2MBase::BaseType M2MBase::base_type() const { return m2mbase_stub::base_type; } M2MBase::Mode M2MBase::mode() const { return m2mbase_stub::mode_value; } uint16_t M2MBase::observation_number() const { return m2mbase_stub::uint16_value; } bool M2MBase::handle_observation_attribute(const char *query) { return m2mbase_stub::bool_value; } void M2MBase::observation_to_be_sent(m2m::Vector<uint16_t>, bool) { } void *M2MBase::memory_alloc(uint32_t size) { if(size) return malloc(size); else return 0; } void M2MBase::memory_free(void *ptr) { if(ptr) free(ptr); } uint8_t* M2MBase::alloc_string_copy(const uint8_t* source, uint32_t size) { assert(source != NULL); uint8_t* result = (uint8_t*)memory_alloc(size + 1); if (result) { memcpy(result, source, size); result[size] = '\0'; } return result; } uint8_t* M2MBase::alloc_copy(const uint8_t* source, uint32_t size) { assert(source != NULL); uint8_t* result = (uint8_t*)memory_alloc(size); if (result) { memcpy(result, source, size); } return result; } M2MReportHandler* M2MBase::report_handler() { return m2mbase_stub::report; } M2MObservationHandler* M2MBase::observation_handler() { return m2mbase_stub::observe; } sn_coap_hdr_s* M2MBase::handle_get_request(nsdl_s */*nsdl*/, sn_coap_hdr_s */*received_coap_header*/, M2MObservationHandler */*observation_handler*/) { //Handled in M2MResource, M2MObjectInstance and M2MObject classes return NULL; } sn_coap_hdr_s* M2MBase::handle_put_request(nsdl_s */*nsdl*/, sn_coap_hdr_s */*received_coap_header*/, M2MObservationHandler */*observation_handler*/, bool &execute_value_updated) { //Handled in M2MResource, M2MObjectInstance and M2MObject classes return NULL; } sn_coap_hdr_s* M2MBase::handle_post_request(nsdl_s */*nsdl*/, sn_coap_hdr_s */*received_coap_header*/, M2MObservationHandler */*observation_handler*/, bool &, sn_nsdl_addr_s *address) { //Handled in M2MResource, M2MObjectInstance and M2MObject classes return NULL; } void M2MBase::set_register_uri( bool register_uri) { } bool M2MBase::register_uri() { return m2mbase_stub::bool_value; } const char* M2MBase::uri_path() const { if (m2mbase_stub::find_resource) { m2mbase_stub::ret_counter++; if (m2mbase_stub::ret_counter == 2) { return m2mbase_stub::object_instance_name; } else if (m2mbase_stub::ret_counter == 3) { return m2mbase_stub::resource_name; } else if (m2mbase_stub::ret_counter == 4 || m2mbase_stub::ret_counter == 5) { return m2mbase_stub::resource_name_inst; } else { return m2mbase_stub::string_value; } } else { return m2mbase_stub::string_value; } } bool M2MBase::is_under_observation() const { return m2mbase_stub::bool_value; } void M2MBase::set_value_updated_function(value_updated_callback callback) { } void M2MBase::set_value_updated_function(value_updated_callback2 callback) { } bool M2MBase::is_value_updated_function_set() { return m2mbase_stub::is_value_updated_function_set; } void M2MBase::execute_value_updated(const String& name) { } bool M2MBase::build_path(StringBuffer<MAX_PATH_SIZE> &buffer, const char *s1, uint16_t i1, const char *s2, uint16_t i2) { if(!buffer.ensure_space(strlen(s1) + strlen(s2) + 10 + 3 + 1)){ return false; } buffer.append(s1); buffer.append('/'); buffer.append_int(i1); buffer.append('/'); buffer.append(s2); buffer.append('/'); buffer.append_int(i2); return true; } bool M2MBase::build_path(StringBuffer<MAX_PATH_SIZE_2> &buffer, const char *s1, uint16_t i1, const char *s2) { if(!buffer.ensure_space(strlen(s1) + strlen(s2) + 5 + 2 + 1)){ return false; } buffer.append(s1); buffer.append('/'); buffer.append_int(i1); buffer.append('/'); buffer.append(s2); return true; } bool M2MBase::build_path(StringBuffer<MAX_PATH_SIZE_3> &buffer, const char *s1, uint16_t i1, uint16_t i2) { if(!buffer.ensure_space(strlen(s1) + 10 + 2 + 1)){ return false; } buffer.append(s1); buffer.append('/'); buffer.append_int(i1); buffer.append('/'); buffer.append_int(i2); return true; } bool M2MBase::build_path(StringBuffer<MAX_PATH_SIZE_4> &buffer, const char *s1, uint16_t i1) { if(!buffer.ensure_space(strlen(s1) + 5 + 1 + 1)){ return false; } buffer.append(s1); buffer.append('/'); buffer.append_int(i1); return true; } sn_nsdl_dynamic_resource_parameters_s* M2MBase::get_nsdl_resource() { return m2mbase_stub::nsdl_resource; } char* M2MBase::stringdup(const char* src) { } char* M2MBase::create_path(const M2MObject &parent, uint16_t object_instance) { } char* M2MBase::create_path(const M2MObject &parent, const char *name) { } char* M2MBase::create_path(const M2MResource &parent, uint16_t resource_instance) { } char* M2MBase::create_path(const M2MResource &parent, const char *name) { } char* M2MBase::create_path(const M2MObjectInstance &parent, const char *name) { } void M2MBase::set_observation_handler(M2MObservationHandler *handler) { } size_t M2MBase::resource_name_length() const { } bool M2MBase::validate_string_length(const String &string, size_t min_length, size_t max_length) { return m2mbase_stub::bool_value; } bool M2MBase::validate_string_length(const char* string, size_t min_length, size_t max_length) { return m2mbase_stub::bool_value; } M2MReportHandler* M2MBase::create_report_handler() { }