From 28bce05de838dfe66dccae8a03b56d73447cf0f0 Mon Sep 17 00:00:00 2001 From: Jesse Brooklyn Hannah Date: Wed, 3 Aug 2022 10:20:17 -0700 Subject: [PATCH] Fix tests and math --- Cargo.lock | 2 +- Cargo.toml | 2 +- README.md | 10 +++++----- src/lib.rs | 26 +++++++++++++------------- src/pokemon/mod.rs | 24 ++++++++++++------------ 5 files changed, 32 insertions(+), 32 deletions(-) diff --git a/Cargo.lock b/Cargo.lock index 463b152..7179ee0 100644 --- a/Cargo.lock +++ b/Cargo.lock @@ -547,7 +547,7 @@ dependencies = [ [[package]] name = "pkpw" -version = "1.1.2" +version = "1.1.3" dependencies = [ "arboard", "assert_cmd", diff --git a/Cargo.toml b/Cargo.toml index c5637f5..270153b 100644 --- a/Cargo.toml +++ b/Cargo.toml @@ -1,6 +1,6 @@ [package] name = "pkpw" -version = "1.1.2" +version = "1.1.3" authors = ["Jesse Brooklyn Hannah "] edition = "2021" license = "MIT" diff --git a/README.md b/README.md index 531175d..f75dda5 100644 --- a/README.md +++ b/README.md @@ -17,7 +17,7 @@ cargo install pkpw ```console $ pkpw -h -pkpw 1.1.2 +pkpw 1.1.3 Jesse Brooklyn Hannah What if correct horse battery staple, but Pokémon. @@ -62,15 +62,15 @@ $$ where a brute-force attack will need an average of $2^{E-1}$ guesses to crack a password with $E$ bits of entropy. -By default, `pkpw` chooses **4** Pokémon names from the pool of [**913** known +By default, `pkpw` chooses **4** Pokémon names from the pool of [**915** known Pokémon][names], resulting in an entropy of $$ -E = log_2(913^4) \approx 39.338 +E = log_2(915^4) \approx 39.35 $$ -bits. A brute-force attack that knows to use the 913 known Pokémon names as -the pool of values would take $3.474 \times 10^{11}$ guesses on average to +bits. A brute-force attack that knows to use the 915 known Pokémon names as +the pool of values would take $3.505 \times 10^{11}$ guesses on average to correctly guess a password, or a bit more than **11 years** at 1000 guesses per second. diff --git a/src/lib.rs b/src/lib.rs index bd906de..2d7a8e4 100644 --- a/src/lib.rs +++ b/src/lib.rs @@ -68,10 +68,10 @@ mod test { /// Ensure that generate() generates a password string. #[test] fn test_generate() { - let mut rng = rng_from_seed(913); + let mut rng = rng_from_seed(915); assert_eq!( - "Shroomish Venusaur Froakie Tyranitar".to_string(), + "Smoliv Trapinch Swanna Aromatisse".to_string(), generate(None, 4, " ", &mut rng) ); } @@ -80,10 +80,10 @@ mod test { /// length. #[test] fn test_generate_length() { - let mut rng = rng_from_seed(913); + let mut rng = rng_from_seed(915); assert_eq!( - "Shroomish Venusaur Froakie Tyranitar Wingull".to_string(), + "Smoliv Trapinch Swanna Aromatisse Charjabug".to_string(), generate(Some(40), 4, " ", &mut rng) ); } @@ -92,10 +92,10 @@ mod test { /// separator between words. #[test] fn test_generate_separator() { - let mut rng = rng_from_seed(913); + let mut rng = rng_from_seed(915); assert_eq!( - "Shroomish-Venusaur-Froakie-Tyranitar".to_string(), + "Smoliv-Trapinch-Swanna-Aromatisse".to_string(), generate(None, 4, "-", &mut rng) ); } @@ -104,10 +104,10 @@ mod test { /// digit separators. #[test] fn test_generate_digit() { - let mut rng = rng_from_seed(913); + let mut rng = rng_from_seed(915); assert_eq!( - "Shroomish7Venusaur0Froakie2Tyranitar".to_string(), + "Smoliv7Trapinch6Swanna5Aromatisse".to_string(), generate(None, 4, "digit", &mut rng) ); } @@ -116,10 +116,10 @@ mod test { /// special character separators. #[test] fn test_generate_special() { - let mut rng = rng_from_seed(913); + let mut rng = rng_from_seed(915); assert_eq!( - "Shroomish#Venusaur`Froakie/Tyranitar".to_string(), + "Smoliv=Trapinch-Swanna/Aromatisse".to_string(), generate(None, 4, "special", &mut rng) ); } @@ -128,11 +128,11 @@ mod test { /// the slice of separators. #[test] fn test_join() { - let mut rng = rng_from_seed(913); - let picked = vec!["Shroomish", "Venusaur", "Froakie", "Tyranitar"]; + let mut rng = rng_from_seed(915); + let picked = vec!["Smoliv", "Trapinch", "Swanna", "Aromatisse"]; assert_eq!( - "Shroomish7Venusaur0Froakie2Tyranitar", + "Smoliv7Trapinch6Swanna5Aromatisse", join(picked, DIGITS, &mut rng) ); } diff --git a/src/pokemon/mod.rs b/src/pokemon/mod.rs index 9a61b40..5fc1786 100644 --- a/src/pokemon/mod.rs +++ b/src/pokemon/mod.rs @@ -3,7 +3,7 @@ use std::array::IntoIter; use lazy_static::lazy_static; use rand::{prelude::SliceRandom, Rng}; -pub const POKEMON_COUNT: usize = 913; +pub const POKEMON_COUNT: usize = 915; lazy_static! { /// Array of all Pokémon names, in English and ASCII-normalized (e.g. @@ -70,7 +70,7 @@ mod test { /// Pokémon names. #[test] fn test_new() { - let pokemon = from_seed(913); + let pokemon = from_seed(915); assert_eq!(pokemon.inner.len(), POKEMON_COUNT); assert_ne!(pokemon.inner, *POKEMON); @@ -80,7 +80,7 @@ mod test { /// arrays of names. #[test] fn test_new_new() { - let pokemon_1 = from_seed(913); + let pokemon_1 = from_seed(915); let pokemon_2 = from_seed(319); assert_ne!(pokemon_1.inner, pokemon_2.inner); @@ -92,7 +92,7 @@ mod test { /// names. #[test] fn test_into_inner() { - let pokemon = from_seed(913); + let pokemon = from_seed(915); let inner = pokemon.into_inner(); assert_eq!(inner.len(), POKEMON_COUNT); @@ -104,11 +104,11 @@ mod test { /// length 1. #[test] fn test_length() { - let mut pokemon = from_seed(913); + let mut pokemon = from_seed(915); let picked = pokemon.length(40, 1); assert_eq!( - vec!["Shroomish", "Venusaur", "Froakie", "Tyranitar", "Wingull"], + vec!["Smoliv", "Trapinch", "Swanna", "Aromatisse", "Charjabug"], picked ); assert!(picked.join(" ").len() > 40); @@ -117,10 +117,10 @@ mod test { /// Ensure that pick(4) returns a vector of four strings. #[test] fn test_pick() { - let mut pokemon = from_seed(913); + let mut pokemon = from_seed(915); assert_eq!( - vec!["Shroomish", "Venusaur", "Froakie", "Tyranitar"], + vec!["Smoliv", "Trapinch", "Swanna", "Aromatisse"], pokemon.pick(4) ); } @@ -129,15 +129,15 @@ mod test { /// names. #[test] fn test_pick_pick() { - let mut pokemon = from_seed(913); + let mut pokemon = from_seed(915); - assert_eq!(vec!["Shroomish", "Venusaur", "Froakie"], pokemon.pick(3)); - assert_eq!(vec!["Tyranitar", "Wingull"], pokemon.pick(2)); + assert_eq!(vec!["Smoliv", "Trapinch", "Swanna"], pokemon.pick(3)); + assert_eq!(vec!["Aromatisse", "Charjabug"], pokemon.pick(2)); } /// Ensure that all Pokémon names are loaded. #[test] fn test_pokemon() { - assert_eq!(POKEMON.len(), 913); + assert_eq!(POKEMON.len(), 915); } }