initial commit
This commit is contained in:
7
exercises/06_ticket_management/16_btreemap/Cargo.toml
Normal file
7
exercises/06_ticket_management/16_btreemap/Cargo.toml
Normal file
@@ -0,0 +1,7 @@
|
||||
[package]
|
||||
name = "btreemap"
|
||||
version = "0.1.0"
|
||||
edition = "2021"
|
||||
|
||||
[dependencies]
|
||||
ticket_fields = { path = "../../../helpers/ticket_fields" }
|
||||
135
exercises/06_ticket_management/16_btreemap/src/lib.rs
Normal file
135
exercises/06_ticket_management/16_btreemap/src/lib.rs
Normal file
@@ -0,0 +1,135 @@
|
||||
// TODO: Replace `todo!()`s with the correct implementation.
|
||||
// Implement `IntoIterator` for `&TicketStore`. The iterator should yield immutable
|
||||
// references to the tickets, ordered by their `TicketId`.
|
||||
// Implement additional traits on `TicketId` if needed.
|
||||
|
||||
use std::collections::BTreeMap;
|
||||
use std::ops::{Index, IndexMut};
|
||||
use ticket_fields::{TicketDescription, TicketTitle};
|
||||
|
||||
#[derive(Clone)]
|
||||
pub struct TicketStore {
|
||||
tickets: BTreeMap<TicketId, Ticket>,
|
||||
counter: u64,
|
||||
}
|
||||
|
||||
#[derive(Clone, Copy, Debug, PartialEq)]
|
||||
pub struct TicketId(u64);
|
||||
|
||||
#[derive(Clone, Debug, PartialEq)]
|
||||
pub struct Ticket {
|
||||
pub id: TicketId,
|
||||
pub title: TicketTitle,
|
||||
pub description: TicketDescription,
|
||||
pub status: Status,
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug, PartialEq, Eq)]
|
||||
pub struct TicketDraft {
|
||||
pub title: TicketTitle,
|
||||
pub description: TicketDescription,
|
||||
}
|
||||
|
||||
#[derive(Clone, Debug, Copy, PartialEq, Eq)]
|
||||
pub enum Status {
|
||||
ToDo,
|
||||
InProgress,
|
||||
Done,
|
||||
}
|
||||
|
||||
impl TicketStore {
|
||||
pub fn new() -> Self {
|
||||
Self {
|
||||
tickets: todo!(),
|
||||
counter: 0,
|
||||
}
|
||||
}
|
||||
|
||||
pub fn add_ticket(&mut self, ticket: TicketDraft) -> TicketId {
|
||||
let id = TicketId(self.counter);
|
||||
self.counter += 1;
|
||||
let ticket = Ticket {
|
||||
id,
|
||||
title: ticket.title,
|
||||
description: ticket.description,
|
||||
status: Status::ToDo,
|
||||
};
|
||||
todo!();
|
||||
id
|
||||
}
|
||||
|
||||
pub fn get(&self, id: TicketId) -> Option<&Ticket> {
|
||||
todo!()
|
||||
}
|
||||
|
||||
pub fn get_mut(&mut self, id: TicketId) -> Option<&mut Ticket> {
|
||||
todo!()
|
||||
}
|
||||
}
|
||||
|
||||
impl Index<TicketId> for TicketStore {
|
||||
type Output = Ticket;
|
||||
|
||||
fn index(&self, index: TicketId) -> &Self::Output {
|
||||
self.get(index).unwrap()
|
||||
}
|
||||
}
|
||||
|
||||
impl Index<&TicketId> for TicketStore {
|
||||
type Output = Ticket;
|
||||
|
||||
fn index(&self, index: &TicketId) -> &Self::Output {
|
||||
&self[*index]
|
||||
}
|
||||
}
|
||||
|
||||
impl IndexMut<TicketId> for TicketStore {
|
||||
fn index_mut(&mut self, index: TicketId) -> &mut Self::Output {
|
||||
self.get_mut(index).unwrap()
|
||||
}
|
||||
}
|
||||
|
||||
impl IndexMut<&TicketId> for TicketStore {
|
||||
fn index_mut(&mut self, index: &TicketId) -> &mut Self::Output {
|
||||
&mut self[*index]
|
||||
}
|
||||
}
|
||||
|
||||
#[cfg(test)]
|
||||
mod tests {
|
||||
use crate::{Status, TicketDraft, TicketId, TicketStore};
|
||||
use ticket_fields::test_helpers::{ticket_description, ticket_title};
|
||||
|
||||
#[test]
|
||||
fn works() {
|
||||
let mut store = TicketStore::new();
|
||||
|
||||
let n_tickets = 5;
|
||||
|
||||
for i in 0..n_tickets {
|
||||
let draft = TicketDraft {
|
||||
title: ticket_title(),
|
||||
description: ticket_description(),
|
||||
};
|
||||
let id = store.add_ticket(draft.clone());
|
||||
let ticket = &store[id];
|
||||
assert_eq!(draft.title, ticket.title);
|
||||
assert_eq!(draft.description, ticket.description);
|
||||
assert_eq!(ticket.status, Status::ToDo);
|
||||
|
||||
let ticket = &mut store[id];
|
||||
ticket.status = Status::InProgress;
|
||||
|
||||
let ticket = &store[id];
|
||||
assert_eq!(ticket.status, Status::InProgress);
|
||||
}
|
||||
|
||||
let ids: Vec<TicketId> = (&store).into_iter().map(|t| t.id).collect();
|
||||
let sorted_ids = {
|
||||
let mut v = ids.clone();
|
||||
v.sort();
|
||||
v
|
||||
};
|
||||
assert_eq!(ids, sorted_ids);
|
||||
}
|
||||
}
|
||||
Reference in New Issue
Block a user