A metronome using the FRDM K64F board

mbed-client/test/mbedclient/utest/stub/m2mresource_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 "m2mresource_stub.h"

uint32_t m2mresource_stub::int_value;
uint8_t* m2mresource_stub::delayed_token;
uint8_t m2mresource_stub::delayed_token_len;
bool m2mresource_stub::bool_value;
// The statically initialized list must be bigh enough to cater
// for all the tests, or the utest framework will complain for memory leak.
M2MResourceInstanceList m2mresource_stub::list(12);

M2MResourceInstance *m2mresource_stub::instance;
M2MObjectInstance *m2mresource_stub::object_instance;
sn_coap_hdr_s *m2mresource_stub::header;
void m2mresource_stub::clear()
{
    int_value = 0;
    delayed_token = NULL;
    delayed_token_len = 0;
    bool_value = false;
    list.clear();
    instance = NULL;
    object_instance = NULL;
}

M2MResource::M2MResource(M2MObjectInstance &parent,
                         const String &resource_name,
                         const String &resource_type,
                         M2MResourceInstance::ResourceType type,
                         const uint8_t *value,
                         const uint8_t value_length,
                         char* path,
                         const uint16_t object_instance_id,
                         bool multiple_instance,
                         bool external_blockwise_store)
: M2MResourceInstance(*this, resource_name, resource_type, type, value, value_length, object_instance_id,
                      path, external_blockwise_store),
  _parent(parent),
  _delayed_token(NULL),
  _delayed_token_len(0),
  _has_multiple_instances(multiple_instance),
  _delayed_response(false)
{

}

M2MResource::M2MResource(M2MObjectInstance &parent,
                         const lwm2m_parameters_s* s,
                          M2MResourceInstance::ResourceType type,
                         const uint16_t object_instance_id)
: M2MResourceInstance(*this, s, type, object_instance_id),
  _parent(parent),
  _delayed_token(NULL),
  _delayed_token_len(0),
  _has_multiple_instances(false),
  _delayed_response(false)
{
    // tbd: _has_multiple_instances could be in flash, but no real benefit, because of current alignment.
}

M2MResource::M2MResource(M2MObjectInstance &parent,
                         const String &resource_name,
                         const String &resource_type,
                         M2MResourceInstance::ResourceType type,
                         bool observable,
                         char *path,
                         const uint16_t object_instance_id,
                         bool multiple_instance,
                         bool external_blockwise_store)
: M2MResourceInstance(*this, resource_name, resource_type, type,
                      object_instance_id, path, external_blockwise_store),
  _parent(parent),
  _delayed_token(NULL),
  _delayed_token_len(0),
  _has_multiple_instances(multiple_instance),
  _delayed_response(false)
{

}

M2MResource::~M2MResource()
{
}

bool M2MResource::supports_multiple_instances() const
{
    return m2mresource_stub::bool_value;
}

void M2MResource::get_delayed_token(unsigned char *&token, unsigned char &token_len)
{
    token_len = 0;
    if(token) {
        free(token);
        token = NULL;
    }
    token = (uint8_t *)malloc(m2mresource_stub::delayed_token_len);
    if(token) {
        token_len = m2mresource_stub::delayed_token_len;
        memcpy((uint8_t *)token, (uint8_t *)m2mresource_stub::delayed_token, token_len);
    }
}

bool M2MResource::remove_resource_instance(uint16_t inst_id)
{
    return m2mresource_stub::bool_value;
}

M2MResourceInstance* M2MResource::resource_instance(uint16_t inst_id) const
{
    return m2mresource_stub::instance;
}

const M2MResourceInstanceList& M2MResource::resource_instances() const
{
    return m2mresource_stub::list;
}

uint16_t M2MResource::resource_instance_count() const
{
    return m2mresource_stub::int_value;
}

bool M2MResource::handle_observation_attribute(const char *query)
{
    return m2mresource_stub::bool_value;
}

void M2MResource::add_resource_instance(M2MResourceInstance *)
{
}

void M2MResource::add_observation_level(M2MBase::Observation)
{
}

void M2MResource::remove_observation_level(M2MBase::Observation)
{
}

void M2MResource::notification_update()
{
}

sn_coap_hdr_s* M2MResource::handle_get_request(nsdl_s *,
                                               sn_coap_hdr_s *,
                                               M2MObservationHandler *)
{
    return m2mresource_stub::header;
}

sn_coap_hdr_s* M2MResource::handle_put_request(nsdl_s *,
                                               sn_coap_hdr_s *,
                                               M2MObservationHandler *,
                                               bool &)
{
    return m2mresource_stub::header;
}

sn_coap_hdr_s* M2MResource::handle_post_request(nsdl_s *,
                                               sn_coap_hdr_s *,
                                               M2MObservationHandler *,
                                               bool &, sn_nsdl_addr_s *)
{
    return m2mresource_stub::header;
}

M2MObjectInstance& M2MResource::get_parent_object_instance() const
{
    return *m2mresource_stub::object_instance;
}

const char* M2MResource::object_name() const
{

}