// Copyright (C) 2023 The Android Open Source Project // // 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. //! Provides useful subscribers for testing specifically. These should not be used in normal code. use crate::*; /// Represents a callback called by a [BufferPublisher] on a [BufferSubscriber]. pub enum TestingSubscriberEvent { /// Represents a call to [BufferSubscriber::on_subscribe]. Subscribe, /// Represents a call to [BufferSubscriber::on_next]. Next(Frame), /// Represents a call to [BufferSubscriber::on_error]. Error(BufferError), /// Represents a call to [BufferSubscriber::on_complete]. Complete, } /// A [BufferSubscriber] specifically for testing. Logs events as they happen which can be retrieved /// by the test to ensure appropriate behavior. pub struct TestSubscriber { config: StreamConfig, subscription: Option>, events: Vec, } impl TestSubscriber { /// Create a new [TestSubscriber]. pub fn new(config: StreamConfig) -> Self { Self { config, subscription: None, events: Vec::new() } } /// Returns true if this [BufferSubscriber] has an active subscription. pub fn has_subscription(&self) -> bool { self.subscription.is_some() } /// Make a request on behalf of this test subscriber. /// /// This will panic if there is no owned subscription. pub fn request(&self, n: u64) { let subscription = self .subscription .as_deref() .expect("Tried to request on a TestSubscriber with no subscription"); subscription.request(n); } /// Cancel on behalf of this test subscriber. /// /// # Panics /// /// This will panic if there is no owned subscription. pub fn cancel(&self) { let subscription = self .subscription .as_deref() .expect("Tried to cancel a TestSubscriber with no subscription"); subscription.cancel(); } /// Gets all of the events that have happened to this [BufferSubscriber] since the last call /// to this function or it was created. pub fn take_events(&mut self) -> Vec { let mut out = Vec::new(); out.append(&mut self.events); out } } impl BufferSubscriber for TestSubscriber { fn get_subscriber_stream_config(&self) -> StreamConfig { self.config } fn on_subscribe(&mut self, subscription: Box) { assert!(self.subscription.is_none(), "TestSubscriber must only be subscribed to once"); self.subscription = Some(subscription); self.events.push(TestingSubscriberEvent::Subscribe); } fn on_next(&mut self, frame: Frame) { self.events.push(TestingSubscriberEvent::Next(frame)); } fn on_error(&mut self, error: BufferError) { self.events.push(TestingSubscriberEvent::Error(error)); } fn on_complete(&mut self) { self.events.push(TestingSubscriberEvent::Complete); } }