libuavcan/libuavcan/test/protocol/helpers.hpp
Go to the documentation of this file.
1 /*
2  * Copyright (C) 2014 Pavel Kirienko <pavel.kirienko@gmail.com>
3  */
4 
5 #pragma once
6 
8 #include <uavcan/node/timer.hpp>
11 #include "../node/test_node.hpp"
12 
13 
14 template <typename DataType>
16 {
17  void handler(const DataType& msg)
18  {
19  this->msg.reset(new DataType(msg));
20  }
21 
22 public:
23  std::unique_ptr<DataType> msg;
24 
26  void (SubscriptionCollector::*)(const DataType&)> Binder;
27 
29 };
30 
31 
32 template <typename DataType>
34 {
37 
38  Collector collector;
39  Subscriber subscriber;
40 
42  : subscriber(node)
43  { }
44 
45  int start() { return subscriber.start(collector.bind()); }
46 };
47 
48 
49 template <typename DataType>
51 {
53 
54 public:
55  class Result
56  {
59  typename DataType::Response response_;
60 
61  public:
62  Result(typename ServiceCallResult::Status arg_status,
63  uavcan::ServiceCallID arg_call_id,
64  const typename DataType::Response& arg_response)
65  : status_(arg_status)
66  , call_id_(arg_call_id)
67  , response_(arg_response)
68  { }
69 
70  bool isSuccessful() const { return status_ == ServiceCallResult::Success; }
71 
72  typename ServiceCallResult::Status getStatus() const { return status_; }
73 
74  uavcan::ServiceCallID getCallID() const { return call_id_; }
75 
76  const typename DataType::Response& getResponse() const { return response_; }
77  typename DataType::Response& getResponse() { return response_; }
78  };
79 
80 private:
82  {
83  std::cout << tmp_result << std::endl;
84  result.reset(new Result(tmp_result.getStatus(), tmp_result.getCallID(), tmp_result.getResponse()));
85  }
86 
87 public:
88  std::unique_ptr<Result> result;
89 
91  void (ServiceCallResultCollector::*)(const uavcan::ServiceCallResult<DataType>&)>
93 
95 };
96 
97 
98 template <typename DataType>
100 {
103 
104  Collector collector;
105  ServiceClient client;
106 
108  : client(node)
109  { }
110 
111  int call(uavcan::NodeID node_id, const typename DataType::Request& request)
112  {
113  client.setCallback(collector.bind());
114  return client.call(node_id, request);
115  }
116 };
117 
118 
120 {
122 
123  BackgroundSpinner(uavcan::INode& spinning_node, uavcan::INode& running_node)
124  : uavcan::TimerBase(running_node)
125  , spinning_node(spinning_node)
126  { }
127 
129  {
130  spinning_node.spin(uavcan::MonotonicDuration::fromMSec(1));
131  }
132 };
133 
134 template <typename CanDriver, typename MessageType>
135 static inline void emulateSingleFrameBroadcastTransfer(CanDriver& can, uavcan::NodeID node_id,
136  const MessageType& message, uavcan::TransferID tid)
137 {
139  uavcan::BitStream bitstream(buffer);
140  uavcan::ScalarCodec codec(bitstream);
141 
142  // Manual message publication
143  ASSERT_LT(0, MessageType::encode(message, codec));
144  ASSERT_GE(8, buffer.getMaxWritePos());
145 
146  // DataTypeID data_type_id, TransferType transfer_type, NodeID src_node_id, NodeID dst_node_id,
147  // uint_fast8_t frame_index, TransferID transfer_id, bool last_frame
148  uavcan::Frame frame(MessageType::DefaultDataTypeID, uavcan::TransferTypeMessageBroadcast,
149  node_id, uavcan::NodeID::Broadcast, tid);
150  frame.setStartOfTransfer(true);
151  frame.setEndOfTransfer(true);
152 
153  ASSERT_EQ(buffer.getMaxWritePos(), frame.setPayload(buffer.getRawPtr(), buffer.getMaxWritePos()));
154 
155  uavcan::CanFrame can_frame;
156  ASSERT_TRUE(frame.compile(can_frame));
157 
158  can.pushRxToAllIfaces(can_frame);
159 }
ServiceCallID getCallID() const
Result(typename ServiceCallResult::Status arg_status, uavcan::ServiceCallID arg_call_id, const typename DataType::Response &arg_response)
static const NodeID Broadcast
Definition: transfer.hpp:122
uavcan::ServiceCallResult< DataType > ServiceCallResult
BackgroundSpinner(uavcan::INode &spinning_node, uavcan::INode &running_node)
void handler(const uavcan::ServiceCallResult< DataType > &tmp_result)
virtual void handleTimerEvent(const uavcan::TimerEvent &)
ServiceCallResultCollector< DataType > Collector
int call(uavcan::NodeID node_id, const typename DataType::Request &request)
uavcan::Subscriber< DataType, typename Collector::Binder > Subscriber
int spin(MonotonicTime deadline)
static void emulateSingleFrameBroadcastTransfer(CanDriver &can, uavcan::NodeID node_id, const MessageType &message, uavcan::TransferID tid)
int start(const Callback &callback)
Definition: subscriber.hpp:83
const ResponseFieldType & getResponse() const
void setCallback(const Callback &cb)
uavcan::CanFrame frame
Definition: can.cpp:78
static MonotonicDuration fromMSec(int64_t ms)
Definition: time.hpp:41
SubscriptionCollector< DataType > Collector
uavcan::ServiceClient< DataType, typename Collector::Binder > ServiceClient
class UAVCAN_EXPORT TimerBase
Definition: timer.hpp:27
uavcan::MethodBinder< SubscriptionCollector *, void(SubscriptionCollector::*)(const DataType &)> Binder
int call(NodeID server_node_id, const RequestType &request)


uavcan_communicator
Author(s):
autogenerated on Wed Jan 11 2023 03:59:39