pub struct Stack<T> {
data: Vec<T>,
}
impl<T> Stack<T> {
pub fn new() -> Self {
Stack {
data: Vec::new(),
}
}
pub fn push(&mut self, item: T) {
self.data.push(item);
}
pub fn pop(&mut self) -> Option<T> {
self.data.pop()
}
pub fn size(&self) -> usize {
self.data.len()
}
pub fn peek(&self) -> Option<&T> {
self.data.last()
}
}
impl<T> Default for Stack<T> {
fn default() -> Self {
Self::new()
}
}
impl <T> Iterator for Stack<T> {
type Item = T;
fn next(&mut self) -> Option<Self::Item> {
self.pop()
}
}
#[cfg(test)]
mod tests {
use super::*;
#[test]
fn create_stack() {
let stack: Stack<i32> = Stack::new();
assert_eq!(stack.data.len(), 0);
}
#[test]
fn push_to_stack() {
let mut stack = Stack::new();
stack.push(1);
assert_eq!(stack.data.len(), 1);
}
#[test]
fn pop_from_stack() {
let mut stack = Stack::new();
stack.push(1);
stack.push(2);
assert_eq!(stack.data.len(), 2);
assert_eq!(stack.pop(), Some(2));
assert_eq!(stack.pop(), Some(1));
assert_eq!(stack.pop(), None);
assert_eq!(stack.pop(), None);
}
#[test]
fn peek_from_stack() {
let mut stack = Stack::new();
stack.push(1);
stack.push(2);
assert_eq!(stack.data.len(), 2);
assert_eq!(stack.peek(), Some(&2));
}
#[test]
fn iterate_stack() {
let mut stack = Stack::new();
stack.push(1);
stack.push(2);
stack.push(3);
let mut iter = stack.into_iter();
assert_eq!(iter.next(), Some(3));
assert_eq!(iter.next(), Some(2));
assert_eq!(iter.next(), Some(1));
assert_eq!(iter.next(), None);
assert_eq!(iter.next(), None);
}
#[test]
fn get_stack_size_when_has_items() {
let mut stack = Stack::new();
stack.push(1);
stack.push(2);
stack.push(3);
assert_eq!(stack.size(), 3);
}
#[test]
fn get_stack_size_when_is_empty() {
let stack: Stack<i32> = Stack::new();
assert_eq!(stack.size(), 0);
}
}