1*84e33947SAndroid Build Coastguard Worker /* 2*84e33947SAndroid Build Coastguard Worker * Copyright (C) 2022 The Android Open Source Project 3*84e33947SAndroid Build Coastguard Worker * 4*84e33947SAndroid Build Coastguard Worker * Licensed under the Apache License, Version 2.0 (the "License"); 5*84e33947SAndroid Build Coastguard Worker * you may not use this file except in compliance with the License. 6*84e33947SAndroid Build Coastguard Worker * You may obtain a copy of the License at 7*84e33947SAndroid Build Coastguard Worker * 8*84e33947SAndroid Build Coastguard Worker * http://www.apache.org/licenses/LICENSE-2.0 9*84e33947SAndroid Build Coastguard Worker * 10*84e33947SAndroid Build Coastguard Worker * Unless required by applicable law or agreed to in writing, software 11*84e33947SAndroid Build Coastguard Worker * distributed under the License is distributed on an "AS IS" BASIS, 12*84e33947SAndroid Build Coastguard Worker * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 13*84e33947SAndroid Build Coastguard Worker * See the License for the specific language governing permissions and 14*84e33947SAndroid Build Coastguard Worker * limitations under the License. 15*84e33947SAndroid Build Coastguard Worker */ 16*84e33947SAndroid Build Coastguard Worker 17*84e33947SAndroid Build Coastguard Worker #include <chrono> 18*84e33947SAndroid Build Coastguard Worker #include <condition_variable> 19*84e33947SAndroid Build Coastguard Worker #include <cstdint> 20*84e33947SAndroid Build Coastguard Worker #include <deque> 21*84e33947SAndroid Build Coastguard Worker #include <mutex> 22*84e33947SAndroid Build Coastguard Worker #include <vector> 23*84e33947SAndroid Build Coastguard Worker 24*84e33947SAndroid Build Coastguard Worker #include <android-base/thread_annotations.h> 25*84e33947SAndroid Build Coastguard Worker 26*84e33947SAndroid Build Coastguard Worker #include "chpp/transport.h" 27*84e33947SAndroid Build Coastguard Worker 28*84e33947SAndroid Build Coastguard Worker using ::std::literals::chrono_literals::operator""ms; 29*84e33947SAndroid Build Coastguard Worker 30*84e33947SAndroid Build Coastguard Worker namespace chpp::test { 31*84e33947SAndroid Build Coastguard Worker 32*84e33947SAndroid Build Coastguard Worker /** 33*84e33947SAndroid Build Coastguard Worker * Wrapper for a fake CHPP link layer which puts outgoing packets on a queue 34*84e33947SAndroid Build Coastguard Worker * where they can be extracted and inspected. 35*84e33947SAndroid Build Coastguard Worker */ 36*84e33947SAndroid Build Coastguard Worker class FakeLink { 37*84e33947SAndroid Build Coastguard Worker public: 38*84e33947SAndroid Build Coastguard Worker //! How long CHPP is expected to wait on an ACK for a transmitted packet 39*84e33947SAndroid Build Coastguard Worker static constexpr auto kTransportTimeout = 40*84e33947SAndroid Build Coastguard Worker std::chrono::duration_cast<std::chrono::milliseconds>( 41*84e33947SAndroid Build Coastguard Worker std::chrono::nanoseconds(CHPP_TRANSPORT_TX_TIMEOUT_NS)); 42*84e33947SAndroid Build Coastguard Worker 43*84e33947SAndroid Build Coastguard Worker // Our default timeout covers the retry timeout, plus some extra buffer to 44*84e33947SAndroid Build Coastguard Worker // account for processing delays 45*84e33947SAndroid Build Coastguard Worker static constexpr auto kDefaultTimeout = 10 * (kTransportTimeout + 5ms); 46*84e33947SAndroid Build Coastguard Worker 47*84e33947SAndroid Build Coastguard Worker /** 48*84e33947SAndroid Build Coastguard Worker * Call from link send. Makes a copy of the provided buffer and 49*84e33947SAndroid Build Coastguard Worker * appends it to the TX packet queue. 50*84e33947SAndroid Build Coastguard Worker */ 51*84e33947SAndroid Build Coastguard Worker void appendTxPacket(uint8_t *data, size_t len); 52*84e33947SAndroid Build Coastguard Worker 53*84e33947SAndroid Build Coastguard Worker //! Returns the number of TX packets waiting to be popped 54*84e33947SAndroid Build Coastguard Worker int getTxPacketCount(); // int to make EXPECT_EQ against a literal simpler 55*84e33947SAndroid Build Coastguard Worker // with -Wsign-compare enabled 56*84e33947SAndroid Build Coastguard Worker 57*84e33947SAndroid Build Coastguard Worker /** 58*84e33947SAndroid Build Coastguard Worker * Wait up to the provided timeout for a packet to hit the TX queue, or return 59*84e33947SAndroid Build Coastguard Worker * immediately if a packet is already waiting to be popped. 60*84e33947SAndroid Build Coastguard Worker * 61*84e33947SAndroid Build Coastguard Worker * @return true if a packet is waiting, false on timeout 62*84e33947SAndroid Build Coastguard Worker */ 63*84e33947SAndroid Build Coastguard Worker bool waitForTxPacket(std::chrono::milliseconds timeout = kDefaultTimeout); 64*84e33947SAndroid Build Coastguard Worker 65*84e33947SAndroid Build Coastguard Worker //! Pop and return the oldest packet on the TX queue, or assert if queue is 66*84e33947SAndroid Build Coastguard Worker //! empty 67*84e33947SAndroid Build Coastguard Worker std::vector<uint8_t> popTxPacket(); 68*84e33947SAndroid Build Coastguard Worker 69*84e33947SAndroid Build Coastguard Worker //! Empties the TX packet queue 70*84e33947SAndroid Build Coastguard Worker void reset(); 71*84e33947SAndroid Build Coastguard Worker 72*84e33947SAndroid Build Coastguard Worker private: 73*84e33947SAndroid Build Coastguard Worker std::mutex mMutex; 74*84e33947SAndroid Build Coastguard Worker std::condition_variable mCondVar; 75*84e33947SAndroid Build Coastguard Worker std::deque<std::vector<uint8_t>> mTxPackets GUARDED_BY(mMutex); 76*84e33947SAndroid Build Coastguard Worker }; 77*84e33947SAndroid Build Coastguard Worker 78*84e33947SAndroid Build Coastguard Worker } // namespace chpp::test