use crypto::PublicKey;
#[derive(Debug, Clone, PartialEq, Eq)]
pub struct Account {
account_id: PublicKey,
sequence: u64,
}
impl Account {
pub fn new(account_id: PublicKey, sequence: u64) -> Account {
Account {
account_id,
sequence,
}
}
pub fn account_id(&self) -> &PublicKey {
&self.account_id
}
pub fn increment_sequence(&mut self) -> u64 {
self.sequence += 1;
self.sequence
}
pub fn sequence(&self) -> u64 {
self.sequence
}
}
#[cfg(test)]
mod tests {
use super::Account;
use crypto::KeyPair;
#[test]
fn test_increment_sequence() {
let kp = KeyPair::random().unwrap();
let mut account = Account::new(kp.public_key().clone(), 999);
let seq = account.increment_sequence();
assert_eq!(seq, 1000);
assert_eq!(account.sequence(), 1000);
}
}